--- /srv/reproducible-results/rbuild-debian/r-b-build.DqxQPpxk/b1/opensubdiv_3.6.0-3_arm64.changes +++ /srv/reproducible-results/rbuild-debian/r-b-build.DqxQPpxk/b2/opensubdiv_3.6.0-3_arm64.changes ├── Files │ @@ -1,9 +1,9 @@ │ │ 756c2111ff7fd5d86b14199f3b8d2a6d 153216 libdevel optional libosd-dev_3.6.0-3_arm64.deb │ - b7e2d2d91a454bb6d2e2e7963b541dc4 31493456 doc optional libosd-doc_3.6.0-3_all.deb │ + 9ac70bca0c61d3ff29825271b1400519 31493148 doc optional libosd-doc_3.6.0-3_all.deb │ 2314c8e84a727d46bf695606ebd0c32b 3484920 debug optional libosdcpu3.6.0-dbgsym_3.6.0-3_arm64.deb │ 198abe2bead00b79fb563197238f4b33 303132 libs optional libosdcpu3.6.0_3.6.0-3_arm64.deb │ f9cf9a726d46b0696dd61c47d4e5e02f 546684 debug optional libosdgpu3.6.0-dbgsym_3.6.0-3_arm64.deb │ 9c582741340b6cabdba07842b729f47d 133496 libs optional libosdgpu3.6.0_3.6.0-3_arm64.deb │ 9f69a1083d0ad7b4e93616e59ea8f0a9 12180348 debug optional opensubdiv-tools-dbgsym_3.6.0-3_arm64.deb │ f73e21bf1f09f001f5f5394f468458a0 581744 graphics optional opensubdiv-tools_3.6.0-3_arm64.deb ├── libosd-doc_3.6.0-3_all.deb │ ├── file list │ │ @@ -1,3 +1,3 @@ │ │ -rw-r--r-- 0 0 0 4 2025-01-02 08:47:46.000000 debian-binary │ │ --rw-r--r-- 0 0 0 25548 2025-01-02 08:47:46.000000 control.tar.xz │ │ --rw-r--r-- 0 0 0 31467716 2025-01-02 08:47:46.000000 data.tar.xz │ │ +-rw-r--r-- 0 0 0 25436 2025-01-02 08:47:46.000000 control.tar.xz │ │ +-rw-r--r-- 0 0 0 31467520 2025-01-02 08:47:46.000000 data.tar.xz │ ├── control.tar.xz │ │ ├── control.tar │ │ │ ├── ./md5sums │ │ │ │ ├── ./md5sums │ │ │ │ │┄ Files differ │ │ │ │ ├── line order │ │ │ │ │ @@ -107,35 +107,35 @@ │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00761_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00764.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00764_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00767.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00767.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00767_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00770.html │ │ │ │ │ +usr/share/doc/opensubdiv/doxy_html/a00770.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00770_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00773.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00773.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00773_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00776.html │ │ │ │ │ -usr/share/doc/opensubdiv/doxy_html/a00776.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00776_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00779.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00779.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00779_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00782.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00782_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00785.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00785_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00788.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00788.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00788_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00791.html │ │ │ │ │ +usr/share/doc/opensubdiv/doxy_html/a00791.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00791_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00794.html │ │ │ │ │ -usr/share/doc/opensubdiv/doxy_html/a00794.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00794_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00797.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00797.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00797_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00800.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00800.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00800_source.html │ │ │ │ │ @@ -217,17 +217,17 @@ │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00878.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00878.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00878_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00881.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00881.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00881_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00884.html │ │ │ │ │ +usr/share/doc/opensubdiv/doxy_html/a00884.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00884_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00887.html │ │ │ │ │ -usr/share/doc/opensubdiv/doxy_html/a00887.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00887_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00890.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00890.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00890_source.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00893.html │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00893.js │ │ │ │ │ usr/share/doc/opensubdiv/doxy_html/a00893_source.html │ ├── data.tar.xz │ │ ├── data.tar │ │ │ ├── file list │ │ │ │ @@ -33,62 +33,62 @@ │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6575 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00674.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 69 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00674.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 76686 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00674_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7384 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00677.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 109 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00677.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 65515 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00677_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6557 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00680.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 78 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00680.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 35227 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00680_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 7310 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00683.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 195 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00683.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 27166 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00683_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 7310 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00680.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 195 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00680.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 27166 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00680_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6557 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00683.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 78 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00683.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 35227 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00683_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7503 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00686.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 111 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00686.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 88830 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00686_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 7764 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00689.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 150 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00689.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 40417 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00689_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 7074 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00692.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 120 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00692.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 75918 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00692_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6435 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00695.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 69 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00695.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 45701 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00695_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6386 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00698.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 55 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00698.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 14298 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00698_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 7074 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00689.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 120 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00689.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 75918 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00689_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 7764 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00692.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 150 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00692.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 40417 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00692_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6386 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00695.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 55 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00695.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 14298 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00695_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6435 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00698.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 69 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00698.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 45701 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00698_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7836 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00704.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 190 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00704.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 147346 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00704_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6697 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00707.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 66 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00707.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 66667 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00707_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 8006 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00710.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 171 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00710.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 74097 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00710_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 8006 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00707.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 171 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00707.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 74097 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00707_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6697 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00710.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 66 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00710.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 66667 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00710_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7135 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00713.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 119 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00713.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 38038 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00713_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 9922 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00716.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 456 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00716.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 177058 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00716_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 9467 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00719.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 404 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00719.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 84413 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00719_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 9467 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00716.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 404 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00716.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 84413 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00716_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 8222 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00719.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 130 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00719.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 212260 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00719_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6562 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00722.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 64 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00722.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 19419 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00722_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 7812 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00725.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 163 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00725.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 67818 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00725_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 8222 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00728.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 130 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00728.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 212260 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00728_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 9922 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00725.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 456 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00725.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 177058 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00725_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 7812 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00728.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 163 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00728.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 67818 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00728_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7335 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00731.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 111 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00731.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 167870 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00731_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6744 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00734.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 103 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00734.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 42246 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00734_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 8123 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00737.html │ │ │ │ @@ -98,82 +98,82 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 160 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00740.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 53847 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00740_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 11426 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00743.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1173 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00743.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 22910 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00743_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5643 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00746.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 38293 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00746_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 5898 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00749.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 22112 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00749_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6081 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00752.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 85952 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00752_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6201 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00755.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 163472 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00755_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6201 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00749.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 163472 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00749_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 5898 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00752.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 22112 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00752_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6081 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00755.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 85952 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00755_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6288 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00758.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 24306 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00758_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6266 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00761.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 81482 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00761_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6113 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00764.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 29125 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00764_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6436 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00767.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 121 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00767.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 46437 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00767_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 5826 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00770.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 100441 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00770_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 7579 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00773.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 130 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00773.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 135866 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00773_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6473 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00776.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 59 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00776.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 53912 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00776_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6297 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00779.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 60 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00779.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 38673 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00779_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 7579 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00770.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 130 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00770.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 135866 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00770_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6297 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00773.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 60 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00773.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 38673 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00773_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 5826 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00776.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 100441 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00776_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6473 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00779.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 59 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00779.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 53912 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00779_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5835 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00782.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 89789 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00782_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5752 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00785.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 38296 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00785_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7124 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00788.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 115 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00788.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 128978 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00788_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 4477 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00791.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 10582 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00791_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6806 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00794.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 67 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00794.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 33909 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00794_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6806 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00791.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 67 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00791.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 33909 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00791_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 4477 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00794.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 10582 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00794_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6424 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00797.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 67 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00797.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 23840 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00797_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6896 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00800.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 65 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00800.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 34222 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00800_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7173 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00803.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 115 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00803.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 252039 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00803_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6160 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00806.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 63 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00806.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 14082 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00806_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6498 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00809.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 69 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00809.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 21924 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00809_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6579 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00812.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 99 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00812.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 12708 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00812_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6579 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00809.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 99 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00809.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 12708 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00809_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6498 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00812.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 69 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00812.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 21924 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00812_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6817 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00815.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 66 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00815.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 35393 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00815_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6451 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00818.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 79 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00818.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 25441 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00818_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 7051 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00821.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 124 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00821.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 223873 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00821_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6245 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00824.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 71 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00824.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 22525 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00824_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6245 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00818.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 71 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00818.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 22525 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00818_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6451 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00821.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 79 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00821.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 25441 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00821_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 7051 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00824.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 124 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00824.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 223873 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00824_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6508 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00827.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 70 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00827.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 18295 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00827_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6591 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00830.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 101 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00830.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 12825 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00830_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6357 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00833.html │ │ │ │ @@ -181,20 +181,20 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 22932 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00833_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6765 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00836.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 68 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00836.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 27920 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00836_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6356 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00839.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 81 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00839.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 26983 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00839_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6409 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00842.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 73 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00842.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 22722 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00842_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 7016 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00845.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 128 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00845.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 49760 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00845_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 7016 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00842.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 128 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00842.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 49760 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00842_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6409 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00845.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 73 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00845.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 22722 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00845_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7224 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00848.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 126 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00848.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 224156 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00848_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7198 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00851.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 121 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00851.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 239107 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00851_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6508 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00854.html │ │ │ │ @@ -211,43 +211,43 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 19961 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00863_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6496 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00866.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 70 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00866.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 21039 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00866_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6444 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00869.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 78 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00869.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 23458 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00869_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 11269 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00872.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 424 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00872.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 29215 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00872_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 8720 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00875.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 262 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00875.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 21258 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00875_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6380 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00878.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 61 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00878.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 111060 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00878_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 8720 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00872.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 262 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00872.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 21258 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00872_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6380 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00875.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 61 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00875.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 111060 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00875_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 11269 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00878.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 424 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00878.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 29215 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00878_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6380 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00881.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 61 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00881.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 110975 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00881_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 4473 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00884.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 12882 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00884_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6369 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00887.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 68 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00887.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 19253 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00887_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6369 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00884.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 68 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00884.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 19253 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00884_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 4473 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00887.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 12882 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00887_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 14200 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00890.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2466 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00890.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 182424 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00890_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6910 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00893.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 66 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00893.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 44338 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00893_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6686 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00896.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 69 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00896.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 27491 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00896_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 6380 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00899.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 61 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00899.js │ │ │ │ --rw-r--r-- 0 root (0) root (0) 110646 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00899_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6380 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00896.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 61 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00896.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 110646 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00896_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 6686 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00899.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 69 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00899.js │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 27491 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00899_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6374 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00902.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 69 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00902.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 20015 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00902_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 4658 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00905.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 71 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00905.js │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5891 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00906.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 216 2025-01-02 08:47:46.000000 ./usr/share/doc/opensubdiv/doxy_html/a00906.js │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00674_source.html │ │ │ │ @@ -503,15 +503,15 @@ │ │ │ │
443} // end namespace Bfr
│ │ │ │
444
│ │ │ │
445} // end namespace OPENSUBDIV_VERSION
│ │ │ │
446using namespace OPENSUBDIV_VERSION;
│ │ │ │
447} // end namespace OpenSubdiv
│ │ │ │
448
│ │ │ │
449#endif /* OPENSUBDIV3_BFR_VERTEX_DESCRIPTOR_H */
│ │ │ │ -
OpenSubdiv
Definition limits.h:32
│ │ │ │ +
OpenSubdiv
Definition limits.h:32
│ │ │ │
OpenSubdiv::OPENSUBDIV_VERSION::Bfr::VertexDescriptor
Simple class used by subclasses of SurfaceFactory to describe a vertex.
Definition vertexDescriptor.h:131
│ │ │ │
OpenSubdiv::OPENSUBDIV_VERSION::Bfr::VertexDescriptor::GetVertexSharpness
float GetVertexSharpness() const
Return the sharpness of the vertex.
Definition vertexDescriptor.h:386
│ │ │ │
OpenSubdiv::OPENSUBDIV_VERSION::Bfr::VertexDescriptor::Finalize
bool Finalize()
Terminate the sequence of specifications.
│ │ │ │
OpenSubdiv::OPENSUBDIV_VERSION::Bfr::VertexDescriptor::SetManifold
void SetManifold(bool isManifold)
Declare the vertex neighborhood as manifold (ordered)
Definition vertexDescriptor.h:325
│ │ │ │
OpenSubdiv::OPENSUBDIV_VERSION::Bfr::VertexDescriptor::Initialize
bool Initialize(int numIncidentFaces)
Initialize specification with the number of incident faces.
│ │ │ │
OpenSubdiv::OPENSUBDIV_VERSION::Bfr::VertexDescriptor::IsManifold
bool IsManifold() const
Return if vertex neighborhood is manifold.
Definition vertexDescriptor.h:329
│ │ │ │
OpenSubdiv::OPENSUBDIV_VERSION::Bfr::VertexDescriptor::HasEdgeSharpness
bool HasEdgeSharpness() const
Return if sharpness was assigned to the incident edges.
Definition vertexDescriptor.h:394
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00677.html │ │ │ │ @@ -94,15 +94,15 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
tessellation.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../bfr/parameterization.h"
│ │ │ │ +#include "../bfr/parameterization.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00677_source.html │ │ │ │ @@ -340,17 +340,17 @@ │ │ │ │
379
│ │ │ │
380} // end namespace OPENSUBDIV_VERSION
│ │ │ │
381using namespace OPENSUBDIV_VERSION;
│ │ │ │
382
│ │ │ │
383} // end namespace OpenSubdiv
│ │ │ │
384
│ │ │ │
385#endif /* OPENSUBDIV3_BFR_TESSELLATION */
│ │ │ │ -
Definition limits.h:32
│ │ │ │ -
Simple class defining the 2D parameterization of a face.
│ │ │ │ -
int GetFaceSize() const
Returns the size (number of vertices) of the corresponding face.
│ │ │ │ +
Definition limits.h:32
│ │ │ │ +
Simple class defining the 2D parameterization of a face.
│ │ │ │ +
int GetFaceSize() const
Returns the size (number of vertices) of the corresponding face.
│ │ │ │
void GetVertexCoord(int vertexIndex, REAL uvCoord[2]) const
Returns the (u,v) coordinate of a given vertex.
│ │ │ │
Encapsulates a specific tessellation pattern of a Parameterization.
│ │ │ │
int GetFaceSize() const
Return the size of the face.
│ │ │ │
int GetNumBoundaryCoords() const
Return the number of boundary coordinates.
│ │ │ │
~Tessellation()
│ │ │ │
void TransformFacetCoordIndices(int facetTuples[], int const boundaryIndices[], int const interiorIndices[])
Reassign all facet coordinate indices.
│ │ │ │
int GetCoordStride() const
Return the number of elements between each coordinate.
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00680.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/surfaceFactoryMeshAdapter.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/bfr/surfaceFactoryCache.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,26 +90,31 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
surfaceFactoryMeshAdapter.h File Reference
│ │ │ │ +
surfaceFactoryCache.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ +#include "../bfr/irregularPatchType.h"
│ │ │ │ +#include <map>
│ │ │ │ #include <cstdint>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  Tessellation
 Encapsulates a specific tessellation pattern of a Parameterization. More...
│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  SurfaceFactoryMeshAdapter
 Abstract interface adapting SurfaceFactory to a connected mesh representation. More...
class  SurfaceFactoryCache
 Container used internally by SurfaceFactory to store reusable information. More...
 
class  SurfaceFactoryCacheThreaded< MUTEX_TYPE, READ_LOCK_GUARD_TYPE, WRITE_LOCK_GUARD_TYPE >
 Template for declaring thread-safe subclasses of SurfaceFactoryCache. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -118,13 +123,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,25 +1,32 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -surfaceFactoryMeshAdapter.h File Reference │ │ │ │ │ +surfaceFactoryCache.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ +#include "../bfr/irregularPatchType.h" │ │ │ │ │ +#include │ │ │ │ │ #include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r │ │ │ │ │ -  Abstract interface adapting _S_u_r_f_a_c_e_F_a_c_t_o_r_y to a connected mesh │ │ │ │ │ - representation. _M_o_r_e_._._. │ │ │ │ │ +class   _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ +  Container used internally by _S_u_r_f_a_c_e_F_a_c_t_o_r_y to store reusable │ │ │ │ │ + information. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +class   _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d_<_ _M_U_T_E_X___T_Y_P_E_,_ _R_E_A_D___L_O_C_K___G_U_A_R_D___T_Y_P_E_, │ │ │ │ │ + _W_R_I_T_E___L_O_C_K___G_U_A_R_D___T_Y_P_E_ _> │ │ │ │ │ +  Template for declaring thread-safe subclasses of _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h │ │ │ │ │ + * _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00680.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,4 @@ │ │ │ │ │ var a00680 = [ │ │ │ │ │ - ["SurfaceFactoryMeshAdapter", "a00957.html", "a00957"] │ │ │ │ │ + ["SurfaceFactoryCache", "a00949.html", "a00949"], │ │ │ │ │ + ["SurfaceFactoryCacheThreaded< MUTEX_TYPE, READ_LOCK_GUARD_TYPE, WRITE_LOCK_GUARD_TYPE >", "a00953.html", "a00953"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00680_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/surfaceFactoryMeshAdapter.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/bfr/surfaceFactoryCache.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
surfaceFactoryMeshAdapter.h
│ │ │ │ +
surfaceFactoryCache.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2021 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,149 +119,126 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H
│ │ │ │ -
26#define OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H
│ │ │ │ +
26#define OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │
29
│ │ │ │ -
30#include <cstdint>
│ │ │ │ +
30#include "../bfr/irregularPatchType.h"
│ │ │ │
31
│ │ │ │ -
32namespace OpenSubdiv {
│ │ │ │ -
33namespace OPENSUBDIV_VERSION {
│ │ │ │ +
32#include <map>
│ │ │ │ +
33#include <cstdint>
│ │ │ │
34
│ │ │ │ -
35namespace Bfr {
│ │ │ │ -
36
│ │ │ │ -
37class VertexDescriptor;
│ │ │ │ -
38
│ │ │ │ -
43// SurfaceFactoryMeshAdapter is an abstract class that defines the interface
│ │ │ │ -
44// through which subclasses of SurfaceFactory adapt to a connected mesh
│ │ │ │ -
45// representation. The interface defines methods that describe the mesh
│ │ │ │ -
46// topology and control indices in the neighborhood of a mesh -- from
│ │ │ │ -
47// which the SurfaceFactory to identifies an appropriate limit surface.
│ │ │ │ -
48//
│ │ │ │ -
49// SurfaceFactoryMeshAdapter methods require a subclass to provide a complete
│ │ │ │ -
50// description of the topology around a base face, as well as indices
│ │ │ │ -
51// associated with it (both vertex and face-varying). The intent here is
│ │ │ │ -
52// to keep the number of methods required to a minimum, and also to minimize
│ │ │ │ -
53// the number of invocations required by the factory.
│ │ │ │ -
54//
│ │ │ │ -
55// With the need to support both linear and non-linear cases (for which
│ │ │ │ -
56// linear is trivial by comparison) and the limit surface for both vertex
│ │ │ │ -
57// and face-varying topologies, the result is a small set of methods
│ │ │ │ -
58// covering this matrix of functionality.
│ │ │ │ -
59//
│ │ │ │ -
60// Since face-varying data may differ in topology from the vertex data --
│ │ │ │ -
61// with each set of face-varying data potentially having its own unique
│ │ │ │ -
62// topology -- sets of face-varying data are uniquely distinguished by an
│ │ │ │ -
63// associated integer (a face-varying ID).
│ │ │ │ -
64//
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
66public:
│ │ │ │ -
68 typedef int Index;
│ │ │ │ -
69
│ │ │ │ -
80 typedef std::intptr_t FVarID;
│ │ │ │ -
81
│ │ │ │ -
82protected:
│ │ │ │ - │ │ │ │ -
85 virtual ~SurfaceFactoryMeshAdapter() { }
│ │ │ │ -
87
│ │ │ │ -
88protected:
│ │ │ │ -
90
│ │ │ │ -
94
│ │ │ │ -
96 virtual bool isFaceHole(Index faceIndex) const = 0;
│ │ │ │ -
97
│ │ │ │ -
99 virtual int getFaceSize(Index faceIndex) const = 0;
│ │ │ │ -
101
│ │ │ │ -
103
│ │ │ │ -
111
│ │ │ │ -
113 virtual int getFaceVertexIndices(Index faceIndex,
│ │ │ │ -
114 Index vertexIndices[]) const = 0;
│ │ │ │ -
115
│ │ │ │ -
117 virtual int getFaceFVarValueIndices(Index faceIndex,
│ │ │ │ -
118 FVarID fvarID, Index fvarValueIndices[]) const = 0;
│ │ │ │ -
120
│ │ │ │ -
121protected:
│ │ │ │ -
123
│ │ │ │ -
159
│ │ │ │ - │ │ │ │ -
162 Index faceIndex, int faceVertex,
│ │ │ │ -
163 VertexDescriptor * vertexDescriptor) const = 0;
│ │ │ │ -
164
│ │ │ │ - │ │ │ │ -
167 Index faceIndex, int faceVertex,
│ │ │ │ -
168 Index vertexIndices[]) const = 0;
│ │ │ │ -
169
│ │ │ │ - │ │ │ │ -
173 Index faceIndex, int faceVertex,
│ │ │ │ -
174 FVarID fvarID, Index fvarValueIndices[]) const = 0;
│ │ │ │ -
176
│ │ │ │ -
177protected:
│ │ │ │ -
179
│ │ │ │ - │ │ │ │ -
204 Index faceIndex, Index vertexIndices[]) const;
│ │ │ │ -
205
│ │ │ │ - │ │ │ │ -
207 Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const;
│ │ │ │ -
209
│ │ │ │ -
210private:
│ │ │ │ -
211 // No private members
│ │ │ │ -
212};
│ │ │ │ -
│ │ │ │ -
213
│ │ │ │ -
214//
│ │ │ │ -
215// Inline defaults for optional methods:
│ │ │ │ -
216//
│ │ │ │ -
217inline bool
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
219 Index, Index[]) const {
│ │ │ │ -
220 return false;
│ │ │ │ -
221}
│ │ │ │ -
│ │ │ │ -
222
│ │ │ │ -
223inline bool
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
225 Index, FVarID, Index[]) const {
│ │ │ │ -
226 return false;
│ │ │ │ -
227}
│ │ │ │ -
│ │ │ │ -
228
│ │ │ │ -
229} // end namespace Bfr
│ │ │ │ -
230
│ │ │ │ -
231} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
232using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
233
│ │ │ │ -
234} // end namespace OpenSubdiv
│ │ │ │ -
235
│ │ │ │ -
236#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H */
│ │ │ │ - │ │ │ │ -
Abstract interface adapting SurfaceFactory to a connected mesh representation.
│ │ │ │ -
virtual int getFaceVertexIncidentFaceFVarValueIndices(Index faceIndex, int faceVertex, FVarID fvarID, Index fvarValueIndices[]) const =0
Gather face-varying indices of incident faces around a face-vertex.
│ │ │ │ -
virtual int getFaceVertexIncidentFaceVertexIndices(Index faceIndex, int faceVertex, Index vertexIndices[]) const =0
Gather vertex indices of incident faces around a face-vertex.
│ │ │ │ -
virtual int getFaceSize(Index faceIndex) const =0
Returns the size of a face (number of vertices)
│ │ │ │ - │ │ │ │ -
virtual int populateFaceVertexDescriptor(Index faceIndex, int faceVertex, VertexDescriptor *vertexDescriptor) const =0
Describe the topology of incident faces around a face-vertex.
│ │ │ │ -
virtual bool getFaceNeighborhoodVertexIndicesIfRegular(Index faceIndex, Index vertexIndices[]) const
│ │ │ │ -
virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular(Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const
│ │ │ │ -
virtual int getFaceFVarValueIndices(Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const =0
Gather the face-varying indices of the face's vertices.
│ │ │ │ -
virtual int getFaceVertexIndices(Index faceIndex, Index vertexIndices[]) const =0
Gather the indices of the face's vertices.
│ │ │ │ -
virtual bool isFaceHole(Index faceIndex) const =0
Returns if a face is a hole.
│ │ │ │ -
std::intptr_t FVarID
Type used to identify and specify face-varying primvars.
│ │ │ │ -
Simple class used by subclasses of SurfaceFactory to describe a vertex.
│ │ │ │ +
35namespace OpenSubdiv {
│ │ │ │ +
36namespace OPENSUBDIV_VERSION {
│ │ │ │ +
37
│ │ │ │ +
38namespace Bfr {
│ │ │ │ +
39
│ │ │ │ +
52//
│ │ │ │ +
53// Initial/expected use requires simple searches of and additions to the
│ │ │ │ +
54// cache by the SurfaceFactory or its Builders. Longer term, with the
│ │ │ │ +
55// possibility of instances of caches being shared between meshes and
│ │ │ │ +
56// factories, additional options and/or public methods may be warranted
│ │ │ │ +
57// to limit what is cached or to prune the cache if it gets too large.
│ │ │ │ +
58//
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
60public:
│ │ │ │ + │ │ │ │ + │ │ │ │ +
63
│ │ │ │ + │ │ │ │ + │ │ │ │ +
66
│ │ │ │ +
67protected:
│ │ │ │ +
69 // Access restricted to the Factory, its Builders, etc.
│ │ │ │ +
70 friend class SurfaceFactory;
│ │ │ │ +
71
│ │ │ │ +
72 typedef std::uint64_t KeyType;
│ │ │ │ +
73 typedef internal::IrregularPatchSharedPtr DataType;
│ │ │ │ +
75
│ │ │ │ +
76protected:
│ │ │ │ +
78 size_t Size() const { return _map.size(); }
│ │ │ │ +
79
│ │ │ │ +
80 //
│ │ │ │ +
81 // Potential overrides by subclasses for thread-safety:
│ │ │ │ +
82 //
│ │ │ │ +
83 virtual DataType Find(KeyType const & key) const;
│ │ │ │ +
84 virtual DataType Add(KeyType const & key, DataType const & data);
│ │ │ │ +
85
│ │ │ │ +
86 //
│ │ │ │ +
87 // Common implementation used by all subclasses:
│ │ │ │ +
88 //
│ │ │ │ +
89 DataType find(KeyType const & key) const;
│ │ │ │ +
90 DataType add(KeyType const & key, DataType const & data);
│ │ │ │ +
92
│ │ │ │ +
93private:
│ │ │ │ +
94 typedef std::map<KeyType, DataType> MapType;
│ │ │ │ +
95
│ │ │ │ +
96 MapType _map;
│ │ │ │ +
97};
│ │ │ │ +
│ │ │ │ +
98
│ │ │ │ +
113// Separate read and write locks are provided to support mutex types
│ │ │ │ +
114// allowing shared (read) or exclusive (write) access.
│ │ │ │ +
115//
│ │ │ │ +
116template <class MUTEX_TYPE, class READ_LOCK_GUARD_TYPE,
│ │ │ │ +
117 class WRITE_LOCK_GUARD_TYPE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
119public:
│ │ │ │ + │ │ │ │ +
121 ~SurfaceFactoryCacheThreaded() override = default;
│ │ │ │ +
122
│ │ │ │ +
123protected:
│ │ │ │ +
125 //
│ │ │ │ +
126 // Virtual overrides from base:
│ │ │ │ +
127 //
│ │ │ │ +
128 DataType Find(KeyType const & key) const override {
│ │ │ │ +
129 READ_LOCK_GUARD_TYPE lockGuard(_mutex);
│ │ │ │ +
130 return find(key);
│ │ │ │ +
131 }
│ │ │ │ +
132
│ │ │ │ +
133 DataType Add(KeyType const & key, DataType const & data) override {
│ │ │ │ +
134 WRITE_LOCK_GUARD_TYPE lockGuard(_mutex);
│ │ │ │ +
135 return add(key, data);
│ │ │ │ +
136 }
│ │ │ │ +
138
│ │ │ │ +
139private:
│ │ │ │ +
140 MUTEX_TYPE mutable _mutex;
│ │ │ │ +
141};
│ │ │ │ +
│ │ │ │ +
142
│ │ │ │ +
143} // end namespace Bfr
│ │ │ │ +
144
│ │ │ │ +
145} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
146using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
147
│ │ │ │ +
148} // end namespace OpenSubdiv
│ │ │ │ +
149
│ │ │ │ +
150#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H */
│ │ │ │ + │ │ │ │ +
Base class providing initialization of a Surface for each face of a mesh.
│ │ │ │ +
Container used internally by SurfaceFactory to store reusable information.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
SurfaceFactoryCache(SurfaceFactoryCache const &)=delete
│ │ │ │ +
SurfaceFactoryCache & operator=(SurfaceFactoryCache const &)=delete
│ │ │ │ +
Template for declaring thread-safe subclasses of SurfaceFactoryCache.
│ │ │ │ + │ │ │ │ + │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -surfaceFactoryMeshAdapter.h │ │ │ │ │ +surfaceFactoryCache.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2021 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,179 +24,131 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H │ │ │ │ │ -26#define OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H │ │ │ │ │ +26#define OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ 29 │ │ │ │ │ -30#include │ │ │ │ │ +30#include "../bfr/irregularPatchType.h" │ │ │ │ │ 31 │ │ │ │ │ -32namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -33namespace OPENSUBDIV_VERSION { │ │ │ │ │ +32#include │ │ │ │ │ +33#include │ │ │ │ │ 34 │ │ │ │ │ -35namespace Bfr { │ │ │ │ │ -36 │ │ │ │ │ -37class VertexDescriptor; │ │ │ │ │ -38 │ │ │ │ │ -43// SurfaceFactoryMeshAdapter is an abstract class that defines the interface │ │ │ │ │ -44// through which subclasses of SurfaceFactory adapt to a connected mesh │ │ │ │ │ -45// representation. The interface defines methods that describe the mesh │ │ │ │ │ -46// topology and control indices in the neighborhood of a mesh -- from │ │ │ │ │ -47// which the SurfaceFactory to identifies an appropriate limit surface. │ │ │ │ │ -48// │ │ │ │ │ -49// SurfaceFactoryMeshAdapter methods require a subclass to provide a complete │ │ │ │ │ -50// description of the topology around a base face, as well as indices │ │ │ │ │ -51// associated with it (both vertex and face-varying). The intent here is │ │ │ │ │ -52// to keep the number of methods required to a minimum, and also to minimize │ │ │ │ │ -53// the number of invocations required by the factory. │ │ │ │ │ -54// │ │ │ │ │ -55// With the need to support both linear and non-linear cases (for which │ │ │ │ │ -56// linear is trivial by comparison) and the limit surface for both vertex │ │ │ │ │ -57// and face-varying topologies, the result is a small set of methods │ │ │ │ │ -58// covering this matrix of functionality. │ │ │ │ │ -59// │ │ │ │ │ -60// Since face-varying data may differ in topology from the vertex data -- │ │ │ │ │ -61// with each set of face-varying data potentially having its own unique │ │ │ │ │ -62// topology -- sets of face-varying data are uniquely distinguished by an │ │ │ │ │ -63// associated integer (a face-varying ID). │ │ │ │ │ -64// │ │ │ │ │ -_6_5class _S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r { │ │ │ │ │ -66public: │ │ │ │ │ -_6_8 typedef int _I_n_d_e_x; │ │ │ │ │ -69 │ │ │ │ │ -_8_0 typedef std::intptr_t _F_V_a_r_I_D; │ │ │ │ │ -81 │ │ │ │ │ -82protected: │ │ │ │ │ -84 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r() { } │ │ │ │ │ -85 virtual _~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r() { } │ │ │ │ │ -87 │ │ │ │ │ -88protected: │ │ │ │ │ -90 │ │ │ │ │ -94 │ │ │ │ │ -_9_6 virtual bool _i_s_F_a_c_e_H_o_l_e(_I_n_d_e_x faceIndex) const = 0; │ │ │ │ │ -97 │ │ │ │ │ -_9_9 virtual int _g_e_t_F_a_c_e_S_i_z_e(_I_n_d_e_x faceIndex) const = 0; │ │ │ │ │ -101 │ │ │ │ │ -103 │ │ │ │ │ -111 │ │ │ │ │ -_1_1_3 virtual int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s(_I_n_d_e_x faceIndex, │ │ │ │ │ -114 _I_n_d_e_x vertexIndices[]) const = 0; │ │ │ │ │ -115 │ │ │ │ │ -_1_1_7 virtual int _g_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s(_I_n_d_e_x faceIndex, │ │ │ │ │ -118 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const = 0; │ │ │ │ │ -120 │ │ │ │ │ -121protected: │ │ │ │ │ -123 │ │ │ │ │ -159 │ │ │ │ │ -_1_6_1 virtual int _p_o_p_u_l_a_t_e_F_a_c_e_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r( │ │ │ │ │ -162 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ -163 _V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r * vertexDescriptor) const = 0; │ │ │ │ │ -164 │ │ │ │ │ -_1_6_6 virtual int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s( │ │ │ │ │ -167 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ -168 _I_n_d_e_x vertexIndices[]) const = 0; │ │ │ │ │ -169 │ │ │ │ │ -_1_7_2 virtual int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s( │ │ │ │ │ -173 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ -174 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const = 0; │ │ │ │ │ -176 │ │ │ │ │ -177protected: │ │ │ │ │ -179 │ │ │ │ │ -203 virtual bool _g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ -204 _I_n_d_e_x faceIndex, _I_n_d_e_x vertexIndices[]) const; │ │ │ │ │ -205 │ │ │ │ │ -206 virtual bool _g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ -207 _I_n_d_e_x faceIndex, _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const; │ │ │ │ │ -209 │ │ │ │ │ -210private: │ │ │ │ │ -211 // No private members │ │ │ │ │ -212}; │ │ │ │ │ -213 │ │ │ │ │ -214// │ │ │ │ │ -215// Inline defaults for optional methods: │ │ │ │ │ -216// │ │ │ │ │ -217inline bool │ │ │ │ │ -_2_1_8_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ -219 _I_n_d_e_x, _I_n_d_e_x[]) const { │ │ │ │ │ -220 return false; │ │ │ │ │ -221} │ │ │ │ │ -222 │ │ │ │ │ -223inline bool │ │ │ │ │ -_2_2_4_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ -225 _I_n_d_e_x, _F_V_a_r_I_D, _I_n_d_e_x[]) const { │ │ │ │ │ -226 return false; │ │ │ │ │ -227} │ │ │ │ │ -228 │ │ │ │ │ -229} // end namespace Bfr │ │ │ │ │ -230 │ │ │ │ │ -231} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -232using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -233 │ │ │ │ │ -234} // end namespace OpenSubdiv │ │ │ │ │ -235 │ │ │ │ │ -236#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H */ │ │ │ │ │ +35namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +36namespace OPENSUBDIV_VERSION { │ │ │ │ │ +37 │ │ │ │ │ +38namespace Bfr { │ │ │ │ │ +39 │ │ │ │ │ +52// │ │ │ │ │ +53// Initial/expected use requires simple searches of and additions to the │ │ │ │ │ +54// cache by the SurfaceFactory or its Builders. Longer term, with the │ │ │ │ │ +55// possibility of instances of caches being shared between meshes and │ │ │ │ │ +56// factories, additional options and/or public methods may be warranted │ │ │ │ │ +57// to limit what is cached or to prune the cache if it gets too large. │ │ │ │ │ +58// │ │ │ │ │ +_5_9class _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e { │ │ │ │ │ +60public: │ │ │ │ │ +_6_1 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e(); │ │ │ │ │ +_6_2 virtual _~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e(); │ │ │ │ │ +63 │ │ │ │ │ +_6_4 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e(_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e const &) = delete; │ │ │ │ │ +_6_5 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e & _o_p_e_r_a_t_o_r_=(_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e const &) = delete; │ │ │ │ │ +66 │ │ │ │ │ +67protected: │ │ │ │ │ +69 // Access restricted to the Factory, its Builders, etc. │ │ │ │ │ +70 friend class _S_u_r_f_a_c_e_F_a_c_t_o_r_y; │ │ │ │ │ +71 │ │ │ │ │ +72 typedef std::uint64_t KeyType; │ │ │ │ │ +73 typedef internal::IrregularPatchSharedPtr DataType; │ │ │ │ │ +75 │ │ │ │ │ +76protected: │ │ │ │ │ +78 size_t Size() const { return _map.size(); } │ │ │ │ │ +79 │ │ │ │ │ +80 // │ │ │ │ │ +81 // Potential overrides by subclasses for thread-safety: │ │ │ │ │ +82 // │ │ │ │ │ +83 virtual DataType Find(KeyType const & key) const; │ │ │ │ │ +84 virtual DataType Add(KeyType const & key, DataType const & data); │ │ │ │ │ +85 │ │ │ │ │ +86 // │ │ │ │ │ +87 // Common implementation used by all subclasses: │ │ │ │ │ +88 // │ │ │ │ │ +89 DataType find(KeyType const & key) const; │ │ │ │ │ +90 DataType add(KeyType const & key, DataType const & data); │ │ │ │ │ +92 │ │ │ │ │ +93private: │ │ │ │ │ +94 typedef std::map MapType; │ │ │ │ │ +95 │ │ │ │ │ +96 MapType _map; │ │ │ │ │ +97}; │ │ │ │ │ +98 │ │ │ │ │ +113// Separate read and write locks are provided to support mutex types │ │ │ │ │ +114// allowing shared (read) or exclusive (write) access. │ │ │ │ │ +115// │ │ │ │ │ +116template │ │ │ │ │ +_1_1_8class _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d : public _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e { │ │ │ │ │ +119public: │ │ │ │ │ +_1_2_0 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d() : _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e() { } │ │ │ │ │ +_1_2_1 _~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d() override = default; │ │ │ │ │ +122 │ │ │ │ │ +123protected: │ │ │ │ │ +125 // │ │ │ │ │ +126 // Virtual overrides from base: │ │ │ │ │ +127 // │ │ │ │ │ +128 DataType Find(KeyType const & key) const override { │ │ │ │ │ +129 READ_LOCK_GUARD_TYPE lockGuard(_mutex); │ │ │ │ │ +130 return find(key); │ │ │ │ │ +131 } │ │ │ │ │ +132 │ │ │ │ │ +133 DataType Add(KeyType const & key, DataType const & data) override { │ │ │ │ │ +134 WRITE_LOCK_GUARD_TYPE lockGuard(_mutex); │ │ │ │ │ +135 return add(key, data); │ │ │ │ │ +136 } │ │ │ │ │ +138 │ │ │ │ │ +139private: │ │ │ │ │ +140 MUTEX_TYPE mutable _mutex; │ │ │ │ │ +141}; │ │ │ │ │ +142 │ │ │ │ │ +143} // end namespace Bfr │ │ │ │ │ +144 │ │ │ │ │ +145} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +146using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +147 │ │ │ │ │ +148} // end namespace OpenSubdiv │ │ │ │ │ +149 │ │ │ │ │ +150#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r │ │ │ │ │ -Abstract interface adapting SurfaceFactory to a connected mesh representation. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s │ │ │ │ │ -virtual int getFaceVertexIncidentFaceFVarValueIndices(Index faceIndex, int │ │ │ │ │ -faceVertex, FVarID fvarID, Index fvarValueIndices[]) const =0 │ │ │ │ │ -Gather face-varying indices of incident faces around a face-vertex. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ -virtual int getFaceVertexIncidentFaceVertexIndices(Index faceIndex, int │ │ │ │ │ -faceVertex, Index vertexIndices[]) const =0 │ │ │ │ │ -Gather vertex indices of incident faces around a face-vertex. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_g_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ -virtual int getFaceSize(Index faceIndex) const =0 │ │ │ │ │ -Returns the size of a face (number of vertices) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_I_n_d_e_x │ │ │ │ │ -int Index │ │ │ │ │ -Integer type representing a mesh index. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_p_o_p_u_l_a_t_e_F_a_c_e_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -virtual int populateFaceVertexDescriptor(Index faceIndex, int faceVertex, │ │ │ │ │ -VertexDescriptor *vertexDescriptor) const =0 │ │ │ │ │ -Describe the topology of incident faces around a face-vertex. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r │ │ │ │ │ -virtual bool getFaceNeighborhoodVertexIndicesIfRegular(Index faceIndex, Index │ │ │ │ │ -vertexIndices[]) const │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_2_1_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r │ │ │ │ │ -virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular(Index faceIndex, │ │ │ │ │ -FVarID fvarID, Index fvarValueIndices[]) const │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_2_2_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s │ │ │ │ │ -virtual int getFaceFVarValueIndices(Index faceIndex, FVarID fvarID, Index │ │ │ │ │ -fvarValueIndices[]) const =0 │ │ │ │ │ -Gather the face-varying indices of the face's vertices. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ -virtual int getFaceVertexIndices(Index faceIndex, Index vertexIndices[]) const │ │ │ │ │ -=0 │ │ │ │ │ -Gather the indices of the face's vertices. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_i_s_F_a_c_e_H_o_l_e │ │ │ │ │ -virtual bool isFaceHole(Index faceIndex) const =0 │ │ │ │ │ -Returns if a face is a hole. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_F_V_a_r_I_D │ │ │ │ │ -std::intptr_t FVarID │ │ │ │ │ -Type used to identify and specify face-varying primvars. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_8_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -Simple class used by subclasses of SurfaceFactory to describe a vertex. │ │ │ │ │ -DDeeffiinniittiioonn _v_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r_._h_:_1_3_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ +Base class providing initialization of a Surface for each face of a mesh. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_0_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ +Container used internally by SurfaceFactory to store reusable information. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h_:_5_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ +SurfaceFactoryCache() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_:_:_~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ +virtual ~SurfaceFactoryCache() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ +SurfaceFactoryCache(SurfaceFactoryCache const &)=delete │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_:_:_o_p_e_r_a_t_o_r_= │ │ │ │ │ +SurfaceFactoryCache & operator=(SurfaceFactoryCache const &)=delete │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d │ │ │ │ │ +Template for declaring thread-safe subclasses of SurfaceFactoryCache. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h_:_1_1_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d_:_: │ │ │ │ │ +_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d │ │ │ │ │ +SurfaceFactoryCacheThreaded() │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h_:_1_2_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d_:_: │ │ │ │ │ +_~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d │ │ │ │ │ +~SurfaceFactoryCacheThreaded() override=default │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h │ │ │ │ │ + * _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00683.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/surfaceFactoryCache.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/bfr/surfaceFactoryMeshAdapter.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,31 +90,26 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
surfaceFactoryCache.h File Reference
│ │ │ │ +
surfaceFactoryMeshAdapter.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../bfr/irregularPatchType.h"
│ │ │ │ -#include <map>
│ │ │ │ #include <cstdint>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  SurfaceFactoryCache
 Container used internally by SurfaceFactory to store reusable information. More...
 
class  SurfaceFactoryCacheThreaded< MUTEX_TYPE, READ_LOCK_GUARD_TYPE, WRITE_LOCK_GUARD_TYPE >
 Template for declaring thread-safe subclasses of SurfaceFactoryCache. More...
class  SurfaceFactoryMeshAdapter
 Abstract interface adapting SurfaceFactory to a connected mesh representation. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -123,13 +118,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,32 +1,25 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -surfaceFactoryCache.h File Reference │ │ │ │ │ +surfaceFactoryMeshAdapter.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "../bfr/irregularPatchType.h" │ │ │ │ │ -#include │ │ │ │ │ #include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ -  Container used internally by _S_u_r_f_a_c_e_F_a_c_t_o_r_y to store reusable │ │ │ │ │ - information. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -class   _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d_<_ _M_U_T_E_X___T_Y_P_E_,_ _R_E_A_D___L_O_C_K___G_U_A_R_D___T_Y_P_E_, │ │ │ │ │ - _W_R_I_T_E___L_O_C_K___G_U_A_R_D___T_Y_P_E_ _> │ │ │ │ │ -  Template for declaring thread-safe subclasses of _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ +class   _S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r │ │ │ │ │ +  Abstract interface adapting _S_u_r_f_a_c_e_F_a_c_t_o_r_y to a connected mesh │ │ │ │ │ + representation. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h │ │ │ │ │ + * _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00683.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,3 @@ │ │ │ │ │ var a00683 = [ │ │ │ │ │ - ["SurfaceFactoryCache", "a00949.html", "a00949"], │ │ │ │ │ - ["SurfaceFactoryCacheThreaded< MUTEX_TYPE, READ_LOCK_GUARD_TYPE, WRITE_LOCK_GUARD_TYPE >", "a00953.html", "a00953"] │ │ │ │ │ + ["SurfaceFactoryMeshAdapter", "a00957.html", "a00957"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00683_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/surfaceFactoryCache.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/bfr/surfaceFactoryMeshAdapter.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
surfaceFactoryCache.h
│ │ │ │ +
surfaceFactoryMeshAdapter.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2021 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,126 +119,149 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H
│ │ │ │ -
26#define OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H
│ │ │ │ +
26#define OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │
29
│ │ │ │ -
30#include "../bfr/irregularPatchType.h"
│ │ │ │ +
30#include <cstdint>
│ │ │ │
31
│ │ │ │ -
32#include <map>
│ │ │ │ -
33#include <cstdint>
│ │ │ │ +
32namespace OpenSubdiv {
│ │ │ │ +
33namespace OPENSUBDIV_VERSION {
│ │ │ │
34
│ │ │ │ -
35namespace OpenSubdiv {
│ │ │ │ -
36namespace OPENSUBDIV_VERSION {
│ │ │ │ -
37
│ │ │ │ -
38namespace Bfr {
│ │ │ │ -
39
│ │ │ │ -
52//
│ │ │ │ -
53// Initial/expected use requires simple searches of and additions to the
│ │ │ │ -
54// cache by the SurfaceFactory or its Builders. Longer term, with the
│ │ │ │ -
55// possibility of instances of caches being shared between meshes and
│ │ │ │ -
56// factories, additional options and/or public methods may be warranted
│ │ │ │ -
57// to limit what is cached or to prune the cache if it gets too large.
│ │ │ │ -
58//
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
60public:
│ │ │ │ - │ │ │ │ - │ │ │ │ -
63
│ │ │ │ - │ │ │ │ - │ │ │ │ -
66
│ │ │ │ -
67protected:
│ │ │ │ -
69 // Access restricted to the Factory, its Builders, etc.
│ │ │ │ -
70 friend class SurfaceFactory;
│ │ │ │ -
71
│ │ │ │ -
72 typedef std::uint64_t KeyType;
│ │ │ │ -
73 typedef internal::IrregularPatchSharedPtr DataType;
│ │ │ │ -
75
│ │ │ │ -
76protected:
│ │ │ │ -
78 size_t Size() const { return _map.size(); }
│ │ │ │ -
79
│ │ │ │ -
80 //
│ │ │ │ -
81 // Potential overrides by subclasses for thread-safety:
│ │ │ │ -
82 //
│ │ │ │ -
83 virtual DataType Find(KeyType const & key) const;
│ │ │ │ -
84 virtual DataType Add(KeyType const & key, DataType const & data);
│ │ │ │ -
85
│ │ │ │ -
86 //
│ │ │ │ -
87 // Common implementation used by all subclasses:
│ │ │ │ -
88 //
│ │ │ │ -
89 DataType find(KeyType const & key) const;
│ │ │ │ -
90 DataType add(KeyType const & key, DataType const & data);
│ │ │ │ -
92
│ │ │ │ -
93private:
│ │ │ │ -
94 typedef std::map<KeyType, DataType> MapType;
│ │ │ │ -
95
│ │ │ │ -
96 MapType _map;
│ │ │ │ -
97};
│ │ │ │ -
│ │ │ │ -
98
│ │ │ │ -
113// Separate read and write locks are provided to support mutex types
│ │ │ │ -
114// allowing shared (read) or exclusive (write) access.
│ │ │ │ -
115//
│ │ │ │ -
116template <class MUTEX_TYPE, class READ_LOCK_GUARD_TYPE,
│ │ │ │ -
117 class WRITE_LOCK_GUARD_TYPE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
119public:
│ │ │ │ - │ │ │ │ -
121 ~SurfaceFactoryCacheThreaded() override = default;
│ │ │ │ -
122
│ │ │ │ -
123protected:
│ │ │ │ -
125 //
│ │ │ │ -
126 // Virtual overrides from base:
│ │ │ │ -
127 //
│ │ │ │ -
128 DataType Find(KeyType const & key) const override {
│ │ │ │ -
129 READ_LOCK_GUARD_TYPE lockGuard(_mutex);
│ │ │ │ -
130 return find(key);
│ │ │ │ -
131 }
│ │ │ │ -
132
│ │ │ │ -
133 DataType Add(KeyType const & key, DataType const & data) override {
│ │ │ │ -
134 WRITE_LOCK_GUARD_TYPE lockGuard(_mutex);
│ │ │ │ -
135 return add(key, data);
│ │ │ │ -
136 }
│ │ │ │ -
138
│ │ │ │ -
139private:
│ │ │ │ -
140 MUTEX_TYPE mutable _mutex;
│ │ │ │ -
141};
│ │ │ │ -
│ │ │ │ -
142
│ │ │ │ -
143} // end namespace Bfr
│ │ │ │ -
144
│ │ │ │ -
145} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
146using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
147
│ │ │ │ -
148} // end namespace OpenSubdiv
│ │ │ │ -
149
│ │ │ │ -
150#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H */
│ │ │ │ - │ │ │ │ -
Base class providing initialization of a Surface for each face of a mesh.
│ │ │ │ -
Container used internally by SurfaceFactory to store reusable information.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
SurfaceFactoryCache(SurfaceFactoryCache const &)=delete
│ │ │ │ -
SurfaceFactoryCache & operator=(SurfaceFactoryCache const &)=delete
│ │ │ │ -
Template for declaring thread-safe subclasses of SurfaceFactoryCache.
│ │ │ │ - │ │ │ │ - │ │ │ │ +
35namespace Bfr {
│ │ │ │ +
36
│ │ │ │ +
37class VertexDescriptor;
│ │ │ │ +
38
│ │ │ │ +
43// SurfaceFactoryMeshAdapter is an abstract class that defines the interface
│ │ │ │ +
44// through which subclasses of SurfaceFactory adapt to a connected mesh
│ │ │ │ +
45// representation. The interface defines methods that describe the mesh
│ │ │ │ +
46// topology and control indices in the neighborhood of a mesh -- from
│ │ │ │ +
47// which the SurfaceFactory to identifies an appropriate limit surface.
│ │ │ │ +
48//
│ │ │ │ +
49// SurfaceFactoryMeshAdapter methods require a subclass to provide a complete
│ │ │ │ +
50// description of the topology around a base face, as well as indices
│ │ │ │ +
51// associated with it (both vertex and face-varying). The intent here is
│ │ │ │ +
52// to keep the number of methods required to a minimum, and also to minimize
│ │ │ │ +
53// the number of invocations required by the factory.
│ │ │ │ +
54//
│ │ │ │ +
55// With the need to support both linear and non-linear cases (for which
│ │ │ │ +
56// linear is trivial by comparison) and the limit surface for both vertex
│ │ │ │ +
57// and face-varying topologies, the result is a small set of methods
│ │ │ │ +
58// covering this matrix of functionality.
│ │ │ │ +
59//
│ │ │ │ +
60// Since face-varying data may differ in topology from the vertex data --
│ │ │ │ +
61// with each set of face-varying data potentially having its own unique
│ │ │ │ +
62// topology -- sets of face-varying data are uniquely distinguished by an
│ │ │ │ +
63// associated integer (a face-varying ID).
│ │ │ │ +
64//
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
66public:
│ │ │ │ +
68 typedef int Index;
│ │ │ │ +
69
│ │ │ │ +
80 typedef std::intptr_t FVarID;
│ │ │ │ +
81
│ │ │ │ +
82protected:
│ │ │ │ + │ │ │ │ +
85 virtual ~SurfaceFactoryMeshAdapter() { }
│ │ │ │ +
87
│ │ │ │ +
88protected:
│ │ │ │ +
90
│ │ │ │ +
94
│ │ │ │ +
96 virtual bool isFaceHole(Index faceIndex) const = 0;
│ │ │ │ +
97
│ │ │ │ +
99 virtual int getFaceSize(Index faceIndex) const = 0;
│ │ │ │ +
101
│ │ │ │ +
103
│ │ │ │ +
111
│ │ │ │ +
113 virtual int getFaceVertexIndices(Index faceIndex,
│ │ │ │ +
114 Index vertexIndices[]) const = 0;
│ │ │ │ +
115
│ │ │ │ +
117 virtual int getFaceFVarValueIndices(Index faceIndex,
│ │ │ │ +
118 FVarID fvarID, Index fvarValueIndices[]) const = 0;
│ │ │ │ +
120
│ │ │ │ +
121protected:
│ │ │ │ +
123
│ │ │ │ +
159
│ │ │ │ + │ │ │ │ +
162 Index faceIndex, int faceVertex,
│ │ │ │ +
163 VertexDescriptor * vertexDescriptor) const = 0;
│ │ │ │ +
164
│ │ │ │ + │ │ │ │ +
167 Index faceIndex, int faceVertex,
│ │ │ │ +
168 Index vertexIndices[]) const = 0;
│ │ │ │ +
169
│ │ │ │ + │ │ │ │ +
173 Index faceIndex, int faceVertex,
│ │ │ │ +
174 FVarID fvarID, Index fvarValueIndices[]) const = 0;
│ │ │ │ +
176
│ │ │ │ +
177protected:
│ │ │ │ +
179
│ │ │ │ + │ │ │ │ +
204 Index faceIndex, Index vertexIndices[]) const;
│ │ │ │ +
205
│ │ │ │ + │ │ │ │ +
207 Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const;
│ │ │ │ +
209
│ │ │ │ +
210private:
│ │ │ │ +
211 // No private members
│ │ │ │ +
212};
│ │ │ │ +
│ │ │ │ +
213
│ │ │ │ +
214//
│ │ │ │ +
215// Inline defaults for optional methods:
│ │ │ │ +
216//
│ │ │ │ +
217inline bool
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
219 Index, Index[]) const {
│ │ │ │ +
220 return false;
│ │ │ │ +
221}
│ │ │ │ +
│ │ │ │ +
222
│ │ │ │ +
223inline bool
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
225 Index, FVarID, Index[]) const {
│ │ │ │ +
226 return false;
│ │ │ │ +
227}
│ │ │ │ +
│ │ │ │ +
228
│ │ │ │ +
229} // end namespace Bfr
│ │ │ │ +
230
│ │ │ │ +
231} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
232using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
233
│ │ │ │ +
234} // end namespace OpenSubdiv
│ │ │ │ +
235
│ │ │ │ +
236#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H */
│ │ │ │ + │ │ │ │ +
Abstract interface adapting SurfaceFactory to a connected mesh representation.
│ │ │ │ +
virtual int getFaceVertexIncidentFaceFVarValueIndices(Index faceIndex, int faceVertex, FVarID fvarID, Index fvarValueIndices[]) const =0
Gather face-varying indices of incident faces around a face-vertex.
│ │ │ │ +
virtual int getFaceVertexIncidentFaceVertexIndices(Index faceIndex, int faceVertex, Index vertexIndices[]) const =0
Gather vertex indices of incident faces around a face-vertex.
│ │ │ │ +
virtual int getFaceSize(Index faceIndex) const =0
Returns the size of a face (number of vertices)
│ │ │ │ + │ │ │ │ +
virtual int populateFaceVertexDescriptor(Index faceIndex, int faceVertex, VertexDescriptor *vertexDescriptor) const =0
Describe the topology of incident faces around a face-vertex.
│ │ │ │ +
virtual bool getFaceNeighborhoodVertexIndicesIfRegular(Index faceIndex, Index vertexIndices[]) const
│ │ │ │ +
virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular(Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const
│ │ │ │ +
virtual int getFaceFVarValueIndices(Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const =0
Gather the face-varying indices of the face's vertices.
│ │ │ │ +
virtual int getFaceVertexIndices(Index faceIndex, Index vertexIndices[]) const =0
Gather the indices of the face's vertices.
│ │ │ │ +
virtual bool isFaceHole(Index faceIndex) const =0
Returns if a face is a hole.
│ │ │ │ +
std::intptr_t FVarID
Type used to identify and specify face-varying primvars.
│ │ │ │ +
Simple class used by subclasses of SurfaceFactory to describe a vertex.
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -surfaceFactoryCache.h │ │ │ │ │ +surfaceFactoryMeshAdapter.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2021 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,131 +24,179 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H │ │ │ │ │ -26#define OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H │ │ │ │ │ +26#define OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ 29 │ │ │ │ │ -30#include "../bfr/irregularPatchType.h" │ │ │ │ │ +30#include │ │ │ │ │ 31 │ │ │ │ │ -32#include │ │ │ │ │ -33#include │ │ │ │ │ +32namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +33namespace OPENSUBDIV_VERSION { │ │ │ │ │ 34 │ │ │ │ │ -35namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -36namespace OPENSUBDIV_VERSION { │ │ │ │ │ -37 │ │ │ │ │ -38namespace Bfr { │ │ │ │ │ -39 │ │ │ │ │ -52// │ │ │ │ │ -53// Initial/expected use requires simple searches of and additions to the │ │ │ │ │ -54// cache by the SurfaceFactory or its Builders. Longer term, with the │ │ │ │ │ -55// possibility of instances of caches being shared between meshes and │ │ │ │ │ -56// factories, additional options and/or public methods may be warranted │ │ │ │ │ -57// to limit what is cached or to prune the cache if it gets too large. │ │ │ │ │ -58// │ │ │ │ │ -_5_9class _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e { │ │ │ │ │ -60public: │ │ │ │ │ -_6_1 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e(); │ │ │ │ │ -_6_2 virtual _~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e(); │ │ │ │ │ -63 │ │ │ │ │ -_6_4 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e(_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e const &) = delete; │ │ │ │ │ -_6_5 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e & _o_p_e_r_a_t_o_r_=(_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e const &) = delete; │ │ │ │ │ -66 │ │ │ │ │ -67protected: │ │ │ │ │ -69 // Access restricted to the Factory, its Builders, etc. │ │ │ │ │ -70 friend class _S_u_r_f_a_c_e_F_a_c_t_o_r_y; │ │ │ │ │ -71 │ │ │ │ │ -72 typedef std::uint64_t KeyType; │ │ │ │ │ -73 typedef internal::IrregularPatchSharedPtr DataType; │ │ │ │ │ -75 │ │ │ │ │ -76protected: │ │ │ │ │ -78 size_t Size() const { return _map.size(); } │ │ │ │ │ -79 │ │ │ │ │ -80 // │ │ │ │ │ -81 // Potential overrides by subclasses for thread-safety: │ │ │ │ │ -82 // │ │ │ │ │ -83 virtual DataType Find(KeyType const & key) const; │ │ │ │ │ -84 virtual DataType Add(KeyType const & key, DataType const & data); │ │ │ │ │ -85 │ │ │ │ │ -86 // │ │ │ │ │ -87 // Common implementation used by all subclasses: │ │ │ │ │ -88 // │ │ │ │ │ -89 DataType find(KeyType const & key) const; │ │ │ │ │ -90 DataType add(KeyType const & key, DataType const & data); │ │ │ │ │ -92 │ │ │ │ │ -93private: │ │ │ │ │ -94 typedef std::map MapType; │ │ │ │ │ -95 │ │ │ │ │ -96 MapType _map; │ │ │ │ │ -97}; │ │ │ │ │ -98 │ │ │ │ │ -113// Separate read and write locks are provided to support mutex types │ │ │ │ │ -114// allowing shared (read) or exclusive (write) access. │ │ │ │ │ -115// │ │ │ │ │ -116template │ │ │ │ │ -_1_1_8class _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d : public _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e { │ │ │ │ │ -119public: │ │ │ │ │ -_1_2_0 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d() : _S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e() { } │ │ │ │ │ -_1_2_1 _~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d() override = default; │ │ │ │ │ -122 │ │ │ │ │ -123protected: │ │ │ │ │ -125 // │ │ │ │ │ -126 // Virtual overrides from base: │ │ │ │ │ -127 // │ │ │ │ │ -128 DataType Find(KeyType const & key) const override { │ │ │ │ │ -129 READ_LOCK_GUARD_TYPE lockGuard(_mutex); │ │ │ │ │ -130 return find(key); │ │ │ │ │ -131 } │ │ │ │ │ -132 │ │ │ │ │ -133 DataType Add(KeyType const & key, DataType const & data) override { │ │ │ │ │ -134 WRITE_LOCK_GUARD_TYPE lockGuard(_mutex); │ │ │ │ │ -135 return add(key, data); │ │ │ │ │ -136 } │ │ │ │ │ -138 │ │ │ │ │ -139private: │ │ │ │ │ -140 MUTEX_TYPE mutable _mutex; │ │ │ │ │ -141}; │ │ │ │ │ -142 │ │ │ │ │ -143} // end namespace Bfr │ │ │ │ │ -144 │ │ │ │ │ -145} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -146using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -147 │ │ │ │ │ -148} // end namespace OpenSubdiv │ │ │ │ │ -149 │ │ │ │ │ -150#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_CACHE_H */ │ │ │ │ │ +35namespace Bfr { │ │ │ │ │ +36 │ │ │ │ │ +37class VertexDescriptor; │ │ │ │ │ +38 │ │ │ │ │ +43// SurfaceFactoryMeshAdapter is an abstract class that defines the interface │ │ │ │ │ +44// through which subclasses of SurfaceFactory adapt to a connected mesh │ │ │ │ │ +45// representation. The interface defines methods that describe the mesh │ │ │ │ │ +46// topology and control indices in the neighborhood of a mesh -- from │ │ │ │ │ +47// which the SurfaceFactory to identifies an appropriate limit surface. │ │ │ │ │ +48// │ │ │ │ │ +49// SurfaceFactoryMeshAdapter methods require a subclass to provide a complete │ │ │ │ │ +50// description of the topology around a base face, as well as indices │ │ │ │ │ +51// associated with it (both vertex and face-varying). The intent here is │ │ │ │ │ +52// to keep the number of methods required to a minimum, and also to minimize │ │ │ │ │ +53// the number of invocations required by the factory. │ │ │ │ │ +54// │ │ │ │ │ +55// With the need to support both linear and non-linear cases (for which │ │ │ │ │ +56// linear is trivial by comparison) and the limit surface for both vertex │ │ │ │ │ +57// and face-varying topologies, the result is a small set of methods │ │ │ │ │ +58// covering this matrix of functionality. │ │ │ │ │ +59// │ │ │ │ │ +60// Since face-varying data may differ in topology from the vertex data -- │ │ │ │ │ +61// with each set of face-varying data potentially having its own unique │ │ │ │ │ +62// topology -- sets of face-varying data are uniquely distinguished by an │ │ │ │ │ +63// associated integer (a face-varying ID). │ │ │ │ │ +64// │ │ │ │ │ +_6_5class _S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r { │ │ │ │ │ +66public: │ │ │ │ │ +_6_8 typedef int _I_n_d_e_x; │ │ │ │ │ +69 │ │ │ │ │ +_8_0 typedef std::intptr_t _F_V_a_r_I_D; │ │ │ │ │ +81 │ │ │ │ │ +82protected: │ │ │ │ │ +84 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r() { } │ │ │ │ │ +85 virtual _~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r() { } │ │ │ │ │ +87 │ │ │ │ │ +88protected: │ │ │ │ │ +90 │ │ │ │ │ +94 │ │ │ │ │ +_9_6 virtual bool _i_s_F_a_c_e_H_o_l_e(_I_n_d_e_x faceIndex) const = 0; │ │ │ │ │ +97 │ │ │ │ │ +_9_9 virtual int _g_e_t_F_a_c_e_S_i_z_e(_I_n_d_e_x faceIndex) const = 0; │ │ │ │ │ +101 │ │ │ │ │ +103 │ │ │ │ │ +111 │ │ │ │ │ +_1_1_3 virtual int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s(_I_n_d_e_x faceIndex, │ │ │ │ │ +114 _I_n_d_e_x vertexIndices[]) const = 0; │ │ │ │ │ +115 │ │ │ │ │ +_1_1_7 virtual int _g_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s(_I_n_d_e_x faceIndex, │ │ │ │ │ +118 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const = 0; │ │ │ │ │ +120 │ │ │ │ │ +121protected: │ │ │ │ │ +123 │ │ │ │ │ +159 │ │ │ │ │ +_1_6_1 virtual int _p_o_p_u_l_a_t_e_F_a_c_e_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r( │ │ │ │ │ +162 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ +163 _V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r * vertexDescriptor) const = 0; │ │ │ │ │ +164 │ │ │ │ │ +_1_6_6 virtual int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s( │ │ │ │ │ +167 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ +168 _I_n_d_e_x vertexIndices[]) const = 0; │ │ │ │ │ +169 │ │ │ │ │ +_1_7_2 virtual int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s( │ │ │ │ │ +173 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ +174 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const = 0; │ │ │ │ │ +176 │ │ │ │ │ +177protected: │ │ │ │ │ +179 │ │ │ │ │ +203 virtual bool _g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ +204 _I_n_d_e_x faceIndex, _I_n_d_e_x vertexIndices[]) const; │ │ │ │ │ +205 │ │ │ │ │ +206 virtual bool _g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ +207 _I_n_d_e_x faceIndex, _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const; │ │ │ │ │ +209 │ │ │ │ │ +210private: │ │ │ │ │ +211 // No private members │ │ │ │ │ +212}; │ │ │ │ │ +213 │ │ │ │ │ +214// │ │ │ │ │ +215// Inline defaults for optional methods: │ │ │ │ │ +216// │ │ │ │ │ +217inline bool │ │ │ │ │ +_2_1_8_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ +219 _I_n_d_e_x, _I_n_d_e_x[]) const { │ │ │ │ │ +220 return false; │ │ │ │ │ +221} │ │ │ │ │ +222 │ │ │ │ │ +223inline bool │ │ │ │ │ +_2_2_4_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ +225 _I_n_d_e_x, _F_V_a_r_I_D, _I_n_d_e_x[]) const { │ │ │ │ │ +226 return false; │ │ │ │ │ +227} │ │ │ │ │ +228 │ │ │ │ │ +229} // end namespace Bfr │ │ │ │ │ +230 │ │ │ │ │ +231} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +232using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +233 │ │ │ │ │ +234} // end namespace OpenSubdiv │ │ │ │ │ +235 │ │ │ │ │ +236#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_ADAPTER_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ -Base class providing initialization of a Surface for each face of a mesh. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_0_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ -Container used internally by SurfaceFactory to store reusable information. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h_:_5_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ -SurfaceFactoryCache() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_:_:_~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ -virtual ~SurfaceFactoryCache() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e │ │ │ │ │ -SurfaceFactoryCache(SurfaceFactoryCache const &)=delete │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_:_:_o_p_e_r_a_t_o_r_= │ │ │ │ │ -SurfaceFactoryCache & operator=(SurfaceFactoryCache const &)=delete │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d │ │ │ │ │ -Template for declaring thread-safe subclasses of SurfaceFactoryCache. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h_:_1_1_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d_:_: │ │ │ │ │ -_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d │ │ │ │ │ -SurfaceFactoryCacheThreaded() │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h_:_1_2_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d_:_: │ │ │ │ │ -_~_S_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_T_h_r_e_a_d_e_d │ │ │ │ │ -~SurfaceFactoryCacheThreaded() override=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r │ │ │ │ │ +Abstract interface adapting SurfaceFactory to a connected mesh representation. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s │ │ │ │ │ +virtual int getFaceVertexIncidentFaceFVarValueIndices(Index faceIndex, int │ │ │ │ │ +faceVertex, FVarID fvarID, Index fvarValueIndices[]) const =0 │ │ │ │ │ +Gather face-varying indices of incident faces around a face-vertex. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ +virtual int getFaceVertexIncidentFaceVertexIndices(Index faceIndex, int │ │ │ │ │ +faceVertex, Index vertexIndices[]) const =0 │ │ │ │ │ +Gather vertex indices of incident faces around a face-vertex. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_g_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ +virtual int getFaceSize(Index faceIndex) const =0 │ │ │ │ │ +Returns the size of a face (number of vertices) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_I_n_d_e_x │ │ │ │ │ +int Index │ │ │ │ │ +Integer type representing a mesh index. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_p_o_p_u_l_a_t_e_F_a_c_e_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +virtual int populateFaceVertexDescriptor(Index faceIndex, int faceVertex, │ │ │ │ │ +VertexDescriptor *vertexDescriptor) const =0 │ │ │ │ │ +Describe the topology of incident faces around a face-vertex. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r │ │ │ │ │ +virtual bool getFaceNeighborhoodVertexIndicesIfRegular(Index faceIndex, Index │ │ │ │ │ +vertexIndices[]) const │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_2_1_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r │ │ │ │ │ +virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular(Index faceIndex, │ │ │ │ │ +FVarID fvarID, Index fvarValueIndices[]) const │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_2_2_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s │ │ │ │ │ +virtual int getFaceFVarValueIndices(Index faceIndex, FVarID fvarID, Index │ │ │ │ │ +fvarValueIndices[]) const =0 │ │ │ │ │ +Gather the face-varying indices of the face's vertices. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ +virtual int getFaceVertexIndices(Index faceIndex, Index vertexIndices[]) const │ │ │ │ │ +=0 │ │ │ │ │ +Gather the indices of the face's vertices. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_i_s_F_a_c_e_H_o_l_e │ │ │ │ │ +virtual bool isFaceHole(Index faceIndex) const =0 │ │ │ │ │ +Returns if a face is a hole. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_F_V_a_r_I_D │ │ │ │ │ +std::intptr_t FVarID │ │ │ │ │ +Type used to identify and specify face-varying primvars. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_8_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +Simple class used by subclasses of SurfaceFactory to describe a vertex. │ │ │ │ │ +DDeeffiinniittiioonn _v_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r_._h_:_1_3_1 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h │ │ │ │ │ + * _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00686.html │ │ │ │ @@ -94,17 +94,17 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
surfaceFactory.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../bfr/surface.h"
│ │ │ │ -#include "../bfr/surfaceFactoryMeshAdapter.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ +#include "../bfr/surface.h"
│ │ │ │ +#include "../bfr/surfaceFactoryMeshAdapter.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │ #include "../sdc/types.h"
│ │ │ │ #include <cstdint>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00686_source.html │ │ │ │ @@ -475,18 +475,18 @@ │ │ │ │
557
│ │ │ │
558} // end namespace OPENSUBDIV_VERSION
│ │ │ │
559using namespace OPENSUBDIV_VERSION;
│ │ │ │
560
│ │ │ │
561} // end namespace OpenSubdiv
│ │ │ │
562
│ │ │ │
563#endif /* OPENSUBDIV3_BFR_SURFACE_FACTORY_H */
│ │ │ │ - │ │ │ │ + │ │ │ │
SchemeType
Enumerated type for all subdivision schemes supported by OpenSubdiv.
Definition types.h:37
│ │ │ │ -
Simple class defining the 2D parameterization of a face.
│ │ │ │ -
Encapsulates the limit surface for a face of a mesh.
Definition surface.h:59
│ │ │ │ +
Simple class defining the 2D parameterization of a face.
│ │ │ │ +
Encapsulates the limit surface for a face of a mesh.
Definition surface.h:59
│ │ │ │
Base class providing initialization of a Surface for each face of a mesh.
│ │ │ │
void setInternalCache(SurfaceFactoryCache *cache)
Subclass to identify an internal cache for use by base class.
│ │ │ │ │ │ │ │
bool InitFaceVaryingSurface(Index faceIndex, Surface< REAL > *surface) const
Initialize a Surface for the default face-varying data.
│ │ │ │
Sdc::Options GetSchemeOptions() const
Return the set of subdivision options.
│ │ │ │
Parameterization GetFaceParameterization(Index faceIndex) const
Return the Parameterization of a face with a limit surface.
│ │ │ │
SurfaceFactory(SurfaceFactory const &)=delete
│ │ │ │ @@ -508,19 +508,19 @@ │ │ │ │ │ │ │ │
bool IsCachingEnabled() const
Return if caching is enable.
│ │ │ │
Options & SetDefaultFVarID(FVarID id)
Assign the default face-varying ID (none assigned by default)
│ │ │ │
Options & SetApproxLevelSharp(int level)
Assign maximum refinement level for sharp features.
│ │ │ │
FVarID GetDefaultFVarID() const
Return the default face-varying ID.
│ │ │ │
int GetApproxLevelSharp() const
Return maximum refinement level for sharp features.
│ │ │ │
SurfaceFactoryCache * GetExternalCache() const
Return any assigned external cache.
│ │ │ │ -
Container used internally by SurfaceFactory to store reusable information.
│ │ │ │ -
Abstract interface adapting SurfaceFactory to a connected mesh representation.
│ │ │ │ - │ │ │ │ -
std::intptr_t FVarID
Type used to identify and specify face-varying primvars.
│ │ │ │ -
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ +
Container used internally by SurfaceFactory to store reusable information.
│ │ │ │ +
Abstract interface adapting SurfaceFactory to a connected mesh representation.
│ │ │ │ + │ │ │ │ +
std::intptr_t FVarID
Type used to identify and specify face-varying primvars.
│ │ │ │ +
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
refinerSurfaceFactory.h File Reference
│ │ │ │ +
surface.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../bfr/surfaceFactory.h"
│ │ │ │ -#include "../bfr/surfaceFactoryCache.h"
│ │ │ │ +#include "../bfr/surfaceData.h"
│ │ │ │ +#include "../bfr/parameterization.h"
│ │ │ │ +#include "../vtr/array.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  RefinerSurfaceFactoryBase
 Intermediate subclass of SurfaceFactory with Far::TopologyRefiner as the mesh. More...
class  Surface< REAL >
 Encapsulates the limit surface for a face of a mesh. More...
 
class  RefinerSurfaceFactory< CACHE_TYPE >
 Template for concrete subclasses of RefinerSurfaceFactoryBase. More...
struct  Surface< REAL >::PointDescriptor
 Simple struct defining the size and stride of points in arrays. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Bfr
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,31 +1,30 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -refinerSurfaceFactory.h File Reference │ │ │ │ │ +surface.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_b_f_r_/_s_u_r_f_a_c_e_F_a_c_t_o_r_y_._h" │ │ │ │ │ -#include "_._._/_b_f_r_/_s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h" │ │ │ │ │ +#include "../bfr/surfaceData.h" │ │ │ │ │ +#include "_._._/_b_f_r_/_p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_a_r_r_a_y_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ -  Intermediate subclass of _S_u_r_f_a_c_e_F_a_c_t_o_r_y with _F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r as │ │ │ │ │ - the mesh. _M_o_r_e_._._. │ │ │ │ │ + class   _S_u_r_f_a_c_e_<_ _R_E_A_L_ _> │ │ │ │ │ +  Encapsulates the limit surface for a face of a mesh. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -class   _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_<_ _C_A_C_H_E___T_Y_P_E_ _> │ │ │ │ │ -  Template for concrete subclasses of _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e. _M_o_r_e_._._. │ │ │ │ │ +struct   _S_u_r_f_a_c_e_<_ _R_E_A_L_ _>_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +  Simple struct defining the size and stride of points in arrays. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │ -  │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h │ │ │ │ │ + * _s_u_r_f_a_c_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00689.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,4 @@ │ │ │ │ │ var a00689 = [ │ │ │ │ │ - ["RefinerSurfaceFactoryBase", "a00925.html", "a00925"], │ │ │ │ │ - ["RefinerSurfaceFactory< CACHE_TYPE >", "a00929.html", "a00929"] │ │ │ │ │ + ["Surface< REAL >", "a00933.html", "a00933"], │ │ │ │ │ + ["PointDescriptor", "a00937.html", "a00937"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00689_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/refinerSurfaceFactory.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/bfr/surface.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
refinerSurfaceFactory.h
│ │ │ │ +
surface.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2021 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,163 +119,358 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H
│ │ │ │ -
26#define OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_BFR_SURFACE_H
│ │ │ │ +
26#define OPENSUBDIV3_BFR_SURFACE_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │
29
│ │ │ │ -
30#include "../bfr/surfaceFactory.h"
│ │ │ │ -
31#include "../bfr/surfaceFactoryCache.h"
│ │ │ │ -
32
│ │ │ │ -
33namespace OpenSubdiv {
│ │ │ │ -
34namespace OPENSUBDIV_VERSION {
│ │ │ │ -
35
│ │ │ │ -
│ │ │ │ -
36namespace Far {
│ │ │ │ -
37 class TopologyRefiner;
│ │ │ │ -
38}
│ │ │ │ -
│ │ │ │ -
39
│ │ │ │ -
40namespace Bfr {
│ │ │ │ -
41
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
59public:
│ │ │ │ -
61
│ │ │ │ -
65
│ │ │ │ - │ │ │ │ -
67 Options const & options);
│ │ │ │ -
68
│ │ │ │ -
69 ~RefinerSurfaceFactoryBase() override = default;
│ │ │ │ -
71
│ │ │ │ +
30#include "../bfr/surfaceData.h"
│ │ │ │ +
31#include "../bfr/parameterization.h"
│ │ │ │ +
32#include "../vtr/array.h"
│ │ │ │ +
33
│ │ │ │ +
34namespace OpenSubdiv {
│ │ │ │ +
35namespace OPENSUBDIV_VERSION {
│ │ │ │ +
36
│ │ │ │ +
37namespace Bfr {
│ │ │ │ +
38
│ │ │ │ +
58template <typename REAL>
│ │ │ │ +
│ │ │ │ +
59class Surface {
│ │ │ │ +
60public:
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ +
65 PointDescriptor(int n) : size(n), stride(n) { }
│ │ │ │ +
66 PointDescriptor(int n, int m) : size(n), stride(m) { }
│ │ │ │ +
67
│ │ │ │ + │ │ │ │ +
69 };
│ │ │ │ +
│ │ │ │ +
70
│ │ │ │ +
72 typedef int Index;
│ │ │ │
73
│ │ │ │ -
77
│ │ │ │ -
79 Far::TopologyRefiner const & GetMesh() const { return _mesh; }
│ │ │ │ -
80
│ │ │ │ -
82 int GetNumFaces() const { return _numFaces; }
│ │ │ │ -
83
│ │ │ │ -
85 int GetNumFVarChannels() const { return _numFVarChannels; }
│ │ │ │ +
74public:
│ │ │ │ +
76
│ │ │ │ +
84
│ │ │ │ +
86 bool IsValid() const { return _data.isValid(); }
│ │ │ │
87
│ │ │ │ -
88protected:
│ │ │ │ -
90 //
│ │ │ │ -
91 // Virtual overrides to satisfy the SurfaceFactoryMeshAdapter interface:
│ │ │ │ -
92 //
│ │ │ │ -
93 bool isFaceHole( Index faceIndex) const override;
│ │ │ │ -
94 int getFaceSize(Index faceIndex) const override;
│ │ │ │ -
95
│ │ │ │ -
96 int getFaceVertexIndices(Index faceIndex,
│ │ │ │ -
97 Index vertexIndices[]) const override;
│ │ │ │ -
98 int getFaceFVarValueIndices(Index faceIndex,
│ │ │ │ -
99 FVarID fvarID, Index fvarValueIndices[]) const override;
│ │ │ │ +
89 void Clear() { _data.reinitialize(); }
│ │ │ │ +
90
│ │ │ │ + │ │ │ │ +
93
│ │ │ │ +
94 Surface(Surface const & src) = default;
│ │ │ │ +
95 Surface& operator=(Surface const & src) = default;
│ │ │ │ +
96 ~Surface() = default;
│ │ │ │ +
98
│ │ │ │
100
│ │ │ │ -
101 int populateFaceVertexDescriptor(Index faceIndex, int faceVertex,
│ │ │ │ -
102 VertexDescriptor * vertexDescriptor) const override;
│ │ │ │ -
103
│ │ │ │ - │ │ │ │ -
105 Index faceIndex, int faceVertex,
│ │ │ │ -
106 Index vertexIndices[]) const override;
│ │ │ │ - │ │ │ │ -
108 Index faceIndex, int faceVertex,
│ │ │ │ -
109 FVarID fvarID, Index fvarValueIndices[]) const override;
│ │ │ │ +
104
│ │ │ │ +
106 Parameterization GetParameterization() const { return _data.getParam(); }
│ │ │ │ +
107
│ │ │ │ +
109 int GetFaceSize() const { return GetParameterization().GetFaceSize(); }
│ │ │ │
110
│ │ │ │ -
111 // Optional SurfaceFactoryMeshAdapter overrides for regular patches:
│ │ │ │ - │ │ │ │ -
113 Index faceIndex,
│ │ │ │ -
114 Index vertexIndices[]) const override;
│ │ │ │ -
115
│ │ │ │ - │ │ │ │ -
117 Index faceIndex,
│ │ │ │ -
118 FVarID fvarID, Index fvarValueIndices[]) const override;
│ │ │ │ -
120
│ │ │ │ -
121private:
│ │ │ │ -
122 //
│ │ │ │ -
123 // Internal supporting methods:
│ │ │ │ -
124 //
│ │ │ │ -
125 int getFaceVaryingChannel(FVarID fvarID) const;
│ │ │ │ -
126
│ │ │ │ -
127 int getFaceVertexPointIndices(Index faceIndex, int faceVertex,
│ │ │ │ -
128 Index indices[], int vtxOrFVarChannel) const;
│ │ │ │ -
129
│ │ │ │ -
130 int getFacePatchPointIndices(Index faceIndex,
│ │ │ │ -
131 Index indices[], int vtxOrFVarChannel) const;
│ │ │ │ -
132
│ │ │ │ -
133private:
│ │ │ │ -
134 // Additional members for the subclass:
│ │ │ │ -
135 Far::TopologyRefiner const & _mesh;
│ │ │ │ -
136
│ │ │ │ -
137 int _numFaces;
│ │ │ │ -
138 int _numFVarChannels;
│ │ │ │ -
139};
│ │ │ │ -
│ │ │ │ -
140
│ │ │ │ +
112 bool IsRegular() const { return _data.isRegular(); }
│ │ │ │ +
113
│ │ │ │ +
115 bool IsLinear() const { return _data.isLinear(); }
│ │ │ │ +
117
│ │ │ │ +
119
│ │ │ │ +
135
│ │ │ │ +
137 int GetNumControlPoints() const { return _data.getNumCVs(); }
│ │ │ │ +
138
│ │ │ │ +
140 int GetControlPointIndices(Index meshPointIndices[]) const;
│ │ │ │
141
│ │ │ │ -
142//
│ │ │ │ -
156template <class CACHE_TYPE = SurfaceFactoryCache>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
158public:
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
160 Options const & options = Options()) :
│ │ │ │ -
161 RefinerSurfaceFactoryBase(mesh, options),
│ │ │ │ -
162 _localCache() {
│ │ │ │ -
163
│ │ │ │ - │ │ │ │ -
165 }
│ │ │ │ -
│ │ │ │ -
166 ~RefinerSurfaceFactory() override = default;
│ │ │ │ -
167
│ │ │ │ -
168private:
│ │ │ │ -
169 CACHE_TYPE _localCache;
│ │ │ │ -
170};
│ │ │ │ -
│ │ │ │ +
151 template <typename REAL_MESH>
│ │ │ │ +
152 void GatherControlPoints(REAL_MESH const meshPoints[],
│ │ │ │ +
153 PointDescriptor const & meshPointDesc,
│ │ │ │ +
154 REAL controlPoints[],
│ │ │ │ +
155 PointDescriptor const & controlPointDesc) const;
│ │ │ │ +
156
│ │ │ │ +
158 void BoundControlPoints(REAL const controlPoints[],
│ │ │ │ +
159 PointDescriptor const & controlPointDesc,
│ │ │ │ +
160 REAL minExtent[],
│ │ │ │ +
161 REAL maxExtent[]) const;
│ │ │ │ +
162
│ │ │ │ +
164 void BoundControlPointsFromMesh(REAL const meshPoints[],
│ │ │ │ +
165 PointDescriptor const & meshPointDesc,
│ │ │ │ +
166 REAL minExtent[],
│ │ │ │ +
167 REAL maxExtent[]) const;
│ │ │ │ +
169
│ │ │ │
171
│ │ │ │ -
172} // end namespace Bfr
│ │ │ │ -
173
│ │ │ │ -
174} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
175using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
176
│ │ │ │ -
177} // end namespace OpenSubdiv
│ │ │ │ -
178
│ │ │ │ -
179#endif /* OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H */
│ │ │ │ - │ │ │ │ -
Intermediate subclass of SurfaceFactory with Far::TopologyRefiner as the mesh.
│ │ │ │ - │ │ │ │ -
int GetNumFVarChannels() const
Return the number of face-varying channels.
│ │ │ │ -
Far::TopologyRefiner const & GetMesh() const
Return the instance of the mesh.
│ │ │ │ - │ │ │ │ -
RefinerSurfaceFactoryBase(Far::TopologyRefiner const &mesh, Options const &options)
│ │ │ │ -
Template for concrete subclasses of RefinerSurfaceFactoryBase.
│ │ │ │ - │ │ │ │ -
RefinerSurfaceFactory(Far::TopologyRefiner const &mesh, Options const &options=Options())
│ │ │ │ +
177
│ │ │ │ +
179 int GetNumPatchPoints() const;
│ │ │ │ +
180
│ │ │ │ +
199 void PreparePatchPoints(REAL const meshPoints[],
│ │ │ │ +
200 PointDescriptor const & meshPointDesc,
│ │ │ │ +
201 REAL patchPoints[],
│ │ │ │ +
202 PointDescriptor const & patchPointDesc) const;
│ │ │ │ +
203
│ │ │ │ +
213 void ComputePatchPoints(REAL patchPoints[],
│ │ │ │ +
214 PointDescriptor const & patchPointDesc) const;
│ │ │ │ +
216
│ │ │ │ +
218
│ │ │ │ +
225
│ │ │ │ +
227 void Evaluate(REAL const uv[2],
│ │ │ │ +
228 REAL const patchPoints[], PointDescriptor const & pointDesc,
│ │ │ │ +
229 REAL P[]) const;
│ │ │ │ +
230
│ │ │ │ +
232 void Evaluate(REAL const uv[2],
│ │ │ │ +
233 REAL const patchPoints[], PointDescriptor const & pointDesc,
│ │ │ │ +
234 REAL P[], REAL Du[], REAL Dv[]) const;
│ │ │ │ +
235
│ │ │ │ +
237 void Evaluate(REAL const uv[2],
│ │ │ │ +
238 REAL const patchPoints[], PointDescriptor const & pointDesc,
│ │ │ │ +
239 REAL P[], REAL Du[], REAL Dv[],
│ │ │ │ +
240 REAL Duu[], REAL Duv[], REAL Dvv[]) const;
│ │ │ │ +
242
│ │ │ │ +
244
│ │ │ │ +
256
│ │ │ │ +
258 int EvaluateStencil(REAL const uv[2], REAL sP[]) const;
│ │ │ │ +
259
│ │ │ │ +
261 int EvaluateStencil(REAL const uv[2], REAL sP[],
│ │ │ │ +
262 REAL sDu[], REAL sDv[]) const;
│ │ │ │ +
263
│ │ │ │ +
265 int EvaluateStencil(REAL const uv[2], REAL sP[],
│ │ │ │ +
266 REAL sDu[], REAL sDv[],
│ │ │ │ +
267 REAL sDuu[], REAL sDuv[], REAL sDvv[]) const;
│ │ │ │ +
268
│ │ │ │ +
270 void ApplyStencil(REAL const stencil[],
│ │ │ │ +
271 REAL const controlPoints[], PointDescriptor const &,
│ │ │ │ +
272 REAL result[]) const;
│ │ │ │ +
273
│ │ │ │ +
275 void ApplyStencilFromMesh(REAL const stencil[],
│ │ │ │ +
276 REAL const meshPoints[], PointDescriptor const &,
│ │ │ │ +
277 REAL result[]) const;
│ │ │ │ +
279
│ │ │ │ +
280private:
│ │ │ │ +
281 // Internal methods for evaluating derivatives, basis weights and
│ │ │ │ +
282 // stencils for regular, irregular and irregular linear patches:
│ │ │ │ + │ │ │ │ +
284
│ │ │ │ +
285 void evaluateDerivs(REAL const uv[2], REAL const patchPoints[],
│ │ │ │ +
286 PointDescriptor const &, REAL * derivs[]) const;
│ │ │ │ +
287 void evalRegularDerivs(REAL const uv[2], REAL const patchPoints[],
│ │ │ │ +
288 PointDescriptor const &, REAL * derivs[]) const;
│ │ │ │ +
289 void evalIrregularDerivs(REAL const uv[2], REAL const patchPoints[],
│ │ │ │ +
290 PointDescriptor const &, REAL * derivs[]) const;
│ │ │ │ +
291 void evalMultiLinearDerivs(REAL const uv[2], REAL const patchPoints[],
│ │ │ │ +
292 PointDescriptor const &, REAL * derivs[]) const;
│ │ │ │ +
293
│ │ │ │ +
294 void evalRegularBasis(REAL const uv[2], REAL * wDeriv[]) const;
│ │ │ │ +
295 IndexArray evalIrregularBasis(REAL const uv[2], REAL * wDeriv[]) const;
│ │ │ │ +
296 int evalMultiLinearBasis(REAL const uv[2], REAL * wDeriv[]) const;
│ │ │ │ +
297
│ │ │ │ +
298 int evaluateStencils(REAL const uv[2], REAL * sDeriv[]) const;
│ │ │ │ +
299 int evalRegularStencils(REAL const uv[2], REAL * sDeriv[]) const;
│ │ │ │ +
300 int evalIrregularStencils(REAL const uv[2], REAL * sDeriv[]) const;
│ │ │ │ +
301 int evalMultiLinearStencils(REAL const uv[2], REAL * sDeriv[]) const;
│ │ │ │ +
302
│ │ │ │ +
303 // Internal methods to compute patch points:
│ │ │ │ +
304 void computeLinearPatchPoints(REAL p[], PointDescriptor const &) const;
│ │ │ │ +
305 void computeIrregularPatchPoints(REAL p[], PointDescriptor const &) const;
│ │ │ │ +
306
│ │ │ │ +
307 // Internal methods specific to regular or irregular patches:
│ │ │ │ +
308 unsigned char getRegPatchType() const { return _data.getRegPatchType(); }
│ │ │ │ +
309 unsigned char getRegPatchMask() const { return _data.getRegPatchMask(); }
│ │ │ │ +
310
│ │ │ │ +
311 internal::IrregularPatchType const & getIrregPatch() const;
│ │ │ │ +
312
│ │ │ │ +
313private:
│ │ │ │ +
314 // Access to the set of member variables - provided to the Factory:
│ │ │ │ +
315 friend class SurfaceFactory;
│ │ │ │ +
316
│ │ │ │ +
317 internal::SurfaceData & getSurfaceData() { return _data; }
│ │ │ │ +
318 internal::SurfaceData const & getSurfaceData() const { return _data; }
│ │ │ │ +
319
│ │ │ │ +
320private:
│ │ │ │ +
321 // All member variables encapsulated in a single class:
│ │ │ │ +
322 internal::SurfaceData _data;
│ │ │ │ +
323};
│ │ │ │ +
│ │ │ │ +
324
│ │ │ │ +
325
│ │ │ │ +
326//
│ │ │ │ +
327// Simple inline methods composed of other methods:
│ │ │ │ +
328//
│ │ │ │ +
329template <typename REAL>
│ │ │ │ +
330inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
332 PointDescriptor const & pointDesc) const {
│ │ │ │ +
333
│ │ │ │ +
334 if (!IsRegular()) {
│ │ │ │ +
335 if (IsLinear()) {
│ │ │ │ +
336 computeLinearPatchPoints(points, pointDesc);
│ │ │ │ +
337 } else {
│ │ │ │ +
338 computeIrregularPatchPoints(points, pointDesc);
│ │ │ │ +
339 }
│ │ │ │ +
340 }
│ │ │ │ +
341}
│ │ │ │ +
│ │ │ │ +
342
│ │ │ │ +
343template <typename REAL>
│ │ │ │ +
344inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
346 REAL const meshPoints[], PointDescriptor const & meshPointDesc,
│ │ │ │ +
347 REAL patchPoints[], PointDescriptor const & patchPointDesc) const {
│ │ │ │ +
348
│ │ │ │ +
349 GatherControlPoints(meshPoints, meshPointDesc, patchPoints, patchPointDesc);
│ │ │ │ +
350 ComputePatchPoints(patchPoints, patchPointDesc);
│ │ │ │ +
351}
│ │ │ │ +
│ │ │ │ +
352
│ │ │ │ +
353//
│ │ │ │ +
354// Inline invocations of more general methods for derivative overloads:
│ │ │ │ +
355//
│ │ │ │ +
356template <typename REAL>
│ │ │ │ +
357inline void
│ │ │ │ +
358Surface<REAL>::evaluateDerivs(REAL const uv[2],
│ │ │ │ +
359 REAL const patchPoints[],
│ │ │ │ +
360 PointDescriptor const & pointDesc,
│ │ │ │ +
361 REAL * derivatives[]) const {
│ │ │ │ +
362 if (IsRegular()) {
│ │ │ │ +
363 evalRegularDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ +
364 } else if (IsLinear()) {
│ │ │ │ +
365 evalMultiLinearDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ +
366 } else {
│ │ │ │ +
367 evalIrregularDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ +
368 }
│ │ │ │ +
369}
│ │ │ │ +
370template <typename REAL>
│ │ │ │ +
371inline void
│ │ │ │ +
│ │ │ │ +
372Surface<REAL>::Evaluate(REAL const uv[2],
│ │ │ │ +
373 REAL const patchPoints[],
│ │ │ │ +
374 PointDescriptor const & pointDesc,
│ │ │ │ +
375 REAL P[]) const {
│ │ │ │ +
376
│ │ │ │ +
377 REAL * derivatives[6] = { P, 0, 0, 0, 0, 0 };
│ │ │ │ +
378 evaluateDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ +
379}
│ │ │ │ +
│ │ │ │ +
380template <typename REAL>
│ │ │ │ +
381inline void
│ │ │ │ +
│ │ │ │ +
382Surface<REAL>::Evaluate(REAL const uv[2],
│ │ │ │ +
383 REAL const patchPoints[],
│ │ │ │ +
384 PointDescriptor const & pointDesc,
│ │ │ │ +
385 REAL P[], REAL Du[], REAL Dv[]) const {
│ │ │ │ +
386
│ │ │ │ +
387 REAL * derivatives[6] = { P, Du, Dv, 0, 0, 0 };
│ │ │ │ +
388 evaluateDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ +
389}
│ │ │ │ +
│ │ │ │ +
390template <typename REAL>
│ │ │ │ +
391inline void
│ │ │ │ +
│ │ │ │ +
392Surface<REAL>::Evaluate(REAL const uv[2],
│ │ │ │ +
393 REAL const patchPoints[],
│ │ │ │ +
394 PointDescriptor const & pointDesc,
│ │ │ │ +
395 REAL P[], REAL Du[], REAL Dv[],
│ │ │ │ +
396 REAL Duu[], REAL Duv[], REAL Dvv[]) const {
│ │ │ │ +
397
│ │ │ │ +
398 REAL * derivatives[6] = { P, Du, Dv, Duu, Duv, Dvv };
│ │ │ │ +
399 evaluateDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ +
400}
│ │ │ │ +
│ │ │ │ +
401
│ │ │ │ +
402template <typename REAL>
│ │ │ │ +
403inline int
│ │ │ │ +
404Surface<REAL>::evaluateStencils(REAL const uv[2], REAL * sDeriv[]) const {
│ │ │ │ +
405
│ │ │ │ +
406 if (IsRegular()) {
│ │ │ │ +
407 return evalRegularStencils(uv, sDeriv);
│ │ │ │ +
408 } else if (IsLinear()) {
│ │ │ │ +
409 return evalMultiLinearStencils(uv, sDeriv);
│ │ │ │ +
410 } else {
│ │ │ │ +
411 return evalIrregularStencils(uv, sDeriv);
│ │ │ │ +
412 }
│ │ │ │ +
413}
│ │ │ │ +
414template <typename REAL>
│ │ │ │ +
415inline int
│ │ │ │ +
│ │ │ │ +
416Surface<REAL>::EvaluateStencil(REAL const uv[2], REAL sP[]) const {
│ │ │ │ +
417
│ │ │ │ +
418 REAL * derivativeStencils[6] = { sP, 0, 0, 0, 0, 0 };
│ │ │ │ +
419 return evaluateStencils(uv, derivativeStencils);
│ │ │ │ +
420}
│ │ │ │ +
│ │ │ │ +
421template <typename REAL>
│ │ │ │ +
422inline int
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
424 REAL sP[], REAL sDu[], REAL sDv[]) const {
│ │ │ │ +
425
│ │ │ │ +
426 REAL * derivativeStencils[6] = { sP, sDu, sDv, 0, 0, 0 };
│ │ │ │ +
427 return evaluateStencils(uv, derivativeStencils);
│ │ │ │ +
428}
│ │ │ │ +
│ │ │ │ +
429template <typename REAL>
│ │ │ │ +
430inline int
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
432 REAL sP[], REAL sDu[], REAL sDv[],
│ │ │ │ +
433 REAL sDuu[], REAL sDuv[], REAL sDvv[]) const {
│ │ │ │ +
434
│ │ │ │ +
435 REAL * derivativeStencils[6] = { sP, sDu, sDv, sDuu, sDuv, sDvv };
│ │ │ │ +
436 return evaluateStencils(uv, derivativeStencils);
│ │ │ │ +
437}
│ │ │ │ +
│ │ │ │ +
438
│ │ │ │ +
439} // end namespace Bfr
│ │ │ │ +
440
│ │ │ │ +
441} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
442using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
443
│ │ │ │ +
444} // end namespace OpenSubdiv
│ │ │ │ +
445
│ │ │ │ +
446#endif /* OPENSUBDIV3_BFR_SURFACE */
│ │ │ │ + │ │ │ │ +
Simple class defining the 2D parameterization of a face.
│ │ │ │ +
int GetFaceSize() const
Returns the size (number of vertices) of the corresponding face.
│ │ │ │ +
Encapsulates the limit surface for a face of a mesh.
Definition surface.h:59
│ │ │ │ +
int GetNumControlPoints() const
Return the number of control points affecting the Surface.
Definition surface.h:137
│ │ │ │ +
void Evaluate(REAL const uv[2], REAL const patchPoints[], PointDescriptor const &pointDesc, REAL P[]) const
Evaluation of position.
Definition surface.h:372
│ │ │ │ +
int GetFaceSize() const
Return the size of the face.
Definition surface.h:109
│ │ │ │ +
bool IsRegular() const
Return if the Surface is a single regular patch.
Definition surface.h:112
│ │ │ │ +
void BoundControlPoints(REAL const controlPoints[], PointDescriptor const &controlPointDesc, REAL minExtent[], REAL maxExtent[]) const
Compute bounds of control points from a local array.
│ │ │ │ +
int GetControlPointIndices(Index meshPointIndices[]) const
Identify indices of control points in the mesh.
│ │ │ │ +
int Index
Integer type representing a mesh index.
Definition surface.h:72
│ │ │ │ +
void ApplyStencil(REAL const stencil[], REAL const controlPoints[], PointDescriptor const &, REAL result[]) const
Apply a single stencil to control points from a local array.
│ │ │ │ +
Parameterization GetParameterization() const
Return the Parameterization.
Definition surface.h:106
│ │ │ │ +
Surface()
Default construction produces an invalid instance.
│ │ │ │ +
void ApplyStencilFromMesh(REAL const stencil[], REAL const meshPoints[], PointDescriptor const &, REAL result[]) const
Apply a single stencil to control points from the mesh data.
│ │ │ │ +
Surface & operator=(Surface const &src)=default
│ │ │ │ +
void BoundControlPointsFromMesh(REAL const meshPoints[], PointDescriptor const &meshPointDesc, REAL minExtent[], REAL maxExtent[]) const
Compute bounds of control points from the mesh data.
│ │ │ │ + │ │ │ │ +
void Clear()
Clear a previously initialized Surface.
Definition surface.h:89
│ │ │ │ + │ │ │ │ +
void PreparePatchPoints(REAL const meshPoints[], PointDescriptor const &meshPointDesc, REAL patchPoints[], PointDescriptor const &patchPointDesc) const
Prepare patch points in a local array for evaluation.
Definition surface.h:345
│ │ │ │ +
bool IsValid() const
Return true if successfully initialized.
Definition surface.h:86
│ │ │ │ +
void GatherControlPoints(REAL_MESH const meshPoints[], PointDescriptor const &meshPointDesc, REAL controlPoints[], PointDescriptor const &controlPointDesc) const
Gather control points in a local array.
│ │ │ │ +
void ComputePatchPoints(REAL patchPoints[], PointDescriptor const &patchPointDesc) const
Compute all patch points following the control points.
Definition surface.h:331
│ │ │ │ +
bool IsLinear() const
Return if the Surface is linear.
Definition surface.h:115
│ │ │ │ +
int GetNumPatchPoints() const
Return the number of patch points representing the Surface.
│ │ │ │ +
int EvaluateStencil(REAL const uv[2], REAL sP[]) const
Evaluation of the limit stencil for position.
Definition surface.h:416
│ │ │ │ +
Simple struct defining the size and stride of points in arrays.
Definition surface.h:63
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │
Base class providing initialization of a Surface for each face of a mesh.
│ │ │ │ -
void setInternalCache(SurfaceFactoryCache *cache)
Subclass to identify an internal cache for use by base class.
│ │ │ │ -
Simple set of options assigned to instances of SurfaceFactory.
│ │ │ │ -
virtual int getFaceVertexIncidentFaceFVarValueIndices(Index faceIndex, int faceVertex, FVarID fvarID, Index fvarValueIndices[]) const =0
Gather face-varying indices of incident faces around a face-vertex.
│ │ │ │ -
virtual int getFaceVertexIncidentFaceVertexIndices(Index faceIndex, int faceVertex, Index vertexIndices[]) const =0
Gather vertex indices of incident faces around a face-vertex.
│ │ │ │ -
virtual int getFaceSize(Index faceIndex) const =0
Returns the size of a face (number of vertices)
│ │ │ │ - │ │ │ │ -
virtual int populateFaceVertexDescriptor(Index faceIndex, int faceVertex, VertexDescriptor *vertexDescriptor) const =0
Describe the topology of incident faces around a face-vertex.
│ │ │ │ -
virtual bool getFaceNeighborhoodVertexIndicesIfRegular(Index faceIndex, Index vertexIndices[]) const
│ │ │ │ -
virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular(Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const
│ │ │ │ -
virtual int getFaceFVarValueIndices(Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const =0
Gather the face-varying indices of the face's vertices.
│ │ │ │ -
virtual int getFaceVertexIndices(Index faceIndex, Index vertexIndices[]) const =0
Gather the indices of the face's vertices.
│ │ │ │ -
virtual bool isFaceHole(Index faceIndex) const =0
Returns if a face is a hole.
│ │ │ │ -
std::intptr_t FVarID
Type used to identify and specify face-varying primvars.
│ │ │ │ -
Simple class used by subclasses of SurfaceFactory to describe a vertex.
│ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ + │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -refinerSurfaceFactory.h │ │ │ │ │ +surface.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2021 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,222 +24,420 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H │ │ │ │ │ -26#define OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_BFR_SURFACE_H │ │ │ │ │ +26#define OPENSUBDIV3_BFR_SURFACE_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ 29 │ │ │ │ │ -30#include "../bfr/surfaceFactory.h" │ │ │ │ │ -31#include "../bfr/surfaceFactoryCache.h" │ │ │ │ │ -32 │ │ │ │ │ -33namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -34namespace OPENSUBDIV_VERSION { │ │ │ │ │ -35 │ │ │ │ │ -_3_6namespace Far { │ │ │ │ │ -37 class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r; │ │ │ │ │ -38} │ │ │ │ │ -39 │ │ │ │ │ -40namespace Bfr { │ │ │ │ │ -41 │ │ │ │ │ -_5_8class _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e : public _S_u_r_f_a_c_e_F_a_c_t_o_r_y { │ │ │ │ │ -59public: │ │ │ │ │ -61 │ │ │ │ │ -65 │ │ │ │ │ -_6_6 _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e(_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & mesh, │ │ │ │ │ -67 _O_p_t_i_o_n_s const & options); │ │ │ │ │ -68 │ │ │ │ │ -_6_9 _~_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e() override = default; │ │ │ │ │ -71 │ │ │ │ │ +30#include "../bfr/surfaceData.h" │ │ │ │ │ +31#include "../bfr/parameterization.h" │ │ │ │ │ +32#include "../vtr/array.h" │ │ │ │ │ +33 │ │ │ │ │ +34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +35namespace OPENSUBDIV_VERSION { │ │ │ │ │ +36 │ │ │ │ │ +37namespace Bfr { │ │ │ │ │ +38 │ │ │ │ │ +58template │ │ │ │ │ +_5_9class _S_u_r_f_a_c_e { │ │ │ │ │ +60public: │ │ │ │ │ +_6_3 struct _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r { │ │ │ │ │ +_6_4 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r() : _s_i_z_e(0), _s_t_r_i_d_e(0) { } │ │ │ │ │ +_6_5 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r(int n) : _s_i_z_e(n), _s_t_r_i_d_e(n) { } │ │ │ │ │ +_6_6 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r(int n, int m) : _s_i_z_e(n), _s_t_r_i_d_e(m) { } │ │ │ │ │ +67 │ │ │ │ │ +_6_8 int _s_i_z_e, _s_t_r_i_d_e; │ │ │ │ │ +69 }; │ │ │ │ │ +70 │ │ │ │ │ +_7_2 typedef int _I_n_d_e_x; │ │ │ │ │ 73 │ │ │ │ │ -77 │ │ │ │ │ -_7_9 _F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & _G_e_t_M_e_s_h() const { return _mesh; } │ │ │ │ │ -80 │ │ │ │ │ -_8_2 int _G_e_t_N_u_m_F_a_c_e_s() const { return _numFaces; } │ │ │ │ │ -83 │ │ │ │ │ -_8_5 int _G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const { return _numFVarChannels; } │ │ │ │ │ +74public: │ │ │ │ │ +76 │ │ │ │ │ +84 │ │ │ │ │ +_8_6 bool _I_s_V_a_l_i_d() const { return _data.isValid(); } │ │ │ │ │ 87 │ │ │ │ │ -88protected: │ │ │ │ │ -90 // │ │ │ │ │ -91 // Virtual overrides to satisfy the SurfaceFactoryMeshAdapter interface: │ │ │ │ │ -92 // │ │ │ │ │ -93 bool _i_s_F_a_c_e_H_o_l_e( _I_n_d_e_x faceIndex) const override; │ │ │ │ │ -94 int _g_e_t_F_a_c_e_S_i_z_e(_I_n_d_e_x faceIndex) const override; │ │ │ │ │ -95 │ │ │ │ │ -96 int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s(_I_n_d_e_x faceIndex, │ │ │ │ │ -97 _I_n_d_e_x vertexIndices[]) const override; │ │ │ │ │ -98 int _g_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s(_I_n_d_e_x faceIndex, │ │ │ │ │ -99 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const override; │ │ │ │ │ +_8_9 void _C_l_e_a_r() { _data.reinitialize(); } │ │ │ │ │ +90 │ │ │ │ │ +_9_2 _S_u_r_f_a_c_e(); │ │ │ │ │ +93 │ │ │ │ │ +_9_4 _S_u_r_f_a_c_e(_S_u_r_f_a_c_e const & src) = default; │ │ │ │ │ +_9_5 _S_u_r_f_a_c_e& _o_p_e_r_a_t_o_r_=(_S_u_r_f_a_c_e const & src) = default; │ │ │ │ │ +_9_6 _~_S_u_r_f_a_c_e() = default; │ │ │ │ │ +98 │ │ │ │ │ 100 │ │ │ │ │ -101 int _p_o_p_u_l_a_t_e_F_a_c_e_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r(_I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ -102 _V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r * vertexDescriptor) const override; │ │ │ │ │ -103 │ │ │ │ │ -104 int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s( │ │ │ │ │ -105 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ -106 _I_n_d_e_x vertexIndices[]) const override; │ │ │ │ │ -107 int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s( │ │ │ │ │ -108 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ -109 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const override; │ │ │ │ │ +104 │ │ │ │ │ +_1_0_6 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n _G_e_t_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n() const { return _data.getParam(); } │ │ │ │ │ +107 │ │ │ │ │ +_1_0_9 int _G_e_t_F_a_c_e_S_i_z_e() const { return _G_e_t_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n()._G_e_t_F_a_c_e_S_i_z_e(); } │ │ │ │ │ 110 │ │ │ │ │ -111 // Optional SurfaceFactoryMeshAdapter overrides for regular patches: │ │ │ │ │ -112 bool _g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ -113 _I_n_d_e_x faceIndex, │ │ │ │ │ -114 _I_n_d_e_x vertexIndices[]) const override; │ │ │ │ │ -115 │ │ │ │ │ -116 bool _g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ -117 _I_n_d_e_x faceIndex, │ │ │ │ │ -118 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const override; │ │ │ │ │ -120 │ │ │ │ │ -121private: │ │ │ │ │ -122 // │ │ │ │ │ -123 // Internal supporting methods: │ │ │ │ │ -124 // │ │ │ │ │ -125 int getFaceVaryingChannel(_F_V_a_r_I_D fvarID) const; │ │ │ │ │ -126 │ │ │ │ │ -127 int getFaceVertexPointIndices(_I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ -128 _I_n_d_e_x indices[], int vtxOrFVarChannel) const; │ │ │ │ │ -129 │ │ │ │ │ -130 int getFacePatchPointIndices(_I_n_d_e_x faceIndex, │ │ │ │ │ -131 _I_n_d_e_x indices[], int vtxOrFVarChannel) const; │ │ │ │ │ -132 │ │ │ │ │ -133private: │ │ │ │ │ -134 // Additional members for the subclass: │ │ │ │ │ -135 _F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & _mesh; │ │ │ │ │ -136 │ │ │ │ │ -137 int _numFaces; │ │ │ │ │ -138 int _numFVarChannels; │ │ │ │ │ -139}; │ │ │ │ │ -140 │ │ │ │ │ +_1_1_2 bool _I_s_R_e_g_u_l_a_r() const { return _data.isRegular(); } │ │ │ │ │ +113 │ │ │ │ │ +_1_1_5 bool _I_s_L_i_n_e_a_r() const { return _data.isLinear(); } │ │ │ │ │ +117 │ │ │ │ │ +119 │ │ │ │ │ +135 │ │ │ │ │ +_1_3_7 int _G_e_t_N_u_m_C_o_n_t_r_o_l_P_o_i_n_t_s() const { return _data.getNumCVs(); } │ │ │ │ │ +138 │ │ │ │ │ +_1_4_0 int _G_e_t_C_o_n_t_r_o_l_P_o_i_n_t_I_n_d_i_c_e_s(_I_n_d_e_x meshPointIndices[]) const; │ │ │ │ │ 141 │ │ │ │ │ -142// │ │ │ │ │ -156template │ │ │ │ │ -_1_5_7class _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y : public _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e { │ │ │ │ │ -158public: │ │ │ │ │ -_1_5_9 _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y(_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & mesh, │ │ │ │ │ -160 _O_p_t_i_o_n_s const & options = _O_p_t_i_o_n_s()) : │ │ │ │ │ -161 _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e(mesh, options), │ │ │ │ │ -162 _localCache() { │ │ │ │ │ -163 │ │ │ │ │ -164 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_:_s_e_t_I_n_t_e_r_n_a_l_C_a_c_h_e(&_localCache); │ │ │ │ │ -165 } │ │ │ │ │ -_1_6_6 _~_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y() override = default; │ │ │ │ │ -167 │ │ │ │ │ -168private: │ │ │ │ │ -169 CACHE_TYPE _localCache; │ │ │ │ │ -170}; │ │ │ │ │ +151 template │ │ │ │ │ +_1_5_2 void _G_a_t_h_e_r_C_o_n_t_r_o_l_P_o_i_n_t_s(REAL_MESH const meshPoints[], │ │ │ │ │ +153 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & meshPointDesc, │ │ │ │ │ +154 REAL controlPoints[], │ │ │ │ │ +155 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & controlPointDesc) const; │ │ │ │ │ +156 │ │ │ │ │ +_1_5_8 void _B_o_u_n_d_C_o_n_t_r_o_l_P_o_i_n_t_s(REAL const controlPoints[], │ │ │ │ │ +159 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & controlPointDesc, │ │ │ │ │ +160 REAL minExtent[], │ │ │ │ │ +161 REAL maxExtent[]) const; │ │ │ │ │ +162 │ │ │ │ │ +_1_6_4 void _B_o_u_n_d_C_o_n_t_r_o_l_P_o_i_n_t_s_F_r_o_m_M_e_s_h(REAL const meshPoints[], │ │ │ │ │ +165 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & meshPointDesc, │ │ │ │ │ +166 REAL minExtent[], │ │ │ │ │ +167 REAL maxExtent[]) const; │ │ │ │ │ +169 │ │ │ │ │ 171 │ │ │ │ │ -172} // end namespace Bfr │ │ │ │ │ -173 │ │ │ │ │ -174} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -175using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -176 │ │ │ │ │ -177} // end namespace OpenSubdiv │ │ │ │ │ -178 │ │ │ │ │ -179#endif /* OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H */ │ │ │ │ │ +177 │ │ │ │ │ +_1_7_9 int _G_e_t_N_u_m_P_a_t_c_h_P_o_i_n_t_s() const; │ │ │ │ │ +180 │ │ │ │ │ +199 void _P_r_e_p_a_r_e_P_a_t_c_h_P_o_i_n_t_s(REAL const meshPoints[], │ │ │ │ │ +200 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & meshPointDesc, │ │ │ │ │ +201 REAL patchPoints[], │ │ │ │ │ +202 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & patchPointDesc) const; │ │ │ │ │ +203 │ │ │ │ │ +213 void _C_o_m_p_u_t_e_P_a_t_c_h_P_o_i_n_t_s(REAL patchPoints[], │ │ │ │ │ +214 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & patchPointDesc) const; │ │ │ │ │ +216 │ │ │ │ │ +218 │ │ │ │ │ +225 │ │ │ │ │ +227 void _E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ +228 REAL const patchPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ +229 REAL P[]) const; │ │ │ │ │ +230 │ │ │ │ │ +232 void _E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ +233 REAL const patchPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ +234 REAL P[], REAL Du[], REAL Dv[]) const; │ │ │ │ │ +235 │ │ │ │ │ +237 void _E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ +238 REAL const patchPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ +239 REAL P[], REAL Du[], REAL Dv[], │ │ │ │ │ +240 REAL Duu[], REAL Duv[], REAL Dvv[]) const; │ │ │ │ │ +242 │ │ │ │ │ +244 │ │ │ │ │ +256 │ │ │ │ │ +258 int _E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], REAL sP[]) const; │ │ │ │ │ +259 │ │ │ │ │ +261 int _E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], REAL sP[], │ │ │ │ │ +262 REAL sDu[], REAL sDv[]) const; │ │ │ │ │ +263 │ │ │ │ │ +265 int _E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], REAL sP[], │ │ │ │ │ +266 REAL sDu[], REAL sDv[], │ │ │ │ │ +267 REAL sDuu[], REAL sDuv[], REAL sDvv[]) const; │ │ │ │ │ +268 │ │ │ │ │ +_2_7_0 void _A_p_p_l_y_S_t_e_n_c_i_l(REAL const stencil[], │ │ │ │ │ +271 REAL const controlPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, │ │ │ │ │ +272 REAL result[]) const; │ │ │ │ │ +273 │ │ │ │ │ +_2_7_5 void _A_p_p_l_y_S_t_e_n_c_i_l_F_r_o_m_M_e_s_h(REAL const stencil[], │ │ │ │ │ +276 REAL const meshPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, │ │ │ │ │ +277 REAL result[]) const; │ │ │ │ │ +279 │ │ │ │ │ +280private: │ │ │ │ │ +281 // Internal methods for evaluating derivatives, basis weights and │ │ │ │ │ +282 // stencils for regular, irregular and irregular linear patches: │ │ │ │ │ +283 typedef _V_t_r_:_:_C_o_n_s_t_A_r_r_a_y_<_i_n_t_> _I_n_d_e_x_A_r_r_a_y; │ │ │ │ │ +284 │ │ │ │ │ +285 void evaluateDerivs(REAL const uv[2], REAL const patchPoints[], │ │ │ │ │ +286 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, REAL * derivs[]) const; │ │ │ │ │ +287 void evalRegularDerivs(REAL const uv[2], REAL const patchPoints[], │ │ │ │ │ +288 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, REAL * derivs[]) const; │ │ │ │ │ +289 void evalIrregularDerivs(REAL const uv[2], REAL const patchPoints[], │ │ │ │ │ +290 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, REAL * derivs[]) const; │ │ │ │ │ +291 void evalMultiLinearDerivs(REAL const uv[2], REAL const patchPoints[], │ │ │ │ │ +292 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, REAL * derivs[]) const; │ │ │ │ │ +293 │ │ │ │ │ +294 void evalRegularBasis(REAL const uv[2], REAL * wDeriv[]) const; │ │ │ │ │ +295 _I_n_d_e_x_A_r_r_a_y evalIrregularBasis(REAL const uv[2], REAL * wDeriv[]) const; │ │ │ │ │ +296 int evalMultiLinearBasis(REAL const uv[2], REAL * wDeriv[]) const; │ │ │ │ │ +297 │ │ │ │ │ +298 int evaluateStencils(REAL const uv[2], REAL * sDeriv[]) const; │ │ │ │ │ +299 int evalRegularStencils(REAL const uv[2], REAL * sDeriv[]) const; │ │ │ │ │ +300 int evalIrregularStencils(REAL const uv[2], REAL * sDeriv[]) const; │ │ │ │ │ +301 int evalMultiLinearStencils(REAL const uv[2], REAL * sDeriv[]) const; │ │ │ │ │ +302 │ │ │ │ │ +303 // Internal methods to compute patch points: │ │ │ │ │ +304 void computeLinearPatchPoints(REAL p[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &) const; │ │ │ │ │ +305 void computeIrregularPatchPoints(REAL p[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &) const; │ │ │ │ │ +306 │ │ │ │ │ +307 // Internal methods specific to regular or irregular patches: │ │ │ │ │ +308 unsigned char getRegPatchType() const { return _data.getRegPatchType(); } │ │ │ │ │ +309 unsigned char getRegPatchMask() const { return _data.getRegPatchMask(); } │ │ │ │ │ +310 │ │ │ │ │ +311 internal::IrregularPatchType const & getIrregPatch() const; │ │ │ │ │ +312 │ │ │ │ │ +313private: │ │ │ │ │ +314 // Access to the set of member variables - provided to the Factory: │ │ │ │ │ +_3_1_5 friend class _S_u_r_f_a_c_e_F_a_c_t_o_r_y; │ │ │ │ │ +316 │ │ │ │ │ +317 internal::SurfaceData & getSurfaceData() { return _data; } │ │ │ │ │ +318 internal::SurfaceData const & getSurfaceData() const { return _data; } │ │ │ │ │ +319 │ │ │ │ │ +320private: │ │ │ │ │ +321 // All member variables encapsulated in a single class: │ │ │ │ │ +322 internal::SurfaceData _data; │ │ │ │ │ +323}; │ │ │ │ │ +324 │ │ │ │ │ +325 │ │ │ │ │ +326// │ │ │ │ │ +327// Simple inline methods composed of other methods: │ │ │ │ │ +328// │ │ │ │ │ +329template │ │ │ │ │ +330inline void │ │ │ │ │ +_3_3_1_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_C_o_m_p_u_t_e_P_a_t_c_h_P_o_i_n_t_s(REAL points[], │ │ │ │ │ +332 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc) const { │ │ │ │ │ +333 │ │ │ │ │ +334 if (!IsRegular()) { │ │ │ │ │ +335 if (IsLinear()) { │ │ │ │ │ +336 computeLinearPatchPoints(points, pointDesc); │ │ │ │ │ +337 } else { │ │ │ │ │ +338 computeIrregularPatchPoints(points, pointDesc); │ │ │ │ │ +339 } │ │ │ │ │ +340 } │ │ │ │ │ +341} │ │ │ │ │ +342 │ │ │ │ │ +343template │ │ │ │ │ +344inline void │ │ │ │ │ +_3_4_5_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_P_r_e_p_a_r_e_P_a_t_c_h_P_o_i_n_t_s( │ │ │ │ │ +346 REAL const meshPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & meshPointDesc, │ │ │ │ │ +347 REAL patchPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & patchPointDesc) const { │ │ │ │ │ +348 │ │ │ │ │ +349 GatherControlPoints(meshPoints, meshPointDesc, patchPoints, │ │ │ │ │ +patchPointDesc); │ │ │ │ │ +350 ComputePatchPoints(patchPoints, patchPointDesc); │ │ │ │ │ +351} │ │ │ │ │ +352 │ │ │ │ │ +353// │ │ │ │ │ +354// Inline invocations of more general methods for derivative overloads: │ │ │ │ │ +355// │ │ │ │ │ +356template │ │ │ │ │ +357inline void │ │ │ │ │ +358_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_e_v_a_l_u_a_t_e_D_e_r_i_v_s(REAL const uv[2], │ │ │ │ │ +359 REAL const patchPoints[], │ │ │ │ │ +360 PointDescriptor const & pointDesc, │ │ │ │ │ +361 REAL * derivatives[]) const { │ │ │ │ │ +362 if (IsRegular()) { │ │ │ │ │ +363 evalRegularDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ +364 } else if (IsLinear()) { │ │ │ │ │ +365 evalMultiLinearDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ +366 } else { │ │ │ │ │ +367 evalIrregularDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ +368 } │ │ │ │ │ +369} │ │ │ │ │ +370template │ │ │ │ │ +371inline void │ │ │ │ │ +_3_7_2_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ +373 REAL const patchPoints[], │ │ │ │ │ +374 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ +375 REAL P[]) const { │ │ │ │ │ +376 │ │ │ │ │ +377 REAL * derivatives[6] = { P, 0, 0, 0, 0, 0 }; │ │ │ │ │ +378 evaluateDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ +379} │ │ │ │ │ +380template │ │ │ │ │ +381inline void │ │ │ │ │ +_3_8_2_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ +383 REAL const patchPoints[], │ │ │ │ │ +384 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ +385 REAL P[], REAL Du[], REAL Dv[]) const { │ │ │ │ │ +386 │ │ │ │ │ +387 REAL * derivatives[6] = { P, Du, Dv, 0, 0, 0 }; │ │ │ │ │ +388 evaluateDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ +389} │ │ │ │ │ +390template │ │ │ │ │ +391inline void │ │ │ │ │ +_3_9_2_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ +393 REAL const patchPoints[], │ │ │ │ │ +394 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ +395 REAL P[], REAL Du[], REAL Dv[], │ │ │ │ │ +396 REAL Duu[], REAL Duv[], REAL Dvv[]) const { │ │ │ │ │ +397 │ │ │ │ │ +398 REAL * derivatives[6] = { P, Du, Dv, Duu, Duv, Dvv }; │ │ │ │ │ +399 evaluateDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ +400} │ │ │ │ │ +401 │ │ │ │ │ +402template │ │ │ │ │ +403inline int │ │ │ │ │ +404_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_e_v_a_l_u_a_t_e_S_t_e_n_c_i_l_s(REAL const uv[2], REAL * sDeriv[]) const { │ │ │ │ │ +405 │ │ │ │ │ +406 if (IsRegular()) { │ │ │ │ │ +407 return evalRegularStencils(uv, sDeriv); │ │ │ │ │ +408 } else if (IsLinear()) { │ │ │ │ │ +409 return evalMultiLinearStencils(uv, sDeriv); │ │ │ │ │ +410 } else { │ │ │ │ │ +411 return evalIrregularStencils(uv, sDeriv); │ │ │ │ │ +412 } │ │ │ │ │ +413} │ │ │ │ │ +414template │ │ │ │ │ +415inline int │ │ │ │ │ +_4_1_6_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], REAL sP[]) const { │ │ │ │ │ +417 │ │ │ │ │ +418 REAL * derivativeStencils[6] = { sP, 0, 0, 0, 0, 0 }; │ │ │ │ │ +419 return evaluateStencils(uv, derivativeStencils); │ │ │ │ │ +420} │ │ │ │ │ +421template │ │ │ │ │ +422inline int │ │ │ │ │ +_4_2_3_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], │ │ │ │ │ +424 REAL sP[], REAL sDu[], REAL sDv[]) const { │ │ │ │ │ +425 │ │ │ │ │ +426 REAL * derivativeStencils[6] = { sP, sDu, sDv, 0, 0, 0 }; │ │ │ │ │ +427 return evaluateStencils(uv, derivativeStencils); │ │ │ │ │ +428} │ │ │ │ │ +429template │ │ │ │ │ +430inline int │ │ │ │ │ +_4_3_1_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], │ │ │ │ │ +432 REAL sP[], REAL sDu[], REAL sDv[], │ │ │ │ │ +433 REAL sDuu[], REAL sDuv[], REAL sDvv[]) const { │ │ │ │ │ +434 │ │ │ │ │ +435 REAL * derivativeStencils[6] = { sP, sDu, sDv, sDuu, sDuv, sDvv }; │ │ │ │ │ +436 return evaluateStencils(uv, derivativeStencils); │ │ │ │ │ +437} │ │ │ │ │ +438 │ │ │ │ │ +439} // end namespace Bfr │ │ │ │ │ +440 │ │ │ │ │ +441} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +442using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +443 │ │ │ │ │ +444} // end namespace OpenSubdiv │ │ │ │ │ +445 │ │ │ │ │ +446#endif /* OPENSUBDIV3_BFR_SURFACE */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ -Intermediate subclass of SurfaceFactory with Far::TopologyRefiner as the mesh. │ │ │ │ │ -DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_5_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_:_G_e_t_N_u_m_F_a_c_e_s │ │ │ │ │ -int GetNumFaces() const │ │ │ │ │ -Return the number of faces. │ │ │ │ │ -DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_8_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_: │ │ │ │ │ -_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ -int GetNumFVarChannels() const │ │ │ │ │ -Return the number of face-varying channels. │ │ │ │ │ -DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_8_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_:_G_e_t_M_e_s_h │ │ │ │ │ -Far::TopologyRefiner const & GetMesh() const │ │ │ │ │ -Return the instance of the mesh. │ │ │ │ │ -DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_7_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_: │ │ │ │ │ -_~_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ -~RefinerSurfaceFactoryBase() override=default │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_: │ │ │ │ │ -_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ -RefinerSurfaceFactoryBase(Far::TopologyRefiner const &mesh, Options const │ │ │ │ │ -&options) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ -Template for concrete subclasses of RefinerSurfaceFactoryBase. │ │ │ │ │ -DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_5_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ -_~_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ -~RefinerSurfaceFactory() override=default │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ -_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ -RefinerSurfaceFactory(Far::TopologyRefiner const &mesh, Options const │ │ │ │ │ -&options=Options()) │ │ │ │ │ -DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_5_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ +Simple class defining the 2D parameterization of a face. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_5_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ +int GetFaceSize() const │ │ │ │ │ +Returns the size (number of vertices) of the corresponding face. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_1_0_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e │ │ │ │ │ +Encapsulates the limit surface for a face of a mesh. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_5_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_N_u_m_C_o_n_t_r_o_l_P_o_i_n_t_s │ │ │ │ │ +int GetNumControlPoints() const │ │ │ │ │ +Return the number of control points affecting the Surface. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_E_v_a_l_u_a_t_e │ │ │ │ │ +void Evaluate(REAL const uv[2], REAL const patchPoints[], PointDescriptor const │ │ │ │ │ +&pointDesc, REAL P[]) const │ │ │ │ │ +Evaluation of position. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_3_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ +int GetFaceSize() const │ │ │ │ │ +Return the size of the face. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_0_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_I_s_R_e_g_u_l_a_r │ │ │ │ │ +bool IsRegular() const │ │ │ │ │ +Return if the Surface is a single regular patch. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_1_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_B_o_u_n_d_C_o_n_t_r_o_l_P_o_i_n_t_s │ │ │ │ │ +void BoundControlPoints(REAL const controlPoints[], PointDescriptor const │ │ │ │ │ +&controlPointDesc, REAL minExtent[], REAL maxExtent[]) const │ │ │ │ │ +Compute bounds of control points from a local array. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_C_o_n_t_r_o_l_P_o_i_n_t_I_n_d_i_c_e_s │ │ │ │ │ +int GetControlPointIndices(Index meshPointIndices[]) const │ │ │ │ │ +Identify indices of control points in the mesh. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_I_n_d_e_x │ │ │ │ │ +int Index │ │ │ │ │ +Integer type representing a mesh index. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_A_p_p_l_y_S_t_e_n_c_i_l │ │ │ │ │ +void ApplyStencil(REAL const stencil[], REAL const controlPoints[], │ │ │ │ │ +PointDescriptor const &, REAL result[]) const │ │ │ │ │ +Apply a single stencil to control points from a local array. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ +Parameterization GetParameterization() const │ │ │ │ │ +Return the Parameterization. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_0_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_S_u_r_f_a_c_e │ │ │ │ │ +Surface() │ │ │ │ │ +Default construction produces an invalid instance. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_A_p_p_l_y_S_t_e_n_c_i_l_F_r_o_m_M_e_s_h │ │ │ │ │ +void ApplyStencilFromMesh(REAL const stencil[], REAL const meshPoints[], │ │ │ │ │ +PointDescriptor const &, REAL result[]) const │ │ │ │ │ +Apply a single stencil to control points from the mesh data. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_o_p_e_r_a_t_o_r_= │ │ │ │ │ +Surface & operator=(Surface const &src)=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_B_o_u_n_d_C_o_n_t_r_o_l_P_o_i_n_t_s_F_r_o_m_M_e_s_h │ │ │ │ │ +void BoundControlPointsFromMesh(REAL const meshPoints[], PointDescriptor const │ │ │ │ │ +&meshPointDesc, REAL minExtent[], REAL maxExtent[]) const │ │ │ │ │ +Compute bounds of control points from the mesh data. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_~_S_u_r_f_a_c_e │ │ │ │ │ +~Surface()=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_C_l_e_a_r │ │ │ │ │ +void Clear() │ │ │ │ │ +Clear a previously initialized Surface. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_8_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_S_u_r_f_a_c_e │ │ │ │ │ +Surface(Surface const &src)=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_r_e_p_a_r_e_P_a_t_c_h_P_o_i_n_t_s │ │ │ │ │ +void PreparePatchPoints(REAL const meshPoints[], PointDescriptor const │ │ │ │ │ +&meshPointDesc, REAL patchPoints[], PointDescriptor const &patchPointDesc) │ │ │ │ │ +const │ │ │ │ │ +Prepare patch points in a local array for evaluation. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_3_4_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_I_s_V_a_l_i_d │ │ │ │ │ +bool IsValid() const │ │ │ │ │ +Return true if successfully initialized. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_a_t_h_e_r_C_o_n_t_r_o_l_P_o_i_n_t_s │ │ │ │ │ +void GatherControlPoints(REAL_MESH const meshPoints[], PointDescriptor const │ │ │ │ │ +&meshPointDesc, REAL controlPoints[], PointDescriptor const &controlPointDesc) │ │ │ │ │ +const │ │ │ │ │ +Gather control points in a local array. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_C_o_m_p_u_t_e_P_a_t_c_h_P_o_i_n_t_s │ │ │ │ │ +void ComputePatchPoints(REAL patchPoints[], PointDescriptor const │ │ │ │ │ +&patchPointDesc) const │ │ │ │ │ +Compute all patch points following the control points. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_3_3_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_I_s_L_i_n_e_a_r │ │ │ │ │ +bool IsLinear() const │ │ │ │ │ +Return if the Surface is linear. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_1_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_N_u_m_P_a_t_c_h_P_o_i_n_t_s │ │ │ │ │ +int GetNumPatchPoints() const │ │ │ │ │ +Return the number of patch points representing the Surface. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_E_v_a_l_u_a_t_e_S_t_e_n_c_i_l │ │ │ │ │ +int EvaluateStencil(REAL const uv[2], REAL sP[]) const │ │ │ │ │ +Evaluation of the limit stencil for position. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_4_1_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +Simple struct defining the size and stride of points in arrays. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_s_t_r_i_d_e │ │ │ │ │ +int stride │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_s_i_z_e │ │ │ │ │ +int size │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +PointDescriptor(int n) │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +PointDescriptor(int n, int m) │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +PointDescriptor() │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_4 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ Base class providing initialization of a Surface for each face of a mesh. │ │ │ │ │ DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_0_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_:_s_e_t_I_n_t_e_r_n_a_l_C_a_c_h_e │ │ │ │ │ -void setInternalCache(SurfaceFactoryCache *cache) │ │ │ │ │ -Subclass to identify an internal cache for use by base class. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s │ │ │ │ │ -Simple set of options assigned to instances of SurfaceFactory. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_1_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s │ │ │ │ │ -virtual int getFaceVertexIncidentFaceFVarValueIndices(Index faceIndex, int │ │ │ │ │ -faceVertex, FVarID fvarID, Index fvarValueIndices[]) const =0 │ │ │ │ │ -Gather face-varying indices of incident faces around a face-vertex. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ -virtual int getFaceVertexIncidentFaceVertexIndices(Index faceIndex, int │ │ │ │ │ -faceVertex, Index vertexIndices[]) const =0 │ │ │ │ │ -Gather vertex indices of incident faces around a face-vertex. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_g_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ -virtual int getFaceSize(Index faceIndex) const =0 │ │ │ │ │ -Returns the size of a face (number of vertices) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_I_n_d_e_x │ │ │ │ │ -int Index │ │ │ │ │ -Integer type representing a mesh index. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_p_o_p_u_l_a_t_e_F_a_c_e_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -virtual int populateFaceVertexDescriptor(Index faceIndex, int faceVertex, │ │ │ │ │ -VertexDescriptor *vertexDescriptor) const =0 │ │ │ │ │ -Describe the topology of incident faces around a face-vertex. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r │ │ │ │ │ -virtual bool getFaceNeighborhoodVertexIndicesIfRegular(Index faceIndex, Index │ │ │ │ │ -vertexIndices[]) const │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_2_1_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r │ │ │ │ │ -virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular(Index faceIndex, │ │ │ │ │ -FVarID fvarID, Index fvarValueIndices[]) const │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_2_2_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s │ │ │ │ │ -virtual int getFaceFVarValueIndices(Index faceIndex, FVarID fvarID, Index │ │ │ │ │ -fvarValueIndices[]) const =0 │ │ │ │ │ -Gather the face-varying indices of the face's vertices. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ -_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ -virtual int getFaceVertexIndices(Index faceIndex, Index vertexIndices[]) const │ │ │ │ │ -=0 │ │ │ │ │ -Gather the indices of the face's vertices. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_i_s_F_a_c_e_H_o_l_e │ │ │ │ │ -virtual bool isFaceHole(Index faceIndex) const =0 │ │ │ │ │ -Returns if a face is a hole. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_F_V_a_r_I_D │ │ │ │ │ -std::intptr_t FVarID │ │ │ │ │ -Type used to identify and specify face-varying primvars. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_8_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -Simple class used by subclasses of SurfaceFactory to describe a vertex. │ │ │ │ │ -DDeeffiinniittiioonn _v_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r_._h_:_1_3_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ -Stores topology data for a specified set of refinement options. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y │ │ │ │ │ +DDeeffiinniittiioonn _a_r_r_a_y_._h_:_5_3 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h │ │ │ │ │ + * _s_u_r_f_a_c_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00692.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/surface.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/bfr/refinerSurfaceFactory.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,46 +90,47 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
surface.h File Reference
│ │ │ │ +
refinerSurfaceFactory.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../bfr/surfaceData.h"
│ │ │ │ -#include "../bfr/parameterization.h"
│ │ │ │ -#include "../vtr/array.h"
│ │ │ │ +#include "../bfr/surfaceFactory.h"
│ │ │ │ +#include "../bfr/surfaceFactoryCache.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  Surface< REAL >
 Encapsulates the limit surface for a face of a mesh. More...
class  RefinerSurfaceFactoryBase
 Intermediate subclass of SurfaceFactory with Far::TopologyRefiner as the mesh. More...
 
struct  Surface< REAL >::PointDescriptor
 Simple struct defining the size and stride of points in arrays. More...
class  RefinerSurfaceFactory< CACHE_TYPE >
 Template for concrete subclasses of RefinerSurfaceFactoryBase. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Bfr
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,30 +1,31 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -surface.h File Reference │ │ │ │ │ +refinerSurfaceFactory.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "../bfr/surfaceData.h" │ │ │ │ │ -#include "_._._/_b_f_r_/_p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_a_r_r_a_y_._h" │ │ │ │ │ +#include "_._._/_b_f_r_/_s_u_r_f_a_c_e_F_a_c_t_o_r_y_._h" │ │ │ │ │ +#include "_._._/_b_f_r_/_s_u_r_f_a_c_e_F_a_c_t_o_r_y_C_a_c_h_e_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ - class   _S_u_r_f_a_c_e_<_ _R_E_A_L_ _> │ │ │ │ │ -  Encapsulates the limit surface for a face of a mesh. _M_o_r_e_._._. │ │ │ │ │ +class   _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ +  Intermediate subclass of _S_u_r_f_a_c_e_F_a_c_t_o_r_y with _F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r as │ │ │ │ │ + the mesh. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -struct   _S_u_r_f_a_c_e_<_ _R_E_A_L_ _>_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -  Simple struct defining the size and stride of points in arrays. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ +class   _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_<_ _C_A_C_H_E___T_Y_P_E_ _> │ │ │ │ │ +  Template for concrete subclasses of _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │ +  │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _s_u_r_f_a_c_e_._h │ │ │ │ │ + * _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00692.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,4 @@ │ │ │ │ │ var a00692 = [ │ │ │ │ │ - ["Surface< REAL >", "a00933.html", "a00933"], │ │ │ │ │ - ["PointDescriptor", "a00937.html", "a00937"] │ │ │ │ │ + ["RefinerSurfaceFactoryBase", "a00925.html", "a00925"], │ │ │ │ │ + ["RefinerSurfaceFactory< CACHE_TYPE >", "a00929.html", "a00929"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00692_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/surface.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/bfr/refinerSurfaceFactory.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
surface.h
│ │ │ │ +
refinerSurfaceFactory.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2021 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,358 +119,163 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_BFR_SURFACE_H
│ │ │ │ -
26#define OPENSUBDIV3_BFR_SURFACE_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H
│ │ │ │ +
26#define OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │
29
│ │ │ │ -
30#include "../bfr/surfaceData.h"
│ │ │ │ -
31#include "../bfr/parameterization.h"
│ │ │ │ -
32#include "../vtr/array.h"
│ │ │ │ -
33
│ │ │ │ -
34namespace OpenSubdiv {
│ │ │ │ -
35namespace OPENSUBDIV_VERSION {
│ │ │ │ -
36
│ │ │ │ -
37namespace Bfr {
│ │ │ │ -
38
│ │ │ │ -
58template <typename REAL>
│ │ │ │ -
│ │ │ │ -
59class Surface {
│ │ │ │ -
60public:
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ -
65 PointDescriptor(int n) : size(n), stride(n) { }
│ │ │ │ -
66 PointDescriptor(int n, int m) : size(n), stride(m) { }
│ │ │ │ -
67
│ │ │ │ - │ │ │ │ -
69 };
│ │ │ │ -
│ │ │ │ -
70
│ │ │ │ -
72 typedef int Index;
│ │ │ │ +
30#include "../bfr/surfaceFactory.h"
│ │ │ │ +
31#include "../bfr/surfaceFactoryCache.h"
│ │ │ │ +
32
│ │ │ │ +
33namespace OpenSubdiv {
│ │ │ │ +
34namespace OPENSUBDIV_VERSION {
│ │ │ │ +
35
│ │ │ │ +
│ │ │ │ +
36namespace Far {
│ │ │ │ +
37 class TopologyRefiner;
│ │ │ │ +
38}
│ │ │ │ +
│ │ │ │ +
39
│ │ │ │ +
40namespace Bfr {
│ │ │ │ +
41
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
59public:
│ │ │ │ +
61
│ │ │ │ +
65
│ │ │ │ + │ │ │ │ +
67 Options const & options);
│ │ │ │ +
68
│ │ │ │ +
69 ~RefinerSurfaceFactoryBase() override = default;
│ │ │ │ +
71
│ │ │ │
73
│ │ │ │ -
74public:
│ │ │ │ -
76
│ │ │ │ -
84
│ │ │ │ -
86 bool IsValid() const { return _data.isValid(); }
│ │ │ │ +
77
│ │ │ │ +
79 Far::TopologyRefiner const & GetMesh() const { return _mesh; }
│ │ │ │ +
80
│ │ │ │ +
82 int GetNumFaces() const { return _numFaces; }
│ │ │ │ +
83
│ │ │ │ +
85 int GetNumFVarChannels() const { return _numFVarChannels; }
│ │ │ │
87
│ │ │ │ -
89 void Clear() { _data.reinitialize(); }
│ │ │ │ -
90
│ │ │ │ - │ │ │ │ -
93
│ │ │ │ -
94 Surface(Surface const & src) = default;
│ │ │ │ -
95 Surface& operator=(Surface const & src) = default;
│ │ │ │ -
96 ~Surface() = default;
│ │ │ │ -
98
│ │ │ │ +
88protected:
│ │ │ │ +
90 //
│ │ │ │ +
91 // Virtual overrides to satisfy the SurfaceFactoryMeshAdapter interface:
│ │ │ │ +
92 //
│ │ │ │ +
93 bool isFaceHole( Index faceIndex) const override;
│ │ │ │ +
94 int getFaceSize(Index faceIndex) const override;
│ │ │ │ +
95
│ │ │ │ +
96 int getFaceVertexIndices(Index faceIndex,
│ │ │ │ +
97 Index vertexIndices[]) const override;
│ │ │ │ +
98 int getFaceFVarValueIndices(Index faceIndex,
│ │ │ │ +
99 FVarID fvarID, Index fvarValueIndices[]) const override;
│ │ │ │
100
│ │ │ │ -
104
│ │ │ │ -
106 Parameterization GetParameterization() const { return _data.getParam(); }
│ │ │ │ -
107
│ │ │ │ -
109 int GetFaceSize() const { return GetParameterization().GetFaceSize(); }
│ │ │ │ +
101 int populateFaceVertexDescriptor(Index faceIndex, int faceVertex,
│ │ │ │ +
102 VertexDescriptor * vertexDescriptor) const override;
│ │ │ │ +
103
│ │ │ │ + │ │ │ │ +
105 Index faceIndex, int faceVertex,
│ │ │ │ +
106 Index vertexIndices[]) const override;
│ │ │ │ + │ │ │ │ +
108 Index faceIndex, int faceVertex,
│ │ │ │ +
109 FVarID fvarID, Index fvarValueIndices[]) const override;
│ │ │ │
110
│ │ │ │ -
112 bool IsRegular() const { return _data.isRegular(); }
│ │ │ │ -
113
│ │ │ │ -
115 bool IsLinear() const { return _data.isLinear(); }
│ │ │ │ -
117
│ │ │ │ -
119
│ │ │ │ -
135
│ │ │ │ -
137 int GetNumControlPoints() const { return _data.getNumCVs(); }
│ │ │ │ -
138
│ │ │ │ -
140 int GetControlPointIndices(Index meshPointIndices[]) const;
│ │ │ │ +
111 // Optional SurfaceFactoryMeshAdapter overrides for regular patches:
│ │ │ │ + │ │ │ │ +
113 Index faceIndex,
│ │ │ │ +
114 Index vertexIndices[]) const override;
│ │ │ │ +
115
│ │ │ │ + │ │ │ │ +
117 Index faceIndex,
│ │ │ │ +
118 FVarID fvarID, Index fvarValueIndices[]) const override;
│ │ │ │ +
120
│ │ │ │ +
121private:
│ │ │ │ +
122 //
│ │ │ │ +
123 // Internal supporting methods:
│ │ │ │ +
124 //
│ │ │ │ +
125 int getFaceVaryingChannel(FVarID fvarID) const;
│ │ │ │ +
126
│ │ │ │ +
127 int getFaceVertexPointIndices(Index faceIndex, int faceVertex,
│ │ │ │ +
128 Index indices[], int vtxOrFVarChannel) const;
│ │ │ │ +
129
│ │ │ │ +
130 int getFacePatchPointIndices(Index faceIndex,
│ │ │ │ +
131 Index indices[], int vtxOrFVarChannel) const;
│ │ │ │ +
132
│ │ │ │ +
133private:
│ │ │ │ +
134 // Additional members for the subclass:
│ │ │ │ +
135 Far::TopologyRefiner const & _mesh;
│ │ │ │ +
136
│ │ │ │ +
137 int _numFaces;
│ │ │ │ +
138 int _numFVarChannels;
│ │ │ │ +
139};
│ │ │ │ +
│ │ │ │ +
140
│ │ │ │
141
│ │ │ │ -
151 template <typename REAL_MESH>
│ │ │ │ -
152 void GatherControlPoints(REAL_MESH const meshPoints[],
│ │ │ │ -
153 PointDescriptor const & meshPointDesc,
│ │ │ │ -
154 REAL controlPoints[],
│ │ │ │ -
155 PointDescriptor const & controlPointDesc) const;
│ │ │ │ -
156
│ │ │ │ -
158 void BoundControlPoints(REAL const controlPoints[],
│ │ │ │ -
159 PointDescriptor const & controlPointDesc,
│ │ │ │ -
160 REAL minExtent[],
│ │ │ │ -
161 REAL maxExtent[]) const;
│ │ │ │ -
162
│ │ │ │ -
164 void BoundControlPointsFromMesh(REAL const meshPoints[],
│ │ │ │ -
165 PointDescriptor const & meshPointDesc,
│ │ │ │ -
166 REAL minExtent[],
│ │ │ │ -
167 REAL maxExtent[]) const;
│ │ │ │ -
169
│ │ │ │ +
142//
│ │ │ │ +
156template <class CACHE_TYPE = SurfaceFactoryCache>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
158public:
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
160 Options const & options = Options()) :
│ │ │ │ +
161 RefinerSurfaceFactoryBase(mesh, options),
│ │ │ │ +
162 _localCache() {
│ │ │ │ +
163
│ │ │ │ + │ │ │ │ +
165 }
│ │ │ │ +
│ │ │ │ +
166 ~RefinerSurfaceFactory() override = default;
│ │ │ │ +
167
│ │ │ │ +
168private:
│ │ │ │ +
169 CACHE_TYPE _localCache;
│ │ │ │ +
170};
│ │ │ │ +
│ │ │ │
171
│ │ │ │ -
177
│ │ │ │ -
179 int GetNumPatchPoints() const;
│ │ │ │ -
180
│ │ │ │ -
199 void PreparePatchPoints(REAL const meshPoints[],
│ │ │ │ -
200 PointDescriptor const & meshPointDesc,
│ │ │ │ -
201 REAL patchPoints[],
│ │ │ │ -
202 PointDescriptor const & patchPointDesc) const;
│ │ │ │ -
203
│ │ │ │ -
213 void ComputePatchPoints(REAL patchPoints[],
│ │ │ │ -
214 PointDescriptor const & patchPointDesc) const;
│ │ │ │ -
216
│ │ │ │ -
218
│ │ │ │ -
225
│ │ │ │ -
227 void Evaluate(REAL const uv[2],
│ │ │ │ -
228 REAL const patchPoints[], PointDescriptor const & pointDesc,
│ │ │ │ -
229 REAL P[]) const;
│ │ │ │ -
230
│ │ │ │ -
232 void Evaluate(REAL const uv[2],
│ │ │ │ -
233 REAL const patchPoints[], PointDescriptor const & pointDesc,
│ │ │ │ -
234 REAL P[], REAL Du[], REAL Dv[]) const;
│ │ │ │ -
235
│ │ │ │ -
237 void Evaluate(REAL const uv[2],
│ │ │ │ -
238 REAL const patchPoints[], PointDescriptor const & pointDesc,
│ │ │ │ -
239 REAL P[], REAL Du[], REAL Dv[],
│ │ │ │ -
240 REAL Duu[], REAL Duv[], REAL Dvv[]) const;
│ │ │ │ -
242
│ │ │ │ -
244
│ │ │ │ -
256
│ │ │ │ -
258 int EvaluateStencil(REAL const uv[2], REAL sP[]) const;
│ │ │ │ -
259
│ │ │ │ -
261 int EvaluateStencil(REAL const uv[2], REAL sP[],
│ │ │ │ -
262 REAL sDu[], REAL sDv[]) const;
│ │ │ │ -
263
│ │ │ │ -
265 int EvaluateStencil(REAL const uv[2], REAL sP[],
│ │ │ │ -
266 REAL sDu[], REAL sDv[],
│ │ │ │ -
267 REAL sDuu[], REAL sDuv[], REAL sDvv[]) const;
│ │ │ │ -
268
│ │ │ │ -
270 void ApplyStencil(REAL const stencil[],
│ │ │ │ -
271 REAL const controlPoints[], PointDescriptor const &,
│ │ │ │ -
272 REAL result[]) const;
│ │ │ │ -
273
│ │ │ │ -
275 void ApplyStencilFromMesh(REAL const stencil[],
│ │ │ │ -
276 REAL const meshPoints[], PointDescriptor const &,
│ │ │ │ -
277 REAL result[]) const;
│ │ │ │ -
279
│ │ │ │ -
280private:
│ │ │ │ -
281 // Internal methods for evaluating derivatives, basis weights and
│ │ │ │ -
282 // stencils for regular, irregular and irregular linear patches:
│ │ │ │ - │ │ │ │ -
284
│ │ │ │ -
285 void evaluateDerivs(REAL const uv[2], REAL const patchPoints[],
│ │ │ │ -
286 PointDescriptor const &, REAL * derivs[]) const;
│ │ │ │ -
287 void evalRegularDerivs(REAL const uv[2], REAL const patchPoints[],
│ │ │ │ -
288 PointDescriptor const &, REAL * derivs[]) const;
│ │ │ │ -
289 void evalIrregularDerivs(REAL const uv[2], REAL const patchPoints[],
│ │ │ │ -
290 PointDescriptor const &, REAL * derivs[]) const;
│ │ │ │ -
291 void evalMultiLinearDerivs(REAL const uv[2], REAL const patchPoints[],
│ │ │ │ -
292 PointDescriptor const &, REAL * derivs[]) const;
│ │ │ │ -
293
│ │ │ │ -
294 void evalRegularBasis(REAL const uv[2], REAL * wDeriv[]) const;
│ │ │ │ -
295 IndexArray evalIrregularBasis(REAL const uv[2], REAL * wDeriv[]) const;
│ │ │ │ -
296 int evalMultiLinearBasis(REAL const uv[2], REAL * wDeriv[]) const;
│ │ │ │ -
297
│ │ │ │ -
298 int evaluateStencils(REAL const uv[2], REAL * sDeriv[]) const;
│ │ │ │ -
299 int evalRegularStencils(REAL const uv[2], REAL * sDeriv[]) const;
│ │ │ │ -
300 int evalIrregularStencils(REAL const uv[2], REAL * sDeriv[]) const;
│ │ │ │ -
301 int evalMultiLinearStencils(REAL const uv[2], REAL * sDeriv[]) const;
│ │ │ │ -
302
│ │ │ │ -
303 // Internal methods to compute patch points:
│ │ │ │ -
304 void computeLinearPatchPoints(REAL p[], PointDescriptor const &) const;
│ │ │ │ -
305 void computeIrregularPatchPoints(REAL p[], PointDescriptor const &) const;
│ │ │ │ -
306
│ │ │ │ -
307 // Internal methods specific to regular or irregular patches:
│ │ │ │ -
308 unsigned char getRegPatchType() const { return _data.getRegPatchType(); }
│ │ │ │ -
309 unsigned char getRegPatchMask() const { return _data.getRegPatchMask(); }
│ │ │ │ -
310
│ │ │ │ -
311 internal::IrregularPatchType const & getIrregPatch() const;
│ │ │ │ -
312
│ │ │ │ -
313private:
│ │ │ │ -
314 // Access to the set of member variables - provided to the Factory:
│ │ │ │ -
315 friend class SurfaceFactory;
│ │ │ │ -
316
│ │ │ │ -
317 internal::SurfaceData & getSurfaceData() { return _data; }
│ │ │ │ -
318 internal::SurfaceData const & getSurfaceData() const { return _data; }
│ │ │ │ -
319
│ │ │ │ -
320private:
│ │ │ │ -
321 // All member variables encapsulated in a single class:
│ │ │ │ -
322 internal::SurfaceData _data;
│ │ │ │ -
323};
│ │ │ │ -
│ │ │ │ -
324
│ │ │ │ -
325
│ │ │ │ -
326//
│ │ │ │ -
327// Simple inline methods composed of other methods:
│ │ │ │ -
328//
│ │ │ │ -
329template <typename REAL>
│ │ │ │ -
330inline void
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
332 PointDescriptor const & pointDesc) const {
│ │ │ │ -
333
│ │ │ │ -
334 if (!IsRegular()) {
│ │ │ │ -
335 if (IsLinear()) {
│ │ │ │ -
336 computeLinearPatchPoints(points, pointDesc);
│ │ │ │ -
337 } else {
│ │ │ │ -
338 computeIrregularPatchPoints(points, pointDesc);
│ │ │ │ -
339 }
│ │ │ │ -
340 }
│ │ │ │ -
341}
│ │ │ │ -
│ │ │ │ -
342
│ │ │ │ -
343template <typename REAL>
│ │ │ │ -
344inline void
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
346 REAL const meshPoints[], PointDescriptor const & meshPointDesc,
│ │ │ │ -
347 REAL patchPoints[], PointDescriptor const & patchPointDesc) const {
│ │ │ │ -
348
│ │ │ │ -
349 GatherControlPoints(meshPoints, meshPointDesc, patchPoints, patchPointDesc);
│ │ │ │ -
350 ComputePatchPoints(patchPoints, patchPointDesc);
│ │ │ │ -
351}
│ │ │ │ -
│ │ │ │ -
352
│ │ │ │ -
353//
│ │ │ │ -
354// Inline invocations of more general methods for derivative overloads:
│ │ │ │ -
355//
│ │ │ │ -
356template <typename REAL>
│ │ │ │ -
357inline void
│ │ │ │ -
358Surface<REAL>::evaluateDerivs(REAL const uv[2],
│ │ │ │ -
359 REAL const patchPoints[],
│ │ │ │ -
360 PointDescriptor const & pointDesc,
│ │ │ │ -
361 REAL * derivatives[]) const {
│ │ │ │ -
362 if (IsRegular()) {
│ │ │ │ -
363 evalRegularDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ -
364 } else if (IsLinear()) {
│ │ │ │ -
365 evalMultiLinearDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ -
366 } else {
│ │ │ │ -
367 evalIrregularDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ -
368 }
│ │ │ │ -
369}
│ │ │ │ -
370template <typename REAL>
│ │ │ │ -
371inline void
│ │ │ │ -
│ │ │ │ -
372Surface<REAL>::Evaluate(REAL const uv[2],
│ │ │ │ -
373 REAL const patchPoints[],
│ │ │ │ -
374 PointDescriptor const & pointDesc,
│ │ │ │ -
375 REAL P[]) const {
│ │ │ │ -
376
│ │ │ │ -
377 REAL * derivatives[6] = { P, 0, 0, 0, 0, 0 };
│ │ │ │ -
378 evaluateDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ -
379}
│ │ │ │ -
│ │ │ │ -
380template <typename REAL>
│ │ │ │ -
381inline void
│ │ │ │ -
│ │ │ │ -
382Surface<REAL>::Evaluate(REAL const uv[2],
│ │ │ │ -
383 REAL const patchPoints[],
│ │ │ │ -
384 PointDescriptor const & pointDesc,
│ │ │ │ -
385 REAL P[], REAL Du[], REAL Dv[]) const {
│ │ │ │ -
386
│ │ │ │ -
387 REAL * derivatives[6] = { P, Du, Dv, 0, 0, 0 };
│ │ │ │ -
388 evaluateDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ -
389}
│ │ │ │ -
│ │ │ │ -
390template <typename REAL>
│ │ │ │ -
391inline void
│ │ │ │ -
│ │ │ │ -
392Surface<REAL>::Evaluate(REAL const uv[2],
│ │ │ │ -
393 REAL const patchPoints[],
│ │ │ │ -
394 PointDescriptor const & pointDesc,
│ │ │ │ -
395 REAL P[], REAL Du[], REAL Dv[],
│ │ │ │ -
396 REAL Duu[], REAL Duv[], REAL Dvv[]) const {
│ │ │ │ -
397
│ │ │ │ -
398 REAL * derivatives[6] = { P, Du, Dv, Duu, Duv, Dvv };
│ │ │ │ -
399 evaluateDerivs(uv, patchPoints, pointDesc, derivatives);
│ │ │ │ -
400}
│ │ │ │ -
│ │ │ │ -
401
│ │ │ │ -
402template <typename REAL>
│ │ │ │ -
403inline int
│ │ │ │ -
404Surface<REAL>::evaluateStencils(REAL const uv[2], REAL * sDeriv[]) const {
│ │ │ │ -
405
│ │ │ │ -
406 if (IsRegular()) {
│ │ │ │ -
407 return evalRegularStencils(uv, sDeriv);
│ │ │ │ -
408 } else if (IsLinear()) {
│ │ │ │ -
409 return evalMultiLinearStencils(uv, sDeriv);
│ │ │ │ -
410 } else {
│ │ │ │ -
411 return evalIrregularStencils(uv, sDeriv);
│ │ │ │ -
412 }
│ │ │ │ -
413}
│ │ │ │ -
414template <typename REAL>
│ │ │ │ -
415inline int
│ │ │ │ -
│ │ │ │ -
416Surface<REAL>::EvaluateStencil(REAL const uv[2], REAL sP[]) const {
│ │ │ │ -
417
│ │ │ │ -
418 REAL * derivativeStencils[6] = { sP, 0, 0, 0, 0, 0 };
│ │ │ │ -
419 return evaluateStencils(uv, derivativeStencils);
│ │ │ │ -
420}
│ │ │ │ -
│ │ │ │ -
421template <typename REAL>
│ │ │ │ -
422inline int
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
424 REAL sP[], REAL sDu[], REAL sDv[]) const {
│ │ │ │ -
425
│ │ │ │ -
426 REAL * derivativeStencils[6] = { sP, sDu, sDv, 0, 0, 0 };
│ │ │ │ -
427 return evaluateStencils(uv, derivativeStencils);
│ │ │ │ -
428}
│ │ │ │ -
│ │ │ │ -
429template <typename REAL>
│ │ │ │ -
430inline int
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
432 REAL sP[], REAL sDu[], REAL sDv[],
│ │ │ │ -
433 REAL sDuu[], REAL sDuv[], REAL sDvv[]) const {
│ │ │ │ -
434
│ │ │ │ -
435 REAL * derivativeStencils[6] = { sP, sDu, sDv, sDuu, sDuv, sDvv };
│ │ │ │ -
436 return evaluateStencils(uv, derivativeStencils);
│ │ │ │ -
437}
│ │ │ │ -
│ │ │ │ -
438
│ │ │ │ -
439} // end namespace Bfr
│ │ │ │ -
440
│ │ │ │ -
441} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
442using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
443
│ │ │ │ -
444} // end namespace OpenSubdiv
│ │ │ │ -
445
│ │ │ │ -
446#endif /* OPENSUBDIV3_BFR_SURFACE */
│ │ │ │ - │ │ │ │ -
Simple class defining the 2D parameterization of a face.
│ │ │ │ -
int GetFaceSize() const
Returns the size (number of vertices) of the corresponding face.
│ │ │ │ -
Encapsulates the limit surface for a face of a mesh.
Definition surface.h:59
│ │ │ │ -
int GetNumControlPoints() const
Return the number of control points affecting the Surface.
Definition surface.h:137
│ │ │ │ -
void Evaluate(REAL const uv[2], REAL const patchPoints[], PointDescriptor const &pointDesc, REAL P[]) const
Evaluation of position.
Definition surface.h:372
│ │ │ │ -
int GetFaceSize() const
Return the size of the face.
Definition surface.h:109
│ │ │ │ -
bool IsRegular() const
Return if the Surface is a single regular patch.
Definition surface.h:112
│ │ │ │ -
void BoundControlPoints(REAL const controlPoints[], PointDescriptor const &controlPointDesc, REAL minExtent[], REAL maxExtent[]) const
Compute bounds of control points from a local array.
│ │ │ │ -
int GetControlPointIndices(Index meshPointIndices[]) const
Identify indices of control points in the mesh.
│ │ │ │ -
int Index
Integer type representing a mesh index.
Definition surface.h:72
│ │ │ │ -
void ApplyStencil(REAL const stencil[], REAL const controlPoints[], PointDescriptor const &, REAL result[]) const
Apply a single stencil to control points from a local array.
│ │ │ │ -
Parameterization GetParameterization() const
Return the Parameterization.
Definition surface.h:106
│ │ │ │ -
Surface()
Default construction produces an invalid instance.
│ │ │ │ -
void ApplyStencilFromMesh(REAL const stencil[], REAL const meshPoints[], PointDescriptor const &, REAL result[]) const
Apply a single stencil to control points from the mesh data.
│ │ │ │ -
Surface & operator=(Surface const &src)=default
│ │ │ │ -
void BoundControlPointsFromMesh(REAL const meshPoints[], PointDescriptor const &meshPointDesc, REAL minExtent[], REAL maxExtent[]) const
Compute bounds of control points from the mesh data.
│ │ │ │ - │ │ │ │ -
void Clear()
Clear a previously initialized Surface.
Definition surface.h:89
│ │ │ │ - │ │ │ │ -
void PreparePatchPoints(REAL const meshPoints[], PointDescriptor const &meshPointDesc, REAL patchPoints[], PointDescriptor const &patchPointDesc) const
Prepare patch points in a local array for evaluation.
Definition surface.h:345
│ │ │ │ -
bool IsValid() const
Return true if successfully initialized.
Definition surface.h:86
│ │ │ │ -
void GatherControlPoints(REAL_MESH const meshPoints[], PointDescriptor const &meshPointDesc, REAL controlPoints[], PointDescriptor const &controlPointDesc) const
Gather control points in a local array.
│ │ │ │ -
void ComputePatchPoints(REAL patchPoints[], PointDescriptor const &patchPointDesc) const
Compute all patch points following the control points.
Definition surface.h:331
│ │ │ │ -
bool IsLinear() const
Return if the Surface is linear.
Definition surface.h:115
│ │ │ │ -
int GetNumPatchPoints() const
Return the number of patch points representing the Surface.
│ │ │ │ -
int EvaluateStencil(REAL const uv[2], REAL sP[]) const
Evaluation of the limit stencil for position.
Definition surface.h:416
│ │ │ │ -
Simple struct defining the size and stride of points in arrays.
Definition surface.h:63
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ +
172} // end namespace Bfr
│ │ │ │ +
173
│ │ │ │ +
174} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
175using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
176
│ │ │ │ +
177} // end namespace OpenSubdiv
│ │ │ │ +
178
│ │ │ │ +
179#endif /* OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H */
│ │ │ │ + │ │ │ │ +
Intermediate subclass of SurfaceFactory with Far::TopologyRefiner as the mesh.
│ │ │ │ + │ │ │ │ +
int GetNumFVarChannels() const
Return the number of face-varying channels.
│ │ │ │ +
Far::TopologyRefiner const & GetMesh() const
Return the instance of the mesh.
│ │ │ │ + │ │ │ │ +
RefinerSurfaceFactoryBase(Far::TopologyRefiner const &mesh, Options const &options)
│ │ │ │ +
Template for concrete subclasses of RefinerSurfaceFactoryBase.
│ │ │ │ + │ │ │ │ +
RefinerSurfaceFactory(Far::TopologyRefiner const &mesh, Options const &options=Options())
│ │ │ │
Base class providing initialization of a Surface for each face of a mesh.
│ │ │ │ - │ │ │ │ +
void setInternalCache(SurfaceFactoryCache *cache)
Subclass to identify an internal cache for use by base class.
│ │ │ │ +
Simple set of options assigned to instances of SurfaceFactory.
│ │ │ │ +
virtual int getFaceVertexIncidentFaceFVarValueIndices(Index faceIndex, int faceVertex, FVarID fvarID, Index fvarValueIndices[]) const =0
Gather face-varying indices of incident faces around a face-vertex.
│ │ │ │ +
virtual int getFaceVertexIncidentFaceVertexIndices(Index faceIndex, int faceVertex, Index vertexIndices[]) const =0
Gather vertex indices of incident faces around a face-vertex.
│ │ │ │ +
virtual int getFaceSize(Index faceIndex) const =0
Returns the size of a face (number of vertices)
│ │ │ │ + │ │ │ │ +
virtual int populateFaceVertexDescriptor(Index faceIndex, int faceVertex, VertexDescriptor *vertexDescriptor) const =0
Describe the topology of incident faces around a face-vertex.
│ │ │ │ +
virtual bool getFaceNeighborhoodVertexIndicesIfRegular(Index faceIndex, Index vertexIndices[]) const
│ │ │ │ +
virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular(Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const
│ │ │ │ +
virtual int getFaceFVarValueIndices(Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const =0
Gather the face-varying indices of the face's vertices.
│ │ │ │ +
virtual int getFaceVertexIndices(Index faceIndex, Index vertexIndices[]) const =0
Gather the indices of the face's vertices.
│ │ │ │ +
virtual bool isFaceHole(Index faceIndex) const =0
Returns if a face is a hole.
│ │ │ │ +
std::intptr_t FVarID
Type used to identify and specify face-varying primvars.
│ │ │ │ +
Simple class used by subclasses of SurfaceFactory to describe a vertex.
│ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -surface.h │ │ │ │ │ +refinerSurfaceFactory.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2021 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,420 +24,222 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_BFR_SURFACE_H │ │ │ │ │ -26#define OPENSUBDIV3_BFR_SURFACE_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H │ │ │ │ │ +26#define OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ 29 │ │ │ │ │ -30#include "../bfr/surfaceData.h" │ │ │ │ │ -31#include "../bfr/parameterization.h" │ │ │ │ │ -32#include "../vtr/array.h" │ │ │ │ │ -33 │ │ │ │ │ -34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -35namespace OPENSUBDIV_VERSION { │ │ │ │ │ -36 │ │ │ │ │ -37namespace Bfr { │ │ │ │ │ -38 │ │ │ │ │ -58template │ │ │ │ │ -_5_9class _S_u_r_f_a_c_e { │ │ │ │ │ -60public: │ │ │ │ │ -_6_3 struct _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r { │ │ │ │ │ -_6_4 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r() : _s_i_z_e(0), _s_t_r_i_d_e(0) { } │ │ │ │ │ -_6_5 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r(int n) : _s_i_z_e(n), _s_t_r_i_d_e(n) { } │ │ │ │ │ -_6_6 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r(int n, int m) : _s_i_z_e(n), _s_t_r_i_d_e(m) { } │ │ │ │ │ -67 │ │ │ │ │ -_6_8 int _s_i_z_e, _s_t_r_i_d_e; │ │ │ │ │ -69 }; │ │ │ │ │ -70 │ │ │ │ │ -_7_2 typedef int _I_n_d_e_x; │ │ │ │ │ +30#include "../bfr/surfaceFactory.h" │ │ │ │ │ +31#include "../bfr/surfaceFactoryCache.h" │ │ │ │ │ +32 │ │ │ │ │ +33namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +34namespace OPENSUBDIV_VERSION { │ │ │ │ │ +35 │ │ │ │ │ +_3_6namespace Far { │ │ │ │ │ +37 class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r; │ │ │ │ │ +38} │ │ │ │ │ +39 │ │ │ │ │ +40namespace Bfr { │ │ │ │ │ +41 │ │ │ │ │ +_5_8class _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e : public _S_u_r_f_a_c_e_F_a_c_t_o_r_y { │ │ │ │ │ +59public: │ │ │ │ │ +61 │ │ │ │ │ +65 │ │ │ │ │ +_6_6 _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e(_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & mesh, │ │ │ │ │ +67 _O_p_t_i_o_n_s const & options); │ │ │ │ │ +68 │ │ │ │ │ +_6_9 _~_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e() override = default; │ │ │ │ │ +71 │ │ │ │ │ 73 │ │ │ │ │ -74public: │ │ │ │ │ -76 │ │ │ │ │ -84 │ │ │ │ │ -_8_6 bool _I_s_V_a_l_i_d() const { return _data.isValid(); } │ │ │ │ │ +77 │ │ │ │ │ +_7_9 _F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & _G_e_t_M_e_s_h() const { return _mesh; } │ │ │ │ │ +80 │ │ │ │ │ +_8_2 int _G_e_t_N_u_m_F_a_c_e_s() const { return _numFaces; } │ │ │ │ │ +83 │ │ │ │ │ +_8_5 int _G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const { return _numFVarChannels; } │ │ │ │ │ 87 │ │ │ │ │ -_8_9 void _C_l_e_a_r() { _data.reinitialize(); } │ │ │ │ │ -90 │ │ │ │ │ -_9_2 _S_u_r_f_a_c_e(); │ │ │ │ │ -93 │ │ │ │ │ -_9_4 _S_u_r_f_a_c_e(_S_u_r_f_a_c_e const & src) = default; │ │ │ │ │ -_9_5 _S_u_r_f_a_c_e& _o_p_e_r_a_t_o_r_=(_S_u_r_f_a_c_e const & src) = default; │ │ │ │ │ -_9_6 _~_S_u_r_f_a_c_e() = default; │ │ │ │ │ -98 │ │ │ │ │ +88protected: │ │ │ │ │ +90 // │ │ │ │ │ +91 // Virtual overrides to satisfy the SurfaceFactoryMeshAdapter interface: │ │ │ │ │ +92 // │ │ │ │ │ +93 bool _i_s_F_a_c_e_H_o_l_e( _I_n_d_e_x faceIndex) const override; │ │ │ │ │ +94 int _g_e_t_F_a_c_e_S_i_z_e(_I_n_d_e_x faceIndex) const override; │ │ │ │ │ +95 │ │ │ │ │ +96 int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s(_I_n_d_e_x faceIndex, │ │ │ │ │ +97 _I_n_d_e_x vertexIndices[]) const override; │ │ │ │ │ +98 int _g_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s(_I_n_d_e_x faceIndex, │ │ │ │ │ +99 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const override; │ │ │ │ │ 100 │ │ │ │ │ -104 │ │ │ │ │ -_1_0_6 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n _G_e_t_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n() const { return _data.getParam(); } │ │ │ │ │ -107 │ │ │ │ │ -_1_0_9 int _G_e_t_F_a_c_e_S_i_z_e() const { return _G_e_t_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n()._G_e_t_F_a_c_e_S_i_z_e(); } │ │ │ │ │ +101 int _p_o_p_u_l_a_t_e_F_a_c_e_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r(_I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ +102 _V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r * vertexDescriptor) const override; │ │ │ │ │ +103 │ │ │ │ │ +104 int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s( │ │ │ │ │ +105 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ +106 _I_n_d_e_x vertexIndices[]) const override; │ │ │ │ │ +107 int _g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s( │ │ │ │ │ +108 _I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ +109 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const override; │ │ │ │ │ 110 │ │ │ │ │ -_1_1_2 bool _I_s_R_e_g_u_l_a_r() const { return _data.isRegular(); } │ │ │ │ │ -113 │ │ │ │ │ -_1_1_5 bool _I_s_L_i_n_e_a_r() const { return _data.isLinear(); } │ │ │ │ │ -117 │ │ │ │ │ -119 │ │ │ │ │ -135 │ │ │ │ │ -_1_3_7 int _G_e_t_N_u_m_C_o_n_t_r_o_l_P_o_i_n_t_s() const { return _data.getNumCVs(); } │ │ │ │ │ -138 │ │ │ │ │ -_1_4_0 int _G_e_t_C_o_n_t_r_o_l_P_o_i_n_t_I_n_d_i_c_e_s(_I_n_d_e_x meshPointIndices[]) const; │ │ │ │ │ +111 // Optional SurfaceFactoryMeshAdapter overrides for regular patches: │ │ │ │ │ +112 bool _g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ +113 _I_n_d_e_x faceIndex, │ │ │ │ │ +114 _I_n_d_e_x vertexIndices[]) const override; │ │ │ │ │ +115 │ │ │ │ │ +116 bool _g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r( │ │ │ │ │ +117 _I_n_d_e_x faceIndex, │ │ │ │ │ +118 _F_V_a_r_I_D fvarID, _I_n_d_e_x fvarValueIndices[]) const override; │ │ │ │ │ +120 │ │ │ │ │ +121private: │ │ │ │ │ +122 // │ │ │ │ │ +123 // Internal supporting methods: │ │ │ │ │ +124 // │ │ │ │ │ +125 int getFaceVaryingChannel(_F_V_a_r_I_D fvarID) const; │ │ │ │ │ +126 │ │ │ │ │ +127 int getFaceVertexPointIndices(_I_n_d_e_x faceIndex, int faceVertex, │ │ │ │ │ +128 _I_n_d_e_x indices[], int vtxOrFVarChannel) const; │ │ │ │ │ +129 │ │ │ │ │ +130 int getFacePatchPointIndices(_I_n_d_e_x faceIndex, │ │ │ │ │ +131 _I_n_d_e_x indices[], int vtxOrFVarChannel) const; │ │ │ │ │ +132 │ │ │ │ │ +133private: │ │ │ │ │ +134 // Additional members for the subclass: │ │ │ │ │ +135 _F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & _mesh; │ │ │ │ │ +136 │ │ │ │ │ +137 int _numFaces; │ │ │ │ │ +138 int _numFVarChannels; │ │ │ │ │ +139}; │ │ │ │ │ +140 │ │ │ │ │ 141 │ │ │ │ │ -151 template │ │ │ │ │ -_1_5_2 void _G_a_t_h_e_r_C_o_n_t_r_o_l_P_o_i_n_t_s(REAL_MESH const meshPoints[], │ │ │ │ │ -153 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & meshPointDesc, │ │ │ │ │ -154 REAL controlPoints[], │ │ │ │ │ -155 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & controlPointDesc) const; │ │ │ │ │ -156 │ │ │ │ │ -_1_5_8 void _B_o_u_n_d_C_o_n_t_r_o_l_P_o_i_n_t_s(REAL const controlPoints[], │ │ │ │ │ -159 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & controlPointDesc, │ │ │ │ │ -160 REAL minExtent[], │ │ │ │ │ -161 REAL maxExtent[]) const; │ │ │ │ │ -162 │ │ │ │ │ -_1_6_4 void _B_o_u_n_d_C_o_n_t_r_o_l_P_o_i_n_t_s_F_r_o_m_M_e_s_h(REAL const meshPoints[], │ │ │ │ │ -165 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & meshPointDesc, │ │ │ │ │ -166 REAL minExtent[], │ │ │ │ │ -167 REAL maxExtent[]) const; │ │ │ │ │ -169 │ │ │ │ │ +142// │ │ │ │ │ +156template │ │ │ │ │ +_1_5_7class _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y : public _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e { │ │ │ │ │ +158public: │ │ │ │ │ +_1_5_9 _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y(_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & mesh, │ │ │ │ │ +160 _O_p_t_i_o_n_s const & options = _O_p_t_i_o_n_s()) : │ │ │ │ │ +161 _R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e(mesh, options), │ │ │ │ │ +162 _localCache() { │ │ │ │ │ +163 │ │ │ │ │ +164 _S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_:_s_e_t_I_n_t_e_r_n_a_l_C_a_c_h_e(&_localCache); │ │ │ │ │ +165 } │ │ │ │ │ +_1_6_6 _~_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y() override = default; │ │ │ │ │ +167 │ │ │ │ │ +168private: │ │ │ │ │ +169 CACHE_TYPE _localCache; │ │ │ │ │ +170}; │ │ │ │ │ 171 │ │ │ │ │ -177 │ │ │ │ │ -_1_7_9 int _G_e_t_N_u_m_P_a_t_c_h_P_o_i_n_t_s() const; │ │ │ │ │ -180 │ │ │ │ │ -199 void _P_r_e_p_a_r_e_P_a_t_c_h_P_o_i_n_t_s(REAL const meshPoints[], │ │ │ │ │ -200 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & meshPointDesc, │ │ │ │ │ -201 REAL patchPoints[], │ │ │ │ │ -202 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & patchPointDesc) const; │ │ │ │ │ -203 │ │ │ │ │ -213 void _C_o_m_p_u_t_e_P_a_t_c_h_P_o_i_n_t_s(REAL patchPoints[], │ │ │ │ │ -214 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & patchPointDesc) const; │ │ │ │ │ -216 │ │ │ │ │ -218 │ │ │ │ │ -225 │ │ │ │ │ -227 void _E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ -228 REAL const patchPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ -229 REAL P[]) const; │ │ │ │ │ -230 │ │ │ │ │ -232 void _E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ -233 REAL const patchPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ -234 REAL P[], REAL Du[], REAL Dv[]) const; │ │ │ │ │ -235 │ │ │ │ │ -237 void _E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ -238 REAL const patchPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ -239 REAL P[], REAL Du[], REAL Dv[], │ │ │ │ │ -240 REAL Duu[], REAL Duv[], REAL Dvv[]) const; │ │ │ │ │ -242 │ │ │ │ │ -244 │ │ │ │ │ -256 │ │ │ │ │ -258 int _E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], REAL sP[]) const; │ │ │ │ │ -259 │ │ │ │ │ -261 int _E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], REAL sP[], │ │ │ │ │ -262 REAL sDu[], REAL sDv[]) const; │ │ │ │ │ -263 │ │ │ │ │ -265 int _E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], REAL sP[], │ │ │ │ │ -266 REAL sDu[], REAL sDv[], │ │ │ │ │ -267 REAL sDuu[], REAL sDuv[], REAL sDvv[]) const; │ │ │ │ │ -268 │ │ │ │ │ -_2_7_0 void _A_p_p_l_y_S_t_e_n_c_i_l(REAL const stencil[], │ │ │ │ │ -271 REAL const controlPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, │ │ │ │ │ -272 REAL result[]) const; │ │ │ │ │ -273 │ │ │ │ │ -_2_7_5 void _A_p_p_l_y_S_t_e_n_c_i_l_F_r_o_m_M_e_s_h(REAL const stencil[], │ │ │ │ │ -276 REAL const meshPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, │ │ │ │ │ -277 REAL result[]) const; │ │ │ │ │ -279 │ │ │ │ │ -280private: │ │ │ │ │ -281 // Internal methods for evaluating derivatives, basis weights and │ │ │ │ │ -282 // stencils for regular, irregular and irregular linear patches: │ │ │ │ │ -283 typedef _V_t_r_:_:_C_o_n_s_t_A_r_r_a_y_<_i_n_t_> _I_n_d_e_x_A_r_r_a_y; │ │ │ │ │ -284 │ │ │ │ │ -285 void evaluateDerivs(REAL const uv[2], REAL const patchPoints[], │ │ │ │ │ -286 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, REAL * derivs[]) const; │ │ │ │ │ -287 void evalRegularDerivs(REAL const uv[2], REAL const patchPoints[], │ │ │ │ │ -288 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, REAL * derivs[]) const; │ │ │ │ │ -289 void evalIrregularDerivs(REAL const uv[2], REAL const patchPoints[], │ │ │ │ │ -290 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, REAL * derivs[]) const; │ │ │ │ │ -291 void evalMultiLinearDerivs(REAL const uv[2], REAL const patchPoints[], │ │ │ │ │ -292 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &, REAL * derivs[]) const; │ │ │ │ │ -293 │ │ │ │ │ -294 void evalRegularBasis(REAL const uv[2], REAL * wDeriv[]) const; │ │ │ │ │ -295 _I_n_d_e_x_A_r_r_a_y evalIrregularBasis(REAL const uv[2], REAL * wDeriv[]) const; │ │ │ │ │ -296 int evalMultiLinearBasis(REAL const uv[2], REAL * wDeriv[]) const; │ │ │ │ │ -297 │ │ │ │ │ -298 int evaluateStencils(REAL const uv[2], REAL * sDeriv[]) const; │ │ │ │ │ -299 int evalRegularStencils(REAL const uv[2], REAL * sDeriv[]) const; │ │ │ │ │ -300 int evalIrregularStencils(REAL const uv[2], REAL * sDeriv[]) const; │ │ │ │ │ -301 int evalMultiLinearStencils(REAL const uv[2], REAL * sDeriv[]) const; │ │ │ │ │ -302 │ │ │ │ │ -303 // Internal methods to compute patch points: │ │ │ │ │ -304 void computeLinearPatchPoints(REAL p[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &) const; │ │ │ │ │ -305 void computeIrregularPatchPoints(REAL p[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const &) const; │ │ │ │ │ -306 │ │ │ │ │ -307 // Internal methods specific to regular or irregular patches: │ │ │ │ │ -308 unsigned char getRegPatchType() const { return _data.getRegPatchType(); } │ │ │ │ │ -309 unsigned char getRegPatchMask() const { return _data.getRegPatchMask(); } │ │ │ │ │ -310 │ │ │ │ │ -311 internal::IrregularPatchType const & getIrregPatch() const; │ │ │ │ │ -312 │ │ │ │ │ -313private: │ │ │ │ │ -314 // Access to the set of member variables - provided to the Factory: │ │ │ │ │ -_3_1_5 friend class _S_u_r_f_a_c_e_F_a_c_t_o_r_y; │ │ │ │ │ -316 │ │ │ │ │ -317 internal::SurfaceData & getSurfaceData() { return _data; } │ │ │ │ │ -318 internal::SurfaceData const & getSurfaceData() const { return _data; } │ │ │ │ │ -319 │ │ │ │ │ -320private: │ │ │ │ │ -321 // All member variables encapsulated in a single class: │ │ │ │ │ -322 internal::SurfaceData _data; │ │ │ │ │ -323}; │ │ │ │ │ -324 │ │ │ │ │ -325 │ │ │ │ │ -326// │ │ │ │ │ -327// Simple inline methods composed of other methods: │ │ │ │ │ -328// │ │ │ │ │ -329template │ │ │ │ │ -330inline void │ │ │ │ │ -_3_3_1_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_C_o_m_p_u_t_e_P_a_t_c_h_P_o_i_n_t_s(REAL points[], │ │ │ │ │ -332 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc) const { │ │ │ │ │ -333 │ │ │ │ │ -334 if (!IsRegular()) { │ │ │ │ │ -335 if (IsLinear()) { │ │ │ │ │ -336 computeLinearPatchPoints(points, pointDesc); │ │ │ │ │ -337 } else { │ │ │ │ │ -338 computeIrregularPatchPoints(points, pointDesc); │ │ │ │ │ -339 } │ │ │ │ │ -340 } │ │ │ │ │ -341} │ │ │ │ │ -342 │ │ │ │ │ -343template │ │ │ │ │ -344inline void │ │ │ │ │ -_3_4_5_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_P_r_e_p_a_r_e_P_a_t_c_h_P_o_i_n_t_s( │ │ │ │ │ -346 REAL const meshPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & meshPointDesc, │ │ │ │ │ -347 REAL patchPoints[], _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & patchPointDesc) const { │ │ │ │ │ -348 │ │ │ │ │ -349 GatherControlPoints(meshPoints, meshPointDesc, patchPoints, │ │ │ │ │ -patchPointDesc); │ │ │ │ │ -350 ComputePatchPoints(patchPoints, patchPointDesc); │ │ │ │ │ -351} │ │ │ │ │ -352 │ │ │ │ │ -353// │ │ │ │ │ -354// Inline invocations of more general methods for derivative overloads: │ │ │ │ │ -355// │ │ │ │ │ -356template │ │ │ │ │ -357inline void │ │ │ │ │ -358_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_e_v_a_l_u_a_t_e_D_e_r_i_v_s(REAL const uv[2], │ │ │ │ │ -359 REAL const patchPoints[], │ │ │ │ │ -360 PointDescriptor const & pointDesc, │ │ │ │ │ -361 REAL * derivatives[]) const { │ │ │ │ │ -362 if (IsRegular()) { │ │ │ │ │ -363 evalRegularDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ -364 } else if (IsLinear()) { │ │ │ │ │ -365 evalMultiLinearDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ -366 } else { │ │ │ │ │ -367 evalIrregularDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ -368 } │ │ │ │ │ -369} │ │ │ │ │ -370template │ │ │ │ │ -371inline void │ │ │ │ │ -_3_7_2_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ -373 REAL const patchPoints[], │ │ │ │ │ -374 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ -375 REAL P[]) const { │ │ │ │ │ -376 │ │ │ │ │ -377 REAL * derivatives[6] = { P, 0, 0, 0, 0, 0 }; │ │ │ │ │ -378 evaluateDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ -379} │ │ │ │ │ -380template │ │ │ │ │ -381inline void │ │ │ │ │ -_3_8_2_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ -383 REAL const patchPoints[], │ │ │ │ │ -384 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ -385 REAL P[], REAL Du[], REAL Dv[]) const { │ │ │ │ │ -386 │ │ │ │ │ -387 REAL * derivatives[6] = { P, Du, Dv, 0, 0, 0 }; │ │ │ │ │ -388 evaluateDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ -389} │ │ │ │ │ -390template │ │ │ │ │ -391inline void │ │ │ │ │ -_3_9_2_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e(REAL const uv[2], │ │ │ │ │ -393 REAL const patchPoints[], │ │ │ │ │ -394 _P_o_i_n_t_D_e_s_c_r_i_p_t_o_r const & pointDesc, │ │ │ │ │ -395 REAL P[], REAL Du[], REAL Dv[], │ │ │ │ │ -396 REAL Duu[], REAL Duv[], REAL Dvv[]) const { │ │ │ │ │ -397 │ │ │ │ │ -398 REAL * derivatives[6] = { P, Du, Dv, Duu, Duv, Dvv }; │ │ │ │ │ -399 evaluateDerivs(uv, patchPoints, pointDesc, derivatives); │ │ │ │ │ -400} │ │ │ │ │ -401 │ │ │ │ │ -402template │ │ │ │ │ -403inline int │ │ │ │ │ -404_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_e_v_a_l_u_a_t_e_S_t_e_n_c_i_l_s(REAL const uv[2], REAL * sDeriv[]) const { │ │ │ │ │ -405 │ │ │ │ │ -406 if (IsRegular()) { │ │ │ │ │ -407 return evalRegularStencils(uv, sDeriv); │ │ │ │ │ -408 } else if (IsLinear()) { │ │ │ │ │ -409 return evalMultiLinearStencils(uv, sDeriv); │ │ │ │ │ -410 } else { │ │ │ │ │ -411 return evalIrregularStencils(uv, sDeriv); │ │ │ │ │ -412 } │ │ │ │ │ -413} │ │ │ │ │ -414template │ │ │ │ │ -415inline int │ │ │ │ │ -_4_1_6_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], REAL sP[]) const { │ │ │ │ │ -417 │ │ │ │ │ -418 REAL * derivativeStencils[6] = { sP, 0, 0, 0, 0, 0 }; │ │ │ │ │ -419 return evaluateStencils(uv, derivativeStencils); │ │ │ │ │ -420} │ │ │ │ │ -421template │ │ │ │ │ -422inline int │ │ │ │ │ -_4_2_3_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], │ │ │ │ │ -424 REAL sP[], REAL sDu[], REAL sDv[]) const { │ │ │ │ │ -425 │ │ │ │ │ -426 REAL * derivativeStencils[6] = { sP, sDu, sDv, 0, 0, 0 }; │ │ │ │ │ -427 return evaluateStencils(uv, derivativeStencils); │ │ │ │ │ -428} │ │ │ │ │ -429template │ │ │ │ │ -430inline int │ │ │ │ │ -_4_3_1_S_u_r_f_a_c_e_<_R_E_A_L_>_:_:_E_v_a_l_u_a_t_e_S_t_e_n_c_i_l(REAL const uv[2], │ │ │ │ │ -432 REAL sP[], REAL sDu[], REAL sDv[], │ │ │ │ │ -433 REAL sDuu[], REAL sDuv[], REAL sDvv[]) const { │ │ │ │ │ -434 │ │ │ │ │ -435 REAL * derivativeStencils[6] = { sP, sDu, sDv, sDuu, sDuv, sDvv }; │ │ │ │ │ -436 return evaluateStencils(uv, derivativeStencils); │ │ │ │ │ -437} │ │ │ │ │ -438 │ │ │ │ │ -439} // end namespace Bfr │ │ │ │ │ -440 │ │ │ │ │ -441} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -442using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -443 │ │ │ │ │ -444} // end namespace OpenSubdiv │ │ │ │ │ -445 │ │ │ │ │ -446#endif /* OPENSUBDIV3_BFR_SURFACE */ │ │ │ │ │ +172} // end namespace Bfr │ │ │ │ │ +173 │ │ │ │ │ +174} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +175using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +176 │ │ │ │ │ +177} // end namespace OpenSubdiv │ │ │ │ │ +178 │ │ │ │ │ +179#endif /* OPENSUBDIV3_BFR_REFINER_SURFACE_FACTORY_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ -Simple class defining the 2D parameterization of a face. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_5_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ -int GetFaceSize() const │ │ │ │ │ -Returns the size (number of vertices) of the corresponding face. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_1_0_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e │ │ │ │ │ -Encapsulates the limit surface for a face of a mesh. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_5_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_N_u_m_C_o_n_t_r_o_l_P_o_i_n_t_s │ │ │ │ │ -int GetNumControlPoints() const │ │ │ │ │ -Return the number of control points affecting the Surface. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_E_v_a_l_u_a_t_e │ │ │ │ │ -void Evaluate(REAL const uv[2], REAL const patchPoints[], PointDescriptor const │ │ │ │ │ -&pointDesc, REAL P[]) const │ │ │ │ │ -Evaluation of position. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_3_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ -int GetFaceSize() const │ │ │ │ │ -Return the size of the face. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_0_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_I_s_R_e_g_u_l_a_r │ │ │ │ │ -bool IsRegular() const │ │ │ │ │ -Return if the Surface is a single regular patch. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_1_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_B_o_u_n_d_C_o_n_t_r_o_l_P_o_i_n_t_s │ │ │ │ │ -void BoundControlPoints(REAL const controlPoints[], PointDescriptor const │ │ │ │ │ -&controlPointDesc, REAL minExtent[], REAL maxExtent[]) const │ │ │ │ │ -Compute bounds of control points from a local array. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_C_o_n_t_r_o_l_P_o_i_n_t_I_n_d_i_c_e_s │ │ │ │ │ -int GetControlPointIndices(Index meshPointIndices[]) const │ │ │ │ │ -Identify indices of control points in the mesh. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_I_n_d_e_x │ │ │ │ │ -int Index │ │ │ │ │ -Integer type representing a mesh index. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_A_p_p_l_y_S_t_e_n_c_i_l │ │ │ │ │ -void ApplyStencil(REAL const stencil[], REAL const controlPoints[], │ │ │ │ │ -PointDescriptor const &, REAL result[]) const │ │ │ │ │ -Apply a single stencil to control points from a local array. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ -Parameterization GetParameterization() const │ │ │ │ │ -Return the Parameterization. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_0_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_S_u_r_f_a_c_e │ │ │ │ │ -Surface() │ │ │ │ │ -Default construction produces an invalid instance. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_A_p_p_l_y_S_t_e_n_c_i_l_F_r_o_m_M_e_s_h │ │ │ │ │ -void ApplyStencilFromMesh(REAL const stencil[], REAL const meshPoints[], │ │ │ │ │ -PointDescriptor const &, REAL result[]) const │ │ │ │ │ -Apply a single stencil to control points from the mesh data. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_o_p_e_r_a_t_o_r_= │ │ │ │ │ -Surface & operator=(Surface const &src)=default │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_B_o_u_n_d_C_o_n_t_r_o_l_P_o_i_n_t_s_F_r_o_m_M_e_s_h │ │ │ │ │ -void BoundControlPointsFromMesh(REAL const meshPoints[], PointDescriptor const │ │ │ │ │ -&meshPointDesc, REAL minExtent[], REAL maxExtent[]) const │ │ │ │ │ -Compute bounds of control points from the mesh data. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_~_S_u_r_f_a_c_e │ │ │ │ │ -~Surface()=default │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_C_l_e_a_r │ │ │ │ │ -void Clear() │ │ │ │ │ -Clear a previously initialized Surface. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_8_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_S_u_r_f_a_c_e │ │ │ │ │ -Surface(Surface const &src)=default │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_r_e_p_a_r_e_P_a_t_c_h_P_o_i_n_t_s │ │ │ │ │ -void PreparePatchPoints(REAL const meshPoints[], PointDescriptor const │ │ │ │ │ -&meshPointDesc, REAL patchPoints[], PointDescriptor const &patchPointDesc) │ │ │ │ │ -const │ │ │ │ │ -Prepare patch points in a local array for evaluation. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_3_4_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_I_s_V_a_l_i_d │ │ │ │ │ -bool IsValid() const │ │ │ │ │ -Return true if successfully initialized. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_a_t_h_e_r_C_o_n_t_r_o_l_P_o_i_n_t_s │ │ │ │ │ -void GatherControlPoints(REAL_MESH const meshPoints[], PointDescriptor const │ │ │ │ │ -&meshPointDesc, REAL controlPoints[], PointDescriptor const &controlPointDesc) │ │ │ │ │ -const │ │ │ │ │ -Gather control points in a local array. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_C_o_m_p_u_t_e_P_a_t_c_h_P_o_i_n_t_s │ │ │ │ │ -void ComputePatchPoints(REAL patchPoints[], PointDescriptor const │ │ │ │ │ -&patchPointDesc) const │ │ │ │ │ -Compute all patch points following the control points. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_3_3_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_I_s_L_i_n_e_a_r │ │ │ │ │ -bool IsLinear() const │ │ │ │ │ -Return if the Surface is linear. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_1_1_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_G_e_t_N_u_m_P_a_t_c_h_P_o_i_n_t_s │ │ │ │ │ -int GetNumPatchPoints() const │ │ │ │ │ -Return the number of patch points representing the Surface. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_E_v_a_l_u_a_t_e_S_t_e_n_c_i_l │ │ │ │ │ -int EvaluateStencil(REAL const uv[2], REAL sP[]) const │ │ │ │ │ -Evaluation of the limit stencil for position. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_4_1_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -Simple struct defining the size and stride of points in arrays. │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_s_t_r_i_d_e │ │ │ │ │ -int stride │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_s_i_z_e │ │ │ │ │ -int size │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -PointDescriptor(int n) │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -PointDescriptor(int n, int m) │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r_:_:_P_o_i_n_t_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -PointDescriptor() │ │ │ │ │ -DDeeffiinniittiioonn _s_u_r_f_a_c_e_._h_:_6_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ +Intermediate subclass of SurfaceFactory with Far::TopologyRefiner as the mesh. │ │ │ │ │ +DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_5_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_:_G_e_t_N_u_m_F_a_c_e_s │ │ │ │ │ +int GetNumFaces() const │ │ │ │ │ +Return the number of faces. │ │ │ │ │ +DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_: │ │ │ │ │ +_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ +int GetNumFVarChannels() const │ │ │ │ │ +Return the number of face-varying channels. │ │ │ │ │ +DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_8_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_:_G_e_t_M_e_s_h │ │ │ │ │ +Far::TopologyRefiner const & GetMesh() const │ │ │ │ │ +Return the instance of the mesh. │ │ │ │ │ +DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_7_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_: │ │ │ │ │ +_~_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ +~RefinerSurfaceFactoryBase() override=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e_:_: │ │ │ │ │ +_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ +RefinerSurfaceFactoryBase(Far::TopologyRefiner const &mesh, Options const │ │ │ │ │ +&options) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ +Template for concrete subclasses of RefinerSurfaceFactoryBase. │ │ │ │ │ +DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_5_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ +_~_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ +~RefinerSurfaceFactory() override=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ +_R_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ +RefinerSurfaceFactory(Far::TopologyRefiner const &mesh, Options const │ │ │ │ │ +&options=Options()) │ │ │ │ │ +DDeeffiinniittiioonn _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_5_9 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y │ │ │ │ │ Base class providing initialization of a Surface for each face of a mesh. │ │ │ │ │ DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_0_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y │ │ │ │ │ -DDeeffiinniittiioonn _a_r_r_a_y_._h_:_5_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_:_s_e_t_I_n_t_e_r_n_a_l_C_a_c_h_e │ │ │ │ │ +void setInternalCache(SurfaceFactoryCache *cache) │ │ │ │ │ +Subclass to identify an internal cache for use by base class. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s │ │ │ │ │ +Simple set of options assigned to instances of SurfaceFactory. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_._h_:_1_1_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s │ │ │ │ │ +virtual int getFaceVertexIncidentFaceFVarValueIndices(Index faceIndex, int │ │ │ │ │ +faceVertex, FVarID fvarID, Index fvarValueIndices[]) const =0 │ │ │ │ │ +Gather face-varying indices of incident faces around a face-vertex. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_c_i_d_e_n_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ +virtual int getFaceVertexIncidentFaceVertexIndices(Index faceIndex, int │ │ │ │ │ +faceVertex, Index vertexIndices[]) const =0 │ │ │ │ │ +Gather vertex indices of incident faces around a face-vertex. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_g_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ +virtual int getFaceSize(Index faceIndex) const =0 │ │ │ │ │ +Returns the size of a face (number of vertices) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_I_n_d_e_x │ │ │ │ │ +int Index │ │ │ │ │ +Integer type representing a mesh index. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_p_o_p_u_l_a_t_e_F_a_c_e_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +virtual int populateFaceVertexDescriptor(Index faceIndex, int faceVertex, │ │ │ │ │ +VertexDescriptor *vertexDescriptor) const =0 │ │ │ │ │ +Describe the topology of incident faces around a face-vertex. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_V_e_r_t_e_x_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r │ │ │ │ │ +virtual bool getFaceNeighborhoodVertexIndicesIfRegular(Index faceIndex, Index │ │ │ │ │ +vertexIndices[]) const │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_2_1_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_N_e_i_g_h_b_o_r_h_o_o_d_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s_I_f_R_e_g_u_l_a_r │ │ │ │ │ +virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular(Index faceIndex, │ │ │ │ │ +FVarID fvarID, Index fvarValueIndices[]) const │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_2_2_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_I_n_d_i_c_e_s │ │ │ │ │ +virtual int getFaceFVarValueIndices(Index faceIndex, FVarID fvarID, Index │ │ │ │ │ +fvarValueIndices[]) const =0 │ │ │ │ │ +Gather the face-varying indices of the face's vertices. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_: │ │ │ │ │ +_g_e_t_F_a_c_e_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ +virtual int getFaceVertexIndices(Index faceIndex, Index vertexIndices[]) const │ │ │ │ │ +=0 │ │ │ │ │ +Gather the indices of the face's vertices. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_i_s_F_a_c_e_H_o_l_e │ │ │ │ │ +virtual bool isFaceHole(Index faceIndex) const =0 │ │ │ │ │ +Returns if a face is a hole. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_S_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_:_:_F_V_a_r_I_D │ │ │ │ │ +std::intptr_t FVarID │ │ │ │ │ +Type used to identify and specify face-varying primvars. │ │ │ │ │ +DDeeffiinniittiioonn _s_u_r_f_a_c_e_F_a_c_t_o_r_y_M_e_s_h_A_d_a_p_t_e_r_._h_:_8_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_V_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +Simple class used by subclasses of SurfaceFactory to describe a vertex. │ │ │ │ │ +DDeeffiinniittiioonn _v_e_r_t_e_x_D_e_s_c_r_i_p_t_o_r_._h_:_1_3_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ +Stores topology data for a specified set of refinement options. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_5_1 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _s_u_r_f_a_c_e_._h │ │ │ │ │ + * _r_e_f_i_n_e_r_S_u_r_f_a_c_e_F_a_c_t_o_r_y_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00695.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/parameterization.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/bfr/limits.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,26 +90,26 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
parameterization.h File Reference
│ │ │ │ +
limits.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/types.h"
│ │ │ │ +#include "../far/types.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  Parameterization
 Simple class defining the 2D parameterization of a face. More...
struct  Limits
 Simple struct with limits related to topology. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -118,13 +118,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,24 +1,24 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -parameterization.h File Reference │ │ │ │ │ +limits.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_t_y_p_e_s_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ -  Simple class defining the 2D parameterization of a face. _M_o_r_e_._._. │ │ │ │ │ +struct   _L_i_m_i_t_s │ │ │ │ │ +  Simple struct with limits related to topology. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h │ │ │ │ │ + * _l_i_m_i_t_s_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00695.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,3 @@ │ │ │ │ │ var a00695 = [ │ │ │ │ │ - ["Parameterization", "a00921.html", "a00921"] │ │ │ │ │ + ["Limits", "a00917.html", null] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00695_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/parameterization.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/bfr/limits.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
parameterization.h
│ │ │ │ +
limits.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2021 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,200 +119,55 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_BFR_PARAMETERIZATION_H
│ │ │ │ -
26#define OPENSUBDIV3_BFR_PARAMETERIZATION_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_BFR_LIMITS_H
│ │ │ │ +
26#define OPENSUBDIV3_BFR_LIMITS_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │
29
│ │ │ │ -
30#include "../sdc/types.h"
│ │ │ │ +
30#include "../far/types.h"
│ │ │ │
31
│ │ │ │ -
32namespace OpenSubdiv {
│ │ │ │ -
33namespace OPENSUBDIV_VERSION {
│ │ │ │ +
│ │ │ │ +
32namespace OpenSubdiv {
│ │ │ │ +
│ │ │ │ +
33namespace OPENSUBDIV_VERSION {
│ │ │ │
34
│ │ │ │ -
35namespace Bfr {
│ │ │ │ +
│ │ │ │ +
35namespace Bfr {
│ │ │ │
36
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
53public:
│ │ │ │ -
62 enum Type { QUAD,
│ │ │ │ - │ │ │ │ - │ │ │ │ -
65 };
│ │ │ │ -
66
│ │ │ │ -
67public:
│ │ │ │ -
69
│ │ │ │ -
76
│ │ │ │ -
78 Parameterization(Sdc::SchemeType scheme, int faceSize);
│ │ │ │ -
79
│ │ │ │ -
81 bool IsValid() const { return (_faceSize > 0); }
│ │ │ │ -
82
│ │ │ │ -
84 Parameterization() : _type(0), _uDim(0), _faceSize(0) { }
│ │ │ │ -
85
│ │ │ │ - │ │ │ │ - │ │ │ │ -
88 ~Parameterization() = default;
│ │ │ │ -
90
│ │ │ │ -
92
│ │ │ │ -
96
│ │ │ │ -
98 Type GetType() const { return (Type) _type; }
│ │ │ │ -
99
│ │ │ │ -
101 int GetFaceSize() const { return _faceSize; }
│ │ │ │ -
103
│ │ │ │ -
104public:
│ │ │ │ -
106
│ │ │ │ -
116
│ │ │ │ -
118 template <typename REAL>
│ │ │ │ -
119 void GetVertexCoord(int vertexIndex, REAL uvCoord[2]) const;
│ │ │ │ -
120
│ │ │ │ -
122 template <typename REAL>
│ │ │ │ -
123 void GetEdgeCoord(int edgeIndex, REAL t, REAL uvCoord[2]) const;
│ │ │ │ -
124
│ │ │ │ -
126 template <typename REAL>
│ │ │ │ -
127 void GetCenterCoord(REAL uvCoord[2]) const;
│ │ │ │ -
129
│ │ │ │ -
130public:
│ │ │ │ -
132
│ │ │ │ -
147
│ │ │ │ -
149 bool HasSubFaces() const;
│ │ │ │ -
150
│ │ │ │ -
152 template <typename REAL>
│ │ │ │ -
153 int GetSubFace(REAL const uvCoord[2]) const;
│ │ │ │ -
154
│ │ │ │ -
157 template <typename REAL>
│ │ │ │ - │ │ │ │ -
159 REAL const uvCoord[2], REAL subFaceCoord[2]) const;
│ │ │ │ -
160
│ │ │ │ -
162 template <typename REAL>
│ │ │ │ -
163 void ConvertSubFaceToCoord(int subFace,
│ │ │ │ -
164 REAL const subFaceCoord[2], REAL uvCoord[2]) const;
│ │ │ │ -
165
│ │ │ │ -
168 template <typename REAL>
│ │ │ │ - │ │ │ │ -
170 REAL const uvCoord[2], REAL subFaceCoord[2]) const;
│ │ │ │ -
171
│ │ │ │ -
173 template <typename REAL>
│ │ │ │ -
174 void ConvertNormalizedSubFaceToCoord(int subFace,
│ │ │ │ -
175 REAL const subFaceCoord[2], REAL uvCoord[2]) const;
│ │ │ │ -
177
│ │ │ │ -
178private:
│ │ │ │ -
179 template <typename REAL>
│ │ │ │ -
180 int convertCoordToSubFace(bool normalized,
│ │ │ │ -
181 REAL const uvCoord[2], REAL subFaceCoord[2]) const;
│ │ │ │ -
182 template <typename REAL>
│ │ │ │ -
183 void convertSubFaceToCoord(bool normalized, int subFace,
│ │ │ │ -
184 REAL const subFaceCoord[2], REAL uvCoord[2]) const;
│ │ │ │ -
185
│ │ │ │ -
186private:
│ │ │ │ -
187 unsigned char _type;
│ │ │ │ -
188 unsigned char _uDim;
│ │ │ │ -
189 unsigned short _faceSize;
│ │ │ │ -
190};
│ │ │ │ -
│ │ │ │ -
191
│ │ │ │ -
192//
│ │ │ │ -
193// Inline sub-face coordinate conversion methods:
│ │ │ │ -
194//
│ │ │ │ -
195inline bool
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
197 return (_type == QUAD_SUBFACES);
│ │ │ │ -
198}
│ │ │ │ -
│ │ │ │ -
199
│ │ │ │ -
200template <typename REAL>
│ │ │ │ -
201inline int
│ │ │ │ -
│ │ │ │ -
202Parameterization::GetSubFace(REAL const uvCoord[2]) const {
│ │ │ │ -
203
│ │ │ │ -
204 if (!HasSubFaces()) return 0;
│ │ │ │ -
205
│ │ │ │ -
206 int uTile = (int) uvCoord[0];
│ │ │ │ -
207 int vTile = (int) uvCoord[1];
│ │ │ │ -
208 return (vTile + ((uvCoord[1] - (REAL) vTile) > 0.75f)) * _uDim +
│ │ │ │ -
209 (uTile + ((uvCoord[0] - (REAL) uTile) > 0.75f));
│ │ │ │ -
210}
│ │ │ │ -
│ │ │ │ -
211
│ │ │ │ -
212// Conversions to unnormalized sub-face coordinates:
│ │ │ │ -
213template <typename REAL>
│ │ │ │ -
214inline int
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
216 REAL const uvCoord[2], REAL subCoord[2]) const {
│ │ │ │ -
217 return convertCoordToSubFace<REAL>(false, uvCoord, subCoord);
│ │ │ │ -
218}
│ │ │ │ -
│ │ │ │ -
219template <typename REAL>
│ │ │ │ -
220inline void
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
222 int subFace, REAL const subCoord[2], REAL uvCoord[2]) const {
│ │ │ │ -
223 convertSubFaceToCoord<REAL>(false, subFace, subCoord, uvCoord);
│ │ │ │ -
224}
│ │ │ │ -
│ │ │ │ -
225
│ │ │ │ -
226// Conversions to normalized sub-face coordinates:
│ │ │ │ -
227template <typename REAL>
│ │ │ │ -
228inline int
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
230 REAL const uvCoord[2], REAL subCoord[2]) const {
│ │ │ │ -
231 return convertCoordToSubFace<REAL>(true, uvCoord, subCoord);
│ │ │ │ -
232}
│ │ │ │ -
│ │ │ │ -
233template <typename REAL>
│ │ │ │ -
234inline void
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
236 int subFace, REAL const subCoord[2], REAL uvCoord[2]) const {
│ │ │ │ -
237 convertSubFaceToCoord<REAL>(true, subFace, subCoord, uvCoord);
│ │ │ │ -
238}
│ │ │ │ -
│ │ │ │ -
239
│ │ │ │ -
240} // end namespace Bfr
│ │ │ │ -
241
│ │ │ │ -
242} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
243using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
244
│ │ │ │ -
245} // end namespace OpenSubdiv
│ │ │ │ -
246
│ │ │ │ -
247#endif /* OPENSUBDIV3_BFR_PARAMETERIZATION */
│ │ │ │ - │ │ │ │ -
SchemeType
Enumerated type for all subdivision schemes supported by OpenSubdiv.
Definition types.h:37
│ │ │ │ -
Simple class defining the 2D parameterization of a face.
│ │ │ │ -
int GetSubFace(REAL const uvCoord[2]) const
Returns the integer sub-face containing the given (u,v)
│ │ │ │ -
int GetFaceSize() const
Returns the size (number of vertices) of the corresponding face.
│ │ │ │ -
Type
Enumerated type for the different kinds of Parameterizations.
│ │ │ │ -
@ QUAD_SUBFACES
Partitioned into quadrilateral sub-faces.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
Parameterization(Sdc::SchemeType scheme, int faceSize)
Primary constructor with subdivision scheme and face size.
│ │ │ │ -
int ConvertCoordToSubFace(REAL const uvCoord[2], REAL subFaceCoord[2]) const
Convert (u,v) to a sub-face (return value) and its local (u,v) coordinate.
│ │ │ │ -
void GetCenterCoord(REAL uvCoord[2]) const
Returns the (u,v) coordinate for the center of the face.
│ │ │ │ -
Type GetType() const
Returns the type of parameterization assigned.
│ │ │ │ - │ │ │ │ -
Parameterization(Parameterization const &)=default
│ │ │ │ -
void GetEdgeCoord(int edgeIndex, REAL t, REAL uvCoord[2]) const
Returns the (u,v) coordinate at any point on a given edge.
│ │ │ │ -
void ConvertNormalizedSubFaceToCoord(int subFace, REAL const subFaceCoord[2], REAL uvCoord[2]) const
Convert a sub-face and its normalized (u,v) coordinate to (u,v)
│ │ │ │ -
void GetVertexCoord(int vertexIndex, REAL uvCoord[2]) const
Returns the (u,v) coordinate of a given vertex.
│ │ │ │ -
Parameterization()
Default construction produces an invalid instance.
│ │ │ │ -
bool IsValid() const
Returns true if correctly initialized.
│ │ │ │ -
bool HasSubFaces() const
Returns if Parameterization has been partitioned into sub-faces.
│ │ │ │ -
int ConvertCoordToNormalizedSubFace(REAL const uvCoord[2], REAL subFaceCoord[2]) const
Convert (u,v) to a sub-face (return value) and its normalized (u,v) coordinate.
│ │ │ │ -
void ConvertSubFaceToCoord(int subFace, REAL const subFaceCoord[2], REAL uvCoord[2]) const
Convert a sub-face and its local (u,v) coordinate to (u,v)
│ │ │ │ -
Parameterization & operator=(Parameterization const &)=default
│ │ │ │ +
│ │ │ │ +
40struct Limits {
│ │ │ │ +
42 static int MaxValence() { return Far::VALENCE_LIMIT; }
│ │ │ │ +
43
│ │ │ │ +
46 static int MaxFaceSize() { return Far::VALENCE_LIMIT; }
│ │ │ │ +
47};
│ │ │ │ +
│ │ │ │ +
48
│ │ │ │ +
49} // end namespace Bfr
│ │ │ │ +
│ │ │ │ +
50
│ │ │ │ +
51} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
│ │ │ │ +
52using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
53} // end namespace OpenSubdiv
│ │ │ │ +
│ │ │ │ +
54
│ │ │ │ +
55#endif /* OPENSUBDIV3_BFR_LIMITS_H */
│ │ │ │ + │ │ │ │ +
Simple struct with limits related to topology.
Definition limits.h:40
│ │ │ │ +
static int MaxFaceSize()
Returns the maximum allowable size for a face (number of vertices)
Definition limits.h:46
│ │ │ │ +
static int MaxValence()
Returns the maximum allowable valence for a vertex.
Definition limits.h:42
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -parameterization.h │ │ │ │ │ +limits.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2021 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,243 +24,49 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_BFR_PARAMETERIZATION_H │ │ │ │ │ -26#define OPENSUBDIV3_BFR_PARAMETERIZATION_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_BFR_LIMITS_H │ │ │ │ │ +26#define OPENSUBDIV3_BFR_LIMITS_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ 29 │ │ │ │ │ -30#include "../sdc/types.h" │ │ │ │ │ +30#include "../far/types.h" │ │ │ │ │ 31 │ │ │ │ │ -32namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -33namespace OPENSUBDIV_VERSION { │ │ │ │ │ +_3_2namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +_3_3namespace OPENSUBDIV_VERSION { │ │ │ │ │ 34 │ │ │ │ │ -35namespace Bfr { │ │ │ │ │ +_3_5namespace Bfr { │ │ │ │ │ 36 │ │ │ │ │ -_5_2class _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n { │ │ │ │ │ -53public: │ │ │ │ │ -_6_2 enum _T_y_p_e { _Q_U_A_D, │ │ │ │ │ -_6_3 _T_R_I, │ │ │ │ │ -64 _Q_U_A_D___S_U_B_F_A_C_E_S │ │ │ │ │ -_6_5 }; │ │ │ │ │ -66 │ │ │ │ │ -67public: │ │ │ │ │ -69 │ │ │ │ │ -76 │ │ │ │ │ -_7_8 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n(_S_d_c_:_:_S_c_h_e_m_e_T_y_p_e scheme, int faceSize); │ │ │ │ │ -79 │ │ │ │ │ -_8_1 bool _I_s_V_a_l_i_d() const { return (_faceSize > 0); } │ │ │ │ │ -82 │ │ │ │ │ -_8_4 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n() : _type(0), _uDim(0), _faceSize(0) { } │ │ │ │ │ -85 │ │ │ │ │ -_8_6 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n(_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n const &) = default; │ │ │ │ │ -_8_7 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n & _o_p_e_r_a_t_o_r_=(_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n const &) = default; │ │ │ │ │ -_8_8 _~_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n() = default; │ │ │ │ │ -90 │ │ │ │ │ -92 │ │ │ │ │ -96 │ │ │ │ │ -_9_8 _T_y_p_e _G_e_t_T_y_p_e() const { return (_T_y_p_e) _type; } │ │ │ │ │ -99 │ │ │ │ │ -_1_0_1 int _G_e_t_F_a_c_e_S_i_z_e() const { return _faceSize; } │ │ │ │ │ -103 │ │ │ │ │ -104public: │ │ │ │ │ -106 │ │ │ │ │ -116 │ │ │ │ │ -118 template │ │ │ │ │ -_1_1_9 void _G_e_t_V_e_r_t_e_x_C_o_o_r_d(int vertexIndex, REAL uvCoord[2]) const; │ │ │ │ │ -120 │ │ │ │ │ -122 template │ │ │ │ │ -_1_2_3 void _G_e_t_E_d_g_e_C_o_o_r_d(int edgeIndex, REAL t, REAL uvCoord[2]) const; │ │ │ │ │ -124 │ │ │ │ │ -126 template │ │ │ │ │ -_1_2_7 void _G_e_t_C_e_n_t_e_r_C_o_o_r_d(REAL uvCoord[2]) const; │ │ │ │ │ -129 │ │ │ │ │ -130public: │ │ │ │ │ -132 │ │ │ │ │ -147 │ │ │ │ │ -149 bool _H_a_s_S_u_b_F_a_c_e_s() const; │ │ │ │ │ -150 │ │ │ │ │ -152 template │ │ │ │ │ -153 int _G_e_t_S_u_b_F_a_c_e(REAL const uvCoord[2]) const; │ │ │ │ │ -154 │ │ │ │ │ -157 template │ │ │ │ │ -158 int _C_o_n_v_e_r_t_C_o_o_r_d_T_o_S_u_b_F_a_c_e( │ │ │ │ │ -159 REAL const uvCoord[2], REAL subFaceCoord[2]) const; │ │ │ │ │ -160 │ │ │ │ │ -162 template │ │ │ │ │ -163 void _C_o_n_v_e_r_t_S_u_b_F_a_c_e_T_o_C_o_o_r_d(int subFace, │ │ │ │ │ -164 REAL const subFaceCoord[2], REAL uvCoord[2]) const; │ │ │ │ │ -165 │ │ │ │ │ -168 template │ │ │ │ │ -169 int _C_o_n_v_e_r_t_C_o_o_r_d_T_o_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e( │ │ │ │ │ -170 REAL const uvCoord[2], REAL subFaceCoord[2]) const; │ │ │ │ │ -171 │ │ │ │ │ -173 template │ │ │ │ │ -174 void _C_o_n_v_e_r_t_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e_T_o_C_o_o_r_d(int subFace, │ │ │ │ │ -175 REAL const subFaceCoord[2], REAL uvCoord[2]) const; │ │ │ │ │ -177 │ │ │ │ │ -178private: │ │ │ │ │ -179 template │ │ │ │ │ -180 int convertCoordToSubFace(bool normalized, │ │ │ │ │ -181 REAL const uvCoord[2], REAL subFaceCoord[2]) const; │ │ │ │ │ -182 template │ │ │ │ │ -183 void convertSubFaceToCoord(bool normalized, int subFace, │ │ │ │ │ -184 REAL const subFaceCoord[2], REAL uvCoord[2]) const; │ │ │ │ │ -185 │ │ │ │ │ -186private: │ │ │ │ │ -187 unsigned char _type; │ │ │ │ │ -188 unsigned char _uDim; │ │ │ │ │ -189 unsigned short _faceSize; │ │ │ │ │ -190}; │ │ │ │ │ -191 │ │ │ │ │ -192// │ │ │ │ │ -193// Inline sub-face coordinate conversion methods: │ │ │ │ │ -194// │ │ │ │ │ -195inline bool │ │ │ │ │ -_1_9_6_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_H_a_s_S_u_b_F_a_c_e_s() const { │ │ │ │ │ -197 return (_type == _Q_U_A_D___S_U_B_F_A_C_E_S); │ │ │ │ │ -198} │ │ │ │ │ -199 │ │ │ │ │ -200template │ │ │ │ │ -201inline int │ │ │ │ │ -_2_0_2_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_S_u_b_F_a_c_e(REAL const uvCoord[2]) const { │ │ │ │ │ -203 │ │ │ │ │ -204 if (!_H_a_s_S_u_b_F_a_c_e_s()) return 0; │ │ │ │ │ -205 │ │ │ │ │ -206 int uTile = (int) uvCoord[0]; │ │ │ │ │ -207 int vTile = (int) uvCoord[1]; │ │ │ │ │ -208 return (vTile + ((uvCoord[1] - (REAL) vTile) > 0.75f)) * _uDim + │ │ │ │ │ -209 (uTile + ((uvCoord[0] - (REAL) uTile) > 0.75f)); │ │ │ │ │ -210} │ │ │ │ │ -211 │ │ │ │ │ -212// Conversions to unnormalized sub-face coordinates: │ │ │ │ │ -213template │ │ │ │ │ -214inline int │ │ │ │ │ -_2_1_5_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_C_o_o_r_d_T_o_S_u_b_F_a_c_e( │ │ │ │ │ -216 REAL const uvCoord[2], REAL subCoord[2]) const { │ │ │ │ │ -217 return convertCoordToSubFace(false, uvCoord, subCoord); │ │ │ │ │ -218} │ │ │ │ │ -219template │ │ │ │ │ -220inline void │ │ │ │ │ -_2_2_1_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_S_u_b_F_a_c_e_T_o_C_o_o_r_d( │ │ │ │ │ -222 int subFace, REAL const subCoord[2], REAL uvCoord[2]) const { │ │ │ │ │ -223 convertSubFaceToCoord(false, subFace, subCoord, uvCoord); │ │ │ │ │ -224} │ │ │ │ │ -225 │ │ │ │ │ -226// Conversions to normalized sub-face coordinates: │ │ │ │ │ -227template │ │ │ │ │ -228inline int │ │ │ │ │ -_2_2_9_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_C_o_o_r_d_T_o_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e( │ │ │ │ │ -230 REAL const uvCoord[2], REAL subCoord[2]) const { │ │ │ │ │ -231 return convertCoordToSubFace(true, uvCoord, subCoord); │ │ │ │ │ -232} │ │ │ │ │ -233template │ │ │ │ │ -234inline void │ │ │ │ │ -_2_3_5_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e_T_o_C_o_o_r_d( │ │ │ │ │ -236 int subFace, REAL const subCoord[2], REAL uvCoord[2]) const { │ │ │ │ │ -237 convertSubFaceToCoord(true, subFace, subCoord, uvCoord); │ │ │ │ │ -238} │ │ │ │ │ -239 │ │ │ │ │ -240} // end namespace Bfr │ │ │ │ │ -241 │ │ │ │ │ -242} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -243using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -244 │ │ │ │ │ -245} // end namespace OpenSubdiv │ │ │ │ │ -246 │ │ │ │ │ -247#endif /* OPENSUBDIV3_BFR_PARAMETERIZATION */ │ │ │ │ │ +_4_0struct _L_i_m_i_t_s { │ │ │ │ │ +_4_2 static int _M_a_x_V_a_l_e_n_c_e() { return Far::VALENCE_LIMIT; } │ │ │ │ │ +43 │ │ │ │ │ +_4_6 static int _M_a_x_F_a_c_e_S_i_z_e() { return Far::VALENCE_LIMIT; } │ │ │ │ │ +47}; │ │ │ │ │ +48 │ │ │ │ │ +49} // end namespace Bfr │ │ │ │ │ +50 │ │ │ │ │ +51} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +52using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +53} // end namespace OpenSubdiv │ │ │ │ │ +54 │ │ │ │ │ +55#endif /* OPENSUBDIV3_BFR_LIMITS_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_T_y_p_e │ │ │ │ │ -SchemeType │ │ │ │ │ -Enumerated type for all subdivision schemes supported by OpenSubdiv. │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ -Simple class defining the 2D parameterization of a face. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_5_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_S_u_b_F_a_c_e │ │ │ │ │ -int GetSubFace(REAL const uvCoord[2]) const │ │ │ │ │ -Returns the integer sub-face containing the given (u,v) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_0_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ -int GetFaceSize() const │ │ │ │ │ -Returns the size (number of vertices) of the corresponding face. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_1_0_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_T_y_p_e │ │ │ │ │ -Type │ │ │ │ │ -Enumerated type for the different kinds of Parameterizations. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_Q_U_A_D___S_U_B_F_A_C_E_S │ │ │ │ │ -@ QUAD_SUBFACES │ │ │ │ │ -Partitioned into quadrilateral sub-faces. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_6_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_T_R_I │ │ │ │ │ -@ TRI │ │ │ │ │ -Triangle. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_6_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_Q_U_A_D │ │ │ │ │ -@ QUAD │ │ │ │ │ -Quadrilateral. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ -Parameterization(Sdc::SchemeType scheme, int faceSize) │ │ │ │ │ -Primary constructor with subdivision scheme and face size. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_C_o_o_r_d_T_o_S_u_b_F_a_c_e │ │ │ │ │ -int ConvertCoordToSubFace(REAL const uvCoord[2], REAL subFaceCoord[2]) const │ │ │ │ │ -Convert (u,v) to a sub-face (return value) and its local (u,v) coordinate. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_1_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_C_e_n_t_e_r_C_o_o_r_d │ │ │ │ │ -void GetCenterCoord(REAL uvCoord[2]) const │ │ │ │ │ -Returns the (u,v) coordinate for the center of the face. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_T_y_p_e │ │ │ │ │ -Type GetType() const │ │ │ │ │ -Returns the type of parameterization assigned. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_9_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_~_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ -~Parameterization()=default │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ -Parameterization(Parameterization const &)=default │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_E_d_g_e_C_o_o_r_d │ │ │ │ │ -void GetEdgeCoord(int edgeIndex, REAL t, REAL uvCoord[2]) const │ │ │ │ │ -Returns the (u,v) coordinate at any point on a given edge. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_: │ │ │ │ │ -_C_o_n_v_e_r_t_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e_T_o_C_o_o_r_d │ │ │ │ │ -void ConvertNormalizedSubFaceToCoord(int subFace, REAL const subFaceCoord[2], │ │ │ │ │ -REAL uvCoord[2]) const │ │ │ │ │ -Convert a sub-face and its normalized (u,v) coordinate to (u,v) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_3_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_V_e_r_t_e_x_C_o_o_r_d │ │ │ │ │ -void GetVertexCoord(int vertexIndex, REAL uvCoord[2]) const │ │ │ │ │ -Returns the (u,v) coordinate of a given vertex. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ -Parameterization() │ │ │ │ │ -Default construction produces an invalid instance. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_8_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_I_s_V_a_l_i_d │ │ │ │ │ -bool IsValid() const │ │ │ │ │ -Returns true if correctly initialized. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_8_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_H_a_s_S_u_b_F_a_c_e_s │ │ │ │ │ -bool HasSubFaces() const │ │ │ │ │ -Returns if Parameterization has been partitioned into sub-faces. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_1_9_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_: │ │ │ │ │ -_C_o_n_v_e_r_t_C_o_o_r_d_T_o_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e │ │ │ │ │ -int ConvertCoordToNormalizedSubFace(REAL const uvCoord[2], REAL subFaceCoord │ │ │ │ │ -[2]) const │ │ │ │ │ -Convert (u,v) to a sub-face (return value) and its normalized (u,v) coordinate. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_2_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_S_u_b_F_a_c_e_T_o_C_o_o_r_d │ │ │ │ │ -void ConvertSubFaceToCoord(int subFace, REAL const subFaceCoord[2], REAL │ │ │ │ │ -uvCoord[2]) const │ │ │ │ │ -Convert a sub-face and its local (u,v) coordinate to (u,v) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_2_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_o_p_e_r_a_t_o_r_= │ │ │ │ │ -Parameterization & operator=(Parameterization const &)=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_L_i_m_i_t_s │ │ │ │ │ +Simple struct with limits related to topology. │ │ │ │ │ +DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_L_i_m_i_t_s_:_:_M_a_x_F_a_c_e_S_i_z_e │ │ │ │ │ +static int MaxFaceSize() │ │ │ │ │ +Returns the maximum allowable size for a face (number of vertices) │ │ │ │ │ +DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_4_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_L_i_m_i_t_s_:_:_M_a_x_V_a_l_e_n_c_e │ │ │ │ │ +static int MaxValence() │ │ │ │ │ +Returns the maximum allowable valence for a vertex. │ │ │ │ │ +DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_4_2 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h │ │ │ │ │ + * _l_i_m_i_t_s_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00698.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/limits.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/bfr/parameterization.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,26 +90,26 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
limits.h File Reference
│ │ │ │ +
parameterization.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/types.h"
│ │ │ │ +#include "../sdc/types.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

struct  Limits
 Simple struct with limits related to topology. More...
class  Parameterization
 Simple class defining the 2D parameterization of a face. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -118,13 +118,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,24 +1,24 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -limits.h File Reference │ │ │ │ │ +parameterization.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_f_a_r_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -struct   _L_i_m_i_t_s │ │ │ │ │ -  Simple struct with limits related to topology. _M_o_r_e_._._. │ │ │ │ │ +class   _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ +  Simple class defining the 2D parameterization of a face. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _l_i_m_i_t_s_._h │ │ │ │ │ + * _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00698.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,3 @@ │ │ │ │ │ var a00698 = [ │ │ │ │ │ - ["Limits", "a00917.html", null] │ │ │ │ │ + ["Parameterization", "a00921.html", "a00921"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00698_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/bfr/limits.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/bfr/parameterization.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
limits.h
│ │ │ │ +
parameterization.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2021 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,55 +119,200 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_BFR_LIMITS_H
│ │ │ │ -
26#define OPENSUBDIV3_BFR_LIMITS_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_BFR_PARAMETERIZATION_H
│ │ │ │ +
26#define OPENSUBDIV3_BFR_PARAMETERIZATION_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │
29
│ │ │ │ -
30#include "../far/types.h"
│ │ │ │ +
30#include "../sdc/types.h"
│ │ │ │
31
│ │ │ │ -
│ │ │ │ -
32namespace OpenSubdiv {
│ │ │ │ -
│ │ │ │ -
33namespace OPENSUBDIV_VERSION {
│ │ │ │ +
32namespace OpenSubdiv {
│ │ │ │ +
33namespace OPENSUBDIV_VERSION {
│ │ │ │
34
│ │ │ │ -
│ │ │ │ -
35namespace Bfr {
│ │ │ │ +
35namespace Bfr {
│ │ │ │
36
│ │ │ │ -
│ │ │ │ -
40struct Limits {
│ │ │ │ -
42 static int MaxValence() { return Far::VALENCE_LIMIT; }
│ │ │ │ -
43
│ │ │ │ -
46 static int MaxFaceSize() { return Far::VALENCE_LIMIT; }
│ │ │ │ -
47};
│ │ │ │ -
│ │ │ │ -
48
│ │ │ │ -
49} // end namespace Bfr
│ │ │ │ -
│ │ │ │ -
50
│ │ │ │ -
51} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
│ │ │ │ -
52using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
53} // end namespace OpenSubdiv
│ │ │ │ -
│ │ │ │ -
54
│ │ │ │ -
55#endif /* OPENSUBDIV3_BFR_LIMITS_H */
│ │ │ │ - │ │ │ │ -
Simple struct with limits related to topology.
Definition limits.h:40
│ │ │ │ -
static int MaxFaceSize()
Returns the maximum allowable size for a face (number of vertices)
Definition limits.h:46
│ │ │ │ -
static int MaxValence()
Returns the maximum allowable valence for a vertex.
Definition limits.h:42
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
53public:
│ │ │ │ +
62 enum Type { QUAD,
│ │ │ │ + │ │ │ │ + │ │ │ │ +
65 };
│ │ │ │ +
66
│ │ │ │ +
67public:
│ │ │ │ +
69
│ │ │ │ +
76
│ │ │ │ +
78 Parameterization(Sdc::SchemeType scheme, int faceSize);
│ │ │ │ +
79
│ │ │ │ +
81 bool IsValid() const { return (_faceSize > 0); }
│ │ │ │ +
82
│ │ │ │ +
84 Parameterization() : _type(0), _uDim(0), _faceSize(0) { }
│ │ │ │ +
85
│ │ │ │ + │ │ │ │ + │ │ │ │ +
88 ~Parameterization() = default;
│ │ │ │ +
90
│ │ │ │ +
92
│ │ │ │ +
96
│ │ │ │ +
98 Type GetType() const { return (Type) _type; }
│ │ │ │ +
99
│ │ │ │ +
101 int GetFaceSize() const { return _faceSize; }
│ │ │ │ +
103
│ │ │ │ +
104public:
│ │ │ │ +
106
│ │ │ │ +
116
│ │ │ │ +
118 template <typename REAL>
│ │ │ │ +
119 void GetVertexCoord(int vertexIndex, REAL uvCoord[2]) const;
│ │ │ │ +
120
│ │ │ │ +
122 template <typename REAL>
│ │ │ │ +
123 void GetEdgeCoord(int edgeIndex, REAL t, REAL uvCoord[2]) const;
│ │ │ │ +
124
│ │ │ │ +
126 template <typename REAL>
│ │ │ │ +
127 void GetCenterCoord(REAL uvCoord[2]) const;
│ │ │ │ +
129
│ │ │ │ +
130public:
│ │ │ │ +
132
│ │ │ │ +
147
│ │ │ │ +
149 bool HasSubFaces() const;
│ │ │ │ +
150
│ │ │ │ +
152 template <typename REAL>
│ │ │ │ +
153 int GetSubFace(REAL const uvCoord[2]) const;
│ │ │ │ +
154
│ │ │ │ +
157 template <typename REAL>
│ │ │ │ + │ │ │ │ +
159 REAL const uvCoord[2], REAL subFaceCoord[2]) const;
│ │ │ │ +
160
│ │ │ │ +
162 template <typename REAL>
│ │ │ │ +
163 void ConvertSubFaceToCoord(int subFace,
│ │ │ │ +
164 REAL const subFaceCoord[2], REAL uvCoord[2]) const;
│ │ │ │ +
165
│ │ │ │ +
168 template <typename REAL>
│ │ │ │ + │ │ │ │ +
170 REAL const uvCoord[2], REAL subFaceCoord[2]) const;
│ │ │ │ +
171
│ │ │ │ +
173 template <typename REAL>
│ │ │ │ +
174 void ConvertNormalizedSubFaceToCoord(int subFace,
│ │ │ │ +
175 REAL const subFaceCoord[2], REAL uvCoord[2]) const;
│ │ │ │ +
177
│ │ │ │ +
178private:
│ │ │ │ +
179 template <typename REAL>
│ │ │ │ +
180 int convertCoordToSubFace(bool normalized,
│ │ │ │ +
181 REAL const uvCoord[2], REAL subFaceCoord[2]) const;
│ │ │ │ +
182 template <typename REAL>
│ │ │ │ +
183 void convertSubFaceToCoord(bool normalized, int subFace,
│ │ │ │ +
184 REAL const subFaceCoord[2], REAL uvCoord[2]) const;
│ │ │ │ +
185
│ │ │ │ +
186private:
│ │ │ │ +
187 unsigned char _type;
│ │ │ │ +
188 unsigned char _uDim;
│ │ │ │ +
189 unsigned short _faceSize;
│ │ │ │ +
190};
│ │ │ │ +
│ │ │ │ +
191
│ │ │ │ +
192//
│ │ │ │ +
193// Inline sub-face coordinate conversion methods:
│ │ │ │ +
194//
│ │ │ │ +
195inline bool
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
197 return (_type == QUAD_SUBFACES);
│ │ │ │ +
198}
│ │ │ │ +
│ │ │ │ +
199
│ │ │ │ +
200template <typename REAL>
│ │ │ │ +
201inline int
│ │ │ │ +
│ │ │ │ +
202Parameterization::GetSubFace(REAL const uvCoord[2]) const {
│ │ │ │ +
203
│ │ │ │ +
204 if (!HasSubFaces()) return 0;
│ │ │ │ +
205
│ │ │ │ +
206 int uTile = (int) uvCoord[0];
│ │ │ │ +
207 int vTile = (int) uvCoord[1];
│ │ │ │ +
208 return (vTile + ((uvCoord[1] - (REAL) vTile) > 0.75f)) * _uDim +
│ │ │ │ +
209 (uTile + ((uvCoord[0] - (REAL) uTile) > 0.75f));
│ │ │ │ +
210}
│ │ │ │ +
│ │ │ │ +
211
│ │ │ │ +
212// Conversions to unnormalized sub-face coordinates:
│ │ │ │ +
213template <typename REAL>
│ │ │ │ +
214inline int
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
216 REAL const uvCoord[2], REAL subCoord[2]) const {
│ │ │ │ +
217 return convertCoordToSubFace<REAL>(false, uvCoord, subCoord);
│ │ │ │ +
218}
│ │ │ │ +
│ │ │ │ +
219template <typename REAL>
│ │ │ │ +
220inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
222 int subFace, REAL const subCoord[2], REAL uvCoord[2]) const {
│ │ │ │ +
223 convertSubFaceToCoord<REAL>(false, subFace, subCoord, uvCoord);
│ │ │ │ +
224}
│ │ │ │ +
│ │ │ │ +
225
│ │ │ │ +
226// Conversions to normalized sub-face coordinates:
│ │ │ │ +
227template <typename REAL>
│ │ │ │ +
228inline int
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
230 REAL const uvCoord[2], REAL subCoord[2]) const {
│ │ │ │ +
231 return convertCoordToSubFace<REAL>(true, uvCoord, subCoord);
│ │ │ │ +
232}
│ │ │ │ +
│ │ │ │ +
233template <typename REAL>
│ │ │ │ +
234inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
236 int subFace, REAL const subCoord[2], REAL uvCoord[2]) const {
│ │ │ │ +
237 convertSubFaceToCoord<REAL>(true, subFace, subCoord, uvCoord);
│ │ │ │ +
238}
│ │ │ │ +
│ │ │ │ +
239
│ │ │ │ +
240} // end namespace Bfr
│ │ │ │ +
241
│ │ │ │ +
242} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
243using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
244
│ │ │ │ +
245} // end namespace OpenSubdiv
│ │ │ │ +
246
│ │ │ │ +
247#endif /* OPENSUBDIV3_BFR_PARAMETERIZATION */
│ │ │ │ + │ │ │ │ +
SchemeType
Enumerated type for all subdivision schemes supported by OpenSubdiv.
Definition types.h:37
│ │ │ │ +
Simple class defining the 2D parameterization of a face.
│ │ │ │ +
int GetSubFace(REAL const uvCoord[2]) const
Returns the integer sub-face containing the given (u,v)
│ │ │ │ +
int GetFaceSize() const
Returns the size (number of vertices) of the corresponding face.
│ │ │ │ +
Type
Enumerated type for the different kinds of Parameterizations.
│ │ │ │ +
@ QUAD_SUBFACES
Partitioned into quadrilateral sub-faces.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
Parameterization(Sdc::SchemeType scheme, int faceSize)
Primary constructor with subdivision scheme and face size.
│ │ │ │ +
int ConvertCoordToSubFace(REAL const uvCoord[2], REAL subFaceCoord[2]) const
Convert (u,v) to a sub-face (return value) and its local (u,v) coordinate.
│ │ │ │ +
void GetCenterCoord(REAL uvCoord[2]) const
Returns the (u,v) coordinate for the center of the face.
│ │ │ │ +
Type GetType() const
Returns the type of parameterization assigned.
│ │ │ │ + │ │ │ │ +
Parameterization(Parameterization const &)=default
│ │ │ │ +
void GetEdgeCoord(int edgeIndex, REAL t, REAL uvCoord[2]) const
Returns the (u,v) coordinate at any point on a given edge.
│ │ │ │ +
void ConvertNormalizedSubFaceToCoord(int subFace, REAL const subFaceCoord[2], REAL uvCoord[2]) const
Convert a sub-face and its normalized (u,v) coordinate to (u,v)
│ │ │ │ +
void GetVertexCoord(int vertexIndex, REAL uvCoord[2]) const
Returns the (u,v) coordinate of a given vertex.
│ │ │ │ +
Parameterization()
Default construction produces an invalid instance.
│ │ │ │ +
bool IsValid() const
Returns true if correctly initialized.
│ │ │ │ +
bool HasSubFaces() const
Returns if Parameterization has been partitioned into sub-faces.
│ │ │ │ +
int ConvertCoordToNormalizedSubFace(REAL const uvCoord[2], REAL subFaceCoord[2]) const
Convert (u,v) to a sub-face (return value) and its normalized (u,v) coordinate.
│ │ │ │ +
void ConvertSubFaceToCoord(int subFace, REAL const subFaceCoord[2], REAL uvCoord[2]) const
Convert a sub-face and its local (u,v) coordinate to (u,v)
│ │ │ │ +
Parameterization & operator=(Parameterization const &)=default
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -limits.h │ │ │ │ │ +parameterization.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2021 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,49 +24,243 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_BFR_LIMITS_H │ │ │ │ │ -26#define OPENSUBDIV3_BFR_LIMITS_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_BFR_PARAMETERIZATION_H │ │ │ │ │ +26#define OPENSUBDIV3_BFR_PARAMETERIZATION_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ 29 │ │ │ │ │ -30#include "../far/types.h" │ │ │ │ │ +30#include "../sdc/types.h" │ │ │ │ │ 31 │ │ │ │ │ -_3_2namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -_3_3namespace OPENSUBDIV_VERSION { │ │ │ │ │ +32namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +33namespace OPENSUBDIV_VERSION { │ │ │ │ │ 34 │ │ │ │ │ -_3_5namespace Bfr { │ │ │ │ │ +35namespace Bfr { │ │ │ │ │ 36 │ │ │ │ │ -_4_0struct _L_i_m_i_t_s { │ │ │ │ │ -_4_2 static int _M_a_x_V_a_l_e_n_c_e() { return Far::VALENCE_LIMIT; } │ │ │ │ │ -43 │ │ │ │ │ -_4_6 static int _M_a_x_F_a_c_e_S_i_z_e() { return Far::VALENCE_LIMIT; } │ │ │ │ │ -47}; │ │ │ │ │ -48 │ │ │ │ │ -49} // end namespace Bfr │ │ │ │ │ -50 │ │ │ │ │ -51} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -52using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -53} // end namespace OpenSubdiv │ │ │ │ │ -54 │ │ │ │ │ -55#endif /* OPENSUBDIV3_BFR_LIMITS_H */ │ │ │ │ │ +_5_2class _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n { │ │ │ │ │ +53public: │ │ │ │ │ +_6_2 enum _T_y_p_e { _Q_U_A_D, │ │ │ │ │ +_6_3 _T_R_I, │ │ │ │ │ +64 _Q_U_A_D___S_U_B_F_A_C_E_S │ │ │ │ │ +_6_5 }; │ │ │ │ │ +66 │ │ │ │ │ +67public: │ │ │ │ │ +69 │ │ │ │ │ +76 │ │ │ │ │ +_7_8 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n(_S_d_c_:_:_S_c_h_e_m_e_T_y_p_e scheme, int faceSize); │ │ │ │ │ +79 │ │ │ │ │ +_8_1 bool _I_s_V_a_l_i_d() const { return (_faceSize > 0); } │ │ │ │ │ +82 │ │ │ │ │ +_8_4 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n() : _type(0), _uDim(0), _faceSize(0) { } │ │ │ │ │ +85 │ │ │ │ │ +_8_6 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n(_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n const &) = default; │ │ │ │ │ +_8_7 _P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n & _o_p_e_r_a_t_o_r_=(_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n const &) = default; │ │ │ │ │ +_8_8 _~_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n() = default; │ │ │ │ │ +90 │ │ │ │ │ +92 │ │ │ │ │ +96 │ │ │ │ │ +_9_8 _T_y_p_e _G_e_t_T_y_p_e() const { return (_T_y_p_e) _type; } │ │ │ │ │ +99 │ │ │ │ │ +_1_0_1 int _G_e_t_F_a_c_e_S_i_z_e() const { return _faceSize; } │ │ │ │ │ +103 │ │ │ │ │ +104public: │ │ │ │ │ +106 │ │ │ │ │ +116 │ │ │ │ │ +118 template │ │ │ │ │ +_1_1_9 void _G_e_t_V_e_r_t_e_x_C_o_o_r_d(int vertexIndex, REAL uvCoord[2]) const; │ │ │ │ │ +120 │ │ │ │ │ +122 template │ │ │ │ │ +_1_2_3 void _G_e_t_E_d_g_e_C_o_o_r_d(int edgeIndex, REAL t, REAL uvCoord[2]) const; │ │ │ │ │ +124 │ │ │ │ │ +126 template │ │ │ │ │ +_1_2_7 void _G_e_t_C_e_n_t_e_r_C_o_o_r_d(REAL uvCoord[2]) const; │ │ │ │ │ +129 │ │ │ │ │ +130public: │ │ │ │ │ +132 │ │ │ │ │ +147 │ │ │ │ │ +149 bool _H_a_s_S_u_b_F_a_c_e_s() const; │ │ │ │ │ +150 │ │ │ │ │ +152 template │ │ │ │ │ +153 int _G_e_t_S_u_b_F_a_c_e(REAL const uvCoord[2]) const; │ │ │ │ │ +154 │ │ │ │ │ +157 template │ │ │ │ │ +158 int _C_o_n_v_e_r_t_C_o_o_r_d_T_o_S_u_b_F_a_c_e( │ │ │ │ │ +159 REAL const uvCoord[2], REAL subFaceCoord[2]) const; │ │ │ │ │ +160 │ │ │ │ │ +162 template │ │ │ │ │ +163 void _C_o_n_v_e_r_t_S_u_b_F_a_c_e_T_o_C_o_o_r_d(int subFace, │ │ │ │ │ +164 REAL const subFaceCoord[2], REAL uvCoord[2]) const; │ │ │ │ │ +165 │ │ │ │ │ +168 template │ │ │ │ │ +169 int _C_o_n_v_e_r_t_C_o_o_r_d_T_o_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e( │ │ │ │ │ +170 REAL const uvCoord[2], REAL subFaceCoord[2]) const; │ │ │ │ │ +171 │ │ │ │ │ +173 template │ │ │ │ │ +174 void _C_o_n_v_e_r_t_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e_T_o_C_o_o_r_d(int subFace, │ │ │ │ │ +175 REAL const subFaceCoord[2], REAL uvCoord[2]) const; │ │ │ │ │ +177 │ │ │ │ │ +178private: │ │ │ │ │ +179 template │ │ │ │ │ +180 int convertCoordToSubFace(bool normalized, │ │ │ │ │ +181 REAL const uvCoord[2], REAL subFaceCoord[2]) const; │ │ │ │ │ +182 template │ │ │ │ │ +183 void convertSubFaceToCoord(bool normalized, int subFace, │ │ │ │ │ +184 REAL const subFaceCoord[2], REAL uvCoord[2]) const; │ │ │ │ │ +185 │ │ │ │ │ +186private: │ │ │ │ │ +187 unsigned char _type; │ │ │ │ │ +188 unsigned char _uDim; │ │ │ │ │ +189 unsigned short _faceSize; │ │ │ │ │ +190}; │ │ │ │ │ +191 │ │ │ │ │ +192// │ │ │ │ │ +193// Inline sub-face coordinate conversion methods: │ │ │ │ │ +194// │ │ │ │ │ +195inline bool │ │ │ │ │ +_1_9_6_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_H_a_s_S_u_b_F_a_c_e_s() const { │ │ │ │ │ +197 return (_type == _Q_U_A_D___S_U_B_F_A_C_E_S); │ │ │ │ │ +198} │ │ │ │ │ +199 │ │ │ │ │ +200template │ │ │ │ │ +201inline int │ │ │ │ │ +_2_0_2_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_S_u_b_F_a_c_e(REAL const uvCoord[2]) const { │ │ │ │ │ +203 │ │ │ │ │ +204 if (!_H_a_s_S_u_b_F_a_c_e_s()) return 0; │ │ │ │ │ +205 │ │ │ │ │ +206 int uTile = (int) uvCoord[0]; │ │ │ │ │ +207 int vTile = (int) uvCoord[1]; │ │ │ │ │ +208 return (vTile + ((uvCoord[1] - (REAL) vTile) > 0.75f)) * _uDim + │ │ │ │ │ +209 (uTile + ((uvCoord[0] - (REAL) uTile) > 0.75f)); │ │ │ │ │ +210} │ │ │ │ │ +211 │ │ │ │ │ +212// Conversions to unnormalized sub-face coordinates: │ │ │ │ │ +213template │ │ │ │ │ +214inline int │ │ │ │ │ +_2_1_5_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_C_o_o_r_d_T_o_S_u_b_F_a_c_e( │ │ │ │ │ +216 REAL const uvCoord[2], REAL subCoord[2]) const { │ │ │ │ │ +217 return convertCoordToSubFace(false, uvCoord, subCoord); │ │ │ │ │ +218} │ │ │ │ │ +219template │ │ │ │ │ +220inline void │ │ │ │ │ +_2_2_1_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_S_u_b_F_a_c_e_T_o_C_o_o_r_d( │ │ │ │ │ +222 int subFace, REAL const subCoord[2], REAL uvCoord[2]) const { │ │ │ │ │ +223 convertSubFaceToCoord(false, subFace, subCoord, uvCoord); │ │ │ │ │ +224} │ │ │ │ │ +225 │ │ │ │ │ +226// Conversions to normalized sub-face coordinates: │ │ │ │ │ +227template │ │ │ │ │ +228inline int │ │ │ │ │ +_2_2_9_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_C_o_o_r_d_T_o_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e( │ │ │ │ │ +230 REAL const uvCoord[2], REAL subCoord[2]) const { │ │ │ │ │ +231 return convertCoordToSubFace(true, uvCoord, subCoord); │ │ │ │ │ +232} │ │ │ │ │ +233template │ │ │ │ │ +234inline void │ │ │ │ │ +_2_3_5_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e_T_o_C_o_o_r_d( │ │ │ │ │ +236 int subFace, REAL const subCoord[2], REAL uvCoord[2]) const { │ │ │ │ │ +237 convertSubFaceToCoord(true, subFace, subCoord, uvCoord); │ │ │ │ │ +238} │ │ │ │ │ +239 │ │ │ │ │ +240} // end namespace Bfr │ │ │ │ │ +241 │ │ │ │ │ +242} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +243using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +244 │ │ │ │ │ +245} // end namespace OpenSubdiv │ │ │ │ │ +246 │ │ │ │ │ +247#endif /* OPENSUBDIV3_BFR_PARAMETERIZATION */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_L_i_m_i_t_s │ │ │ │ │ -Simple struct with limits related to topology. │ │ │ │ │ -DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_L_i_m_i_t_s_:_:_M_a_x_F_a_c_e_S_i_z_e │ │ │ │ │ -static int MaxFaceSize() │ │ │ │ │ -Returns the maximum allowable size for a face (number of vertices) │ │ │ │ │ -DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_4_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_L_i_m_i_t_s_:_:_M_a_x_V_a_l_e_n_c_e │ │ │ │ │ -static int MaxValence() │ │ │ │ │ -Returns the maximum allowable valence for a vertex. │ │ │ │ │ -DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_4_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_T_y_p_e │ │ │ │ │ +SchemeType │ │ │ │ │ +Enumerated type for all subdivision schemes supported by OpenSubdiv. │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ +Simple class defining the 2D parameterization of a face. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_5_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_S_u_b_F_a_c_e │ │ │ │ │ +int GetSubFace(REAL const uvCoord[2]) const │ │ │ │ │ +Returns the integer sub-face containing the given (u,v) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_0_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_F_a_c_e_S_i_z_e │ │ │ │ │ +int GetFaceSize() const │ │ │ │ │ +Returns the size (number of vertices) of the corresponding face. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_1_0_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_T_y_p_e │ │ │ │ │ +Type │ │ │ │ │ +Enumerated type for the different kinds of Parameterizations. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_Q_U_A_D___S_U_B_F_A_C_E_S │ │ │ │ │ +@ QUAD_SUBFACES │ │ │ │ │ +Partitioned into quadrilateral sub-faces. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_6_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_T_R_I │ │ │ │ │ +@ TRI │ │ │ │ │ +Triangle. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_6_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_Q_U_A_D │ │ │ │ │ +@ QUAD │ │ │ │ │ +Quadrilateral. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ +Parameterization(Sdc::SchemeType scheme, int faceSize) │ │ │ │ │ +Primary constructor with subdivision scheme and face size. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_C_o_o_r_d_T_o_S_u_b_F_a_c_e │ │ │ │ │ +int ConvertCoordToSubFace(REAL const uvCoord[2], REAL subFaceCoord[2]) const │ │ │ │ │ +Convert (u,v) to a sub-face (return value) and its local (u,v) coordinate. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_1_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_C_e_n_t_e_r_C_o_o_r_d │ │ │ │ │ +void GetCenterCoord(REAL uvCoord[2]) const │ │ │ │ │ +Returns the (u,v) coordinate for the center of the face. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_T_y_p_e │ │ │ │ │ +Type GetType() const │ │ │ │ │ +Returns the type of parameterization assigned. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_~_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ +~Parameterization()=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ +Parameterization(Parameterization const &)=default │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_E_d_g_e_C_o_o_r_d │ │ │ │ │ +void GetEdgeCoord(int edgeIndex, REAL t, REAL uvCoord[2]) const │ │ │ │ │ +Returns the (u,v) coordinate at any point on a given edge. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_: │ │ │ │ │ +_C_o_n_v_e_r_t_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e_T_o_C_o_o_r_d │ │ │ │ │ +void ConvertNormalizedSubFaceToCoord(int subFace, REAL const subFaceCoord[2], │ │ │ │ │ +REAL uvCoord[2]) const │ │ │ │ │ +Convert a sub-face and its normalized (u,v) coordinate to (u,v) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_3_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_G_e_t_V_e_r_t_e_x_C_o_o_r_d │ │ │ │ │ +void GetVertexCoord(int vertexIndex, REAL uvCoord[2]) const │ │ │ │ │ +Returns the (u,v) coordinate of a given vertex. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n │ │ │ │ │ +Parameterization() │ │ │ │ │ +Default construction produces an invalid instance. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_8_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_I_s_V_a_l_i_d │ │ │ │ │ +bool IsValid() const │ │ │ │ │ +Returns true if correctly initialized. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_8_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_H_a_s_S_u_b_F_a_c_e_s │ │ │ │ │ +bool HasSubFaces() const │ │ │ │ │ +Returns if Parameterization has been partitioned into sub-faces. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_1_9_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_: │ │ │ │ │ +_C_o_n_v_e_r_t_C_o_o_r_d_T_o_N_o_r_m_a_l_i_z_e_d_S_u_b_F_a_c_e │ │ │ │ │ +int ConvertCoordToNormalizedSubFace(REAL const uvCoord[2], REAL subFaceCoord │ │ │ │ │ +[2]) const │ │ │ │ │ +Convert (u,v) to a sub-face (return value) and its normalized (u,v) coordinate. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_2_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_C_o_n_v_e_r_t_S_u_b_F_a_c_e_T_o_C_o_o_r_d │ │ │ │ │ +void ConvertSubFaceToCoord(int subFace, REAL const subFaceCoord[2], REAL │ │ │ │ │ +uvCoord[2]) const │ │ │ │ │ +Convert a sub-face and its local (u,v) coordinate to (u,v) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h_:_2_2_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_B_f_r_:_:_P_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_:_:_o_p_e_r_a_t_o_r_= │ │ │ │ │ +Parameterization & operator=(Parameterization const &)=default │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _b_f_r │ │ │ │ │ - * _l_i_m_i_t_s_._h │ │ │ │ │ + * _p_a_r_a_m_e_t_e_r_i_z_a_t_i_o_n_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00704.html │ │ │ │ @@ -94,15 +94,15 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
topologyRefinerFactory.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/topologyRefiner.h"
│ │ │ │ +#include "../far/topologyRefiner.h"
│ │ │ │ #include "../far/error.h"
│ │ │ │ #include <cassert>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00704_source.html │ │ │ │ @@ -739,15 +739,15 @@ │ │ │ │
717} // end namespace Far
│ │ │ │
718
│ │ │ │
719} // end namespace OPENSUBDIV_VERSION
│ │ │ │
720using namespace OPENSUBDIV_VERSION;
│ │ │ │
721} // end namespace OpenSubdiv
│ │ │ │
722
│ │ │ │
723#endif /* OPENSUBDIV3_FAR_TOPOLOGY_REFINER_FACTORY_H */
│ │ │ │ - │ │ │ │ + │ │ │ │
void Error(ErrorType err, const char *format,...)
Sends an OSD error with a message (internal use only)
│ │ │ │
@ FAR_RUNTIME_ERROR
Issue a generic runtime error, but continue execution.
Definition error.h:40
│ │ │ │ │ │ │ │
SchemeType
Enumerated type for all subdivision schemes supported by OpenSubdiv.
Definition types.h:37
│ │ │ │ │ │ │ │
Factory for constructing TopologyRefiners from specific mesh classes.
│ │ │ │
static int getNumBaseFaces(TopologyRefiner const &newRefiner)
│ │ │ │ @@ -782,29 +782,29 @@ │ │ │ │
static TopologyRefiner * Create(MESH const &mesh, Options options=Options())
Instantiates a TopologyRefiner from client-provided topological representation.
│ │ │ │
static Index findBaseEdge(TopologyRefiner const &newRefiner, Index v0, Index v1)
Identify an edge to be assigned a sharpness value given a vertex pair.
│ │ │ │
static IndexArray getBaseVertexEdges(TopologyRefiner &newRefiner, Index v)
Assign the edges incident each vertex.
│ │ │ │
static int createBaseFVarChannel(TopologyRefiner &newRefiner, int numValues)
Create a new face-varying channel with the given number of values.
│ │ │ │
static int getNumBaseEdges(TopologyRefiner const &newRefiner)
│ │ │ │
static void setNumBaseVertices(TopologyRefiner &newRefiner, int count)
Specify the number of vertices to be accommodated.
│ │ │ │
static void setBaseFaceHole(TopologyRefiner &newRefiner, Index f, bool isHole)
Tag a face as a hole.
│ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │
Private base class of Factories for constructing TopologyRefiners.
│ │ │ │
static bool prepareComponentTopologyAssignment(TopologyRefiner &refiner, bool fullValidation, TopologyCallback callback, void const *callbackData)
│ │ │ │ │ │ │ │
static bool prepareComponentTagsAndSharpness(TopologyRefiner &refiner)
│ │ │ │
static bool prepareComponentTopologySizing(TopologyRefiner &refiner)
│ │ │ │
static bool prepareFaceVaryingChannels(TopologyRefiner &refiner)
│ │ │ │
Options related to the construction of each TopologyRefiner.
│ │ │ │
Options(Sdc::SchemeType sdcType=Sdc::SCHEME_CATMARK, Sdc::Options sdcOptions=Sdc::Options())
│ │ │ │ │ │ │ │
Sdc::SchemeType schemeType
The subdivision scheme type identifier.
│ │ │ │ │ │ │ │ -
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ -
void SetFVarLinearInterpolation(FVarLinearInterpolation b)
Set face-varying interpolation rule.
Definition options.h:98
│ │ │ │ -
FVarLinearInterpolation GetFVarLinearInterpolation() const
Get face-varying interpolation rule.
Definition options.h:95
│ │ │ │ +
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ +
void SetFVarLinearInterpolation(FVarLinearInterpolation b)
Set face-varying interpolation rule.
Definition options.h:98
│ │ │ │ +
FVarLinearInterpolation GetFVarLinearInterpolation() const
Get face-varying interpolation rule.
Definition options.h:95
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
topologyLevel.h File Reference
│ │ │ │ +
topologyRefiner.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../vtr/level.h"
│ │ │ │ -#include "../vtr/refinement.h"
│ │ │ │ +#include "../sdc/types.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │ #include "../far/types.h"
│ │ │ │ +#include "../far/topologyLevel.h"
│ │ │ │ #include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  TopologyLevel
 An interface for accessing data in a specific level of a refined topology hierarchy. More...
class  TopologyRefiner
 Stores topology data for a specified set of refinement options. More...
 
struct  TopologyRefiner::UniformOptions
 Uniform refinement options. More...
 
struct  TopologyRefiner::AdaptiveOptions
 Adaptive refinement options. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Vtr
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,28 +1,37 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -topologyLevel.h File Reference │ │ │ │ │ +topologyRefiner.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_v_t_r_/_l_e_v_e_l_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_r_e_f_i_n_e_m_e_n_t_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ #include "_._._/_f_a_r_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_t_o_p_o_l_o_g_y_L_e_v_e_l_._h" │ │ │ │ │ #include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _T_o_p_o_l_o_g_y_L_e_v_e_l │ │ │ │ │ -  An interface for accessing data in a specific level of a refined │ │ │ │ │ - topology hierarchy. _M_o_r_e_._._. │ │ │ │ │ + class   _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ +  Stores topology data for a specified set of refinement options. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +struct   _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s │ │ │ │ │ +  Uniform refinement options. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +struct   _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ +  Adaptive refinement options. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r │ │ │ │ │ +  │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _t_o_p_o_l_o_g_y_L_e_v_e_l_._h │ │ │ │ │ + * _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00707.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,5 @@ │ │ │ │ │ var a00707 = [ │ │ │ │ │ - ["TopologyLevel", "a01113.html", "a01113"] │ │ │ │ │ + ["TopologyRefiner", "a01121.html", "a01121"], │ │ │ │ │ + ["UniformOptions", "a01125.html", "a01125"], │ │ │ │ │ + ["AdaptiveOptions", "a01129.html", "a01129"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00707_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/topologyLevel.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/far/topologyRefiner.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
topologyLevel.h
│ │ │ │ +
topologyRefiner.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2015 DreamWorks Animation LLC.
│ │ │ │ +
2// Copyright 2014 DreamWorks Animation LLC.
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -118,228 +118,305 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24#ifndef OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H
│ │ │ │ -
25#define OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H
│ │ │ │ +
24#ifndef OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H
│ │ │ │ +
25#define OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H
│ │ │ │
26
│ │ │ │
27#include "../version.h"
│ │ │ │
28
│ │ │ │ -
29#include "../vtr/level.h"
│ │ │ │ -
30#include "../vtr/refinement.h"
│ │ │ │ +
29#include "../sdc/types.h"
│ │ │ │ +
30#include "../sdc/options.h"
│ │ │ │
31#include "../far/types.h"
│ │ │ │ -
32
│ │ │ │ -
33#include <vector>
│ │ │ │ -
34
│ │ │ │ -
35namespace OpenSubdiv {
│ │ │ │ -
36namespace OPENSUBDIV_VERSION {
│ │ │ │ -
37
│ │ │ │ -
38namespace Far {
│ │ │ │ +
32#include "../far/topologyLevel.h"
│ │ │ │ +
33
│ │ │ │ +
34#include <vector>
│ │ │ │ +
35
│ │ │ │ +
36
│ │ │ │ +
37namespace OpenSubdiv {
│ │ │ │ +
38namespace OPENSUBDIV_VERSION {
│ │ │ │
39
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
50
│ │ │ │ -
51public:
│ │ │ │ -
53
│ │ │ │ +
40namespace Vtr { namespace internal { class SparseSelector; } }
│ │ │ │ +
41namespace Far { namespace internal { class FeatureMask; } }
│ │ │ │ +
42
│ │ │ │ +
43namespace Far {
│ │ │ │ +
44
│ │ │ │ +
45template <typename REAL> class PrimvarRefinerReal;
│ │ │ │ +
46template <class MESH> class TopologyRefinerFactory;
│ │ │ │ +
47
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
52
│ │ │ │ +
53public:
│ │ │ │ +
54
│ │ │ │ + │ │ │ │ +
57
│ │ │ │ + │ │ │ │
60
│ │ │ │ -
62 int GetNumVertices() const { return _level->getNumVertices(); }
│ │ │ │ +
62 Sdc::SchemeType GetSchemeType() const { return _subdivType; }
│ │ │ │
63
│ │ │ │ -
65 int GetNumFaces() const { return _level->getNumFaces(); }
│ │ │ │ +
65 Sdc::Options GetSchemeOptions() const { return _subdivOptions; }
│ │ │ │
66
│ │ │ │ -
68 int GetNumEdges() const { return _level->getNumEdges(); }
│ │ │ │ +
68 bool IsUniform() const { return _isUniform; }
│ │ │ │
69
│ │ │ │ -
71 int GetNumFaceVertices() const { return _level->getNumFaceVerticesTotal(); }
│ │ │ │ -
73
│ │ │ │ +
71 int GetNumLevels() const { return (int)_farLevels.size(); }
│ │ │ │ +
72
│ │ │ │ +
74 int GetMaxLevel() const { return _maxLevel; }
│ │ │ │
75
│ │ │ │ -
90 //
│ │ │ │ -
91
│ │ │ │ -
93 ConstIndexArray GetFaceVertices(Index f) const { return _level->getFaceVertices(f); }
│ │ │ │ -
94
│ │ │ │ -
96 ConstIndexArray GetFaceEdges(Index f) const { return _level->getFaceEdges(f); }
│ │ │ │ -
97
│ │ │ │ -
99 ConstIndexArray GetEdgeVertices(Index e) const { return _level->getEdgeVertices(e); }
│ │ │ │ +
77 int GetMaxValence() const { return _maxValence; }
│ │ │ │ +
78
│ │ │ │ +
80 bool HasHoles() const { return _hasHoles; }
│ │ │ │ +
81
│ │ │ │ +
83 int GetNumVerticesTotal() const { return _totalVertices; }
│ │ │ │ +
84
│ │ │ │ +
86 int GetNumEdgesTotal() const { return _totalEdges; }
│ │ │ │ +
87
│ │ │ │ +
89 int GetNumFacesTotal() const { return _totalFaces; }
│ │ │ │ +
90
│ │ │ │ +
92 int GetNumFaceVerticesTotal() const { return _totalFaceVertices; }
│ │ │ │ +
93
│ │ │ │ +
95 TopologyLevel const & GetLevel(int level) const { return _farLevels[level]; }
│ │ │ │ +
96
│ │ │ │ +
98
│ │ │ │
100
│ │ │ │ -
102 ConstIndexArray GetEdgeFaces(Index e) const { return _level->getEdgeFaces(e); }
│ │ │ │ -
103
│ │ │ │ -
105 ConstIndexArray GetVertexFaces(Index v) const { return _level->getVertexFaces(v); }
│ │ │ │ -
106
│ │ │ │ -
108 ConstIndexArray GetVertexEdges(Index v) const { return _level->getVertexEdges(v); }
│ │ │ │ -
109
│ │ │ │ -
111 ConstLocalIndexArray GetVertexFaceLocalIndices(Index v) const { return _level->getVertexFaceLocalIndices(v); }
│ │ │ │ -
112
│ │ │ │ -
114 ConstLocalIndexArray GetVertexEdgeLocalIndices(Index v) const { return _level->getVertexEdgeLocalIndices(v); }
│ │ │ │ -
115
│ │ │ │ -
117 ConstLocalIndexArray GetEdgeFaceLocalIndices(Index e) const { return _level->getEdgeFaceLocalIndices(e); }
│ │ │ │ -
118
│ │ │ │ -
120 Index FindEdge(Index v0, Index v1) const { return _level->findEdge(v0, v1); }
│ │ │ │ -
122
│ │ │ │ +
101 //
│ │ │ │ +
102 // Uniform refinement
│ │ │ │ +
103 //
│ │ │ │ +
104
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
119
│ │ │ │ +
│ │ │ │ +
120 UniformOptions(int level) :
│ │ │ │ +
121 refinementLevel(level & 0xf),
│ │ │ │ + │ │ │ │ +
123 fullTopologyInLastLevel(false) { }
│ │ │ │ +
│ │ │ │
124
│ │ │ │ -
126
│ │ │ │ -
128 bool IsEdgeNonManifold(Index e) const { return _level->isEdgeNonManifold(e); }
│ │ │ │ -
129
│ │ │ │ -
131 bool IsVertexNonManifold(Index v) const { return _level->isVertexNonManifold(v); }
│ │ │ │ -
132
│ │ │ │ -
134 bool IsEdgeBoundary(Index e) const { return _level->getEdgeTag(e)._boundary; }
│ │ │ │ +
126 void SetRefinementLevel(int level) { refinementLevel = level & 0xf; }
│ │ │ │ +
127
│ │ │ │ +
128 unsigned int refinementLevel:4,
│ │ │ │ + │ │ │ │ + │ │ │ │ +
134 };
│ │ │ │ +
│ │ │ │
135
│ │ │ │ -
137 bool IsVertexBoundary(Index v) const { return _level->getVertexTag(v)._boundary; }
│ │ │ │ -
138
│ │ │ │ -
140 bool IsVertexCorner(Index v) const { return (_level->getNumVertexFaces(v) == 1); }
│ │ │ │ -
141
│ │ │ │ -
162 bool IsVertexValenceRegular(Index v) const { return !_level->getVertexTag(v)._xordinary || IsVertexCorner(v); }
│ │ │ │ -
164
│ │ │ │ -
166
│ │ │ │ + │ │ │ │ +
147
│ │ │ │ +
149 UniformOptions GetUniformOptions() const { return _uniformOptions; }
│ │ │ │ +
150
│ │ │ │ +
151 //
│ │ │ │ +
152 // Adaptive refinement
│ │ │ │ +
153 //
│ │ │ │ +
154
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
157
│ │ │ │ +
│ │ │ │ +
158 AdaptiveOptions(int level) :
│ │ │ │ +
159 isolationLevel(level & 0xf),
│ │ │ │ +
160 secondaryLevel(0xf),
│ │ │ │ + │ │ │ │ +
162 useInfSharpPatch(false),
│ │ │ │ + │ │ │ │ + │ │ │ │ +
│ │ │ │ +
165
│ │ │ │ +
167 void SetIsolationLevel(int level) { isolationLevel = level & 0xf; }
│ │ │ │ +
168
│ │ │ │ +
170 void SetSecondaryLevel(int level) { secondaryLevel = level & 0xf; }
│ │ │ │
171
│ │ │ │ -
173 float GetEdgeSharpness(Index e) const { return _level->getEdgeSharpness(e); }
│ │ │ │ -
174
│ │ │ │ -
176 float GetVertexSharpness(Index v) const { return _level->getVertexSharpness(v); }
│ │ │ │ -
177
│ │ │ │ -
179 bool IsEdgeInfSharp(Index e) const { return _level->getEdgeTag(e)._infSharp; }
│ │ │ │ -
180
│ │ │ │ -
182 bool IsVertexInfSharp(Index v) const { return _level->getVertexTag(v)._infSharp; }
│ │ │ │ -
183
│ │ │ │ -
185 bool IsEdgeSemiSharp(Index e) const { return _level->getEdgeTag(e)._semiSharp; }
│ │ │ │ -
186
│ │ │ │ -
188 bool IsVertexSemiSharp(Index v) const { return _level->getVertexTag(v)._semiSharp; }
│ │ │ │ -
189
│ │ │ │ -
191 bool IsFaceHole(Index f) const { return _level->isFaceHole(f); }
│ │ │ │ -
192
│ │ │ │ -
194 Sdc::Crease::Rule GetVertexRule(Index v) const { return _level->getVertexRule(v); }
│ │ │ │ -
196
│ │ │ │ -
198
│ │ │ │ -
228
│ │ │ │ -
230 int GetNumFVarChannels() const { return _level->getNumFVarChannels(); }
│ │ │ │ -
231
│ │ │ │ -
234 int GetNumFVarValues(int channel = 0) const { return _level->getNumFVarValues(channel); }
│ │ │ │ -
235
│ │ │ │ -
│ │ │ │ -
237 ConstIndexArray GetFaceFVarValues(Index f, int channel = 0) const {
│ │ │ │ -
238 return _level->getFaceFVarValues(f, channel);
│ │ │ │ -
239 }
│ │ │ │ -
│ │ │ │ -
240
│ │ │ │ -
│ │ │ │ -
242 bool DoesVertexFVarTopologyMatch(Index v, int channel = 0) const {
│ │ │ │ -
243 return _level->doesVertexFVarTopologyMatch(v, channel);
│ │ │ │ -
244 }
│ │ │ │ -
│ │ │ │ -
245
│ │ │ │ -
│ │ │ │ -
247 bool DoesEdgeFVarTopologyMatch(Index e, int channel = 0) const {
│ │ │ │ -
248 return _level->doesEdgeFVarTopologyMatch(e, channel);
│ │ │ │ -
249 }
│ │ │ │ -
│ │ │ │ -
250
│ │ │ │ -
│ │ │ │ -
252 bool DoesFaceFVarTopologyMatch(Index f, int channel = 0) const {
│ │ │ │ -
253 return _level->doesFaceFVarTopologyMatch(f, channel);
│ │ │ │ -
254 }
│ │ │ │ -
│ │ │ │ +
172 unsigned int isolationLevel:4;
│ │ │ │ +
174 unsigned int secondaryLevel:4;
│ │ │ │ +
176 unsigned int useSingleCreasePatch:1;
│ │ │ │ +
178 unsigned int useInfSharpPatch:1;
│ │ │ │ +
180 unsigned int considerFVarChannels:1;
│ │ │ │ + │ │ │ │ +
184 };
│ │ │ │ +
│ │ │ │ +
185
│ │ │ │ + │ │ │ │ +
193 ConstIndexArray selectedFaces = ConstIndexArray());
│ │ │ │ +
194
│ │ │ │ +
196 AdaptiveOptions GetAdaptiveOptions() const { return _adaptiveOptions; }
│ │ │ │ +
197
│ │ │ │ +
199 void Unrefine();
│ │ │ │ +
200
│ │ │ │ +
201
│ │ │ │ +
203
│ │ │ │ +
205
│ │ │ │ +
207 int GetNumFVarChannels() const;
│ │ │ │ +
208
│ │ │ │ + │ │ │ │ +
211
│ │ │ │ +
213 int GetNumFVarValuesTotal(int channel = 0) const;
│ │ │ │ +
214
│ │ │ │ +
216
│ │ │ │ +
217protected:
│ │ │ │ +
218
│ │ │ │ +
219 //
│ │ │ │ +
220 // Lower level protected methods intended strictly for internal use:
│ │ │ │ +
221 //
│ │ │ │ +
222 template <class MESH>
│ │ │ │ + │ │ │ │ + │ │ │ │ +
225 friend class PatchTableBuilder;
│ │ │ │ +
226 friend class PatchBuilder;
│ │ │ │ +
227 friend class PtexIndices;
│ │ │ │ +
228 template <typename REAL>
│ │ │ │ +
229 friend class PrimvarRefinerReal;
│ │ │ │ +
230
│ │ │ │ +
231 // Copy constructor exposed via the factory class:
│ │ │ │ + │ │ │ │ +
233
│ │ │ │ +
234public:
│ │ │ │ +
235 // Levels and Refinements available internally (avoids need for more friends)
│ │ │ │ +
236 Vtr::internal::Level & getLevel(int l) { return *_levels[l]; }
│ │ │ │ +
237 Vtr::internal::Level const & getLevel(int l) const { return *_levels[l]; }
│ │ │ │ +
238
│ │ │ │ +
239 Vtr::internal::Refinement & getRefinement(int l) { return *_refinements[l]; }
│ │ │ │ +
240 Vtr::internal::Refinement const & getRefinement(int l) const { return *_refinements[l]; }
│ │ │ │ +
241
│ │ │ │ +
242private:
│ │ │ │ +
243 // Not default constructible or copyable:
│ │ │ │ +
244 TopologyRefiner() : _uniformOptions(0), _adaptiveOptions(0) { }
│ │ │ │ +
245 TopologyRefiner & operator=(TopologyRefiner const &) { return *this; }
│ │ │ │ +
246
│ │ │ │ +
247 void selectFeatureAdaptiveComponents(Vtr::internal::SparseSelector& selector,
│ │ │ │ +
248 internal::FeatureMask const & mask,
│ │ │ │ +
249 ConstIndexArray selectedFaces);
│ │ │ │ +
250 void selectLinearIrregularFaces(Vtr::internal::SparseSelector& selector,
│ │ │ │ +
251 ConstIndexArray selectedFaces);
│ │ │ │ +
252
│ │ │ │ +
253 void initializeInventory();
│ │ │ │ +
254 void updateInventory(Vtr::internal::Level const & newLevel);
│ │ │ │
255
│ │ │ │ -
257
│ │ │ │ +
256 void appendLevel(Vtr::internal::Level & newLevel);
│ │ │ │ +
257 void appendRefinement(Vtr::internal::Refinement & newRefinement);
│ │ │ │ +
258 void assembleFarLevels();
│ │ │ │
259
│ │ │ │ -
260
│ │ │ │ -
262 ConstIndexArray GetFaceChildFaces(Index f) const { return _refToChild->getFaceChildFaces(f); }
│ │ │ │ -
263
│ │ │ │ -
265 ConstIndexArray GetFaceChildEdges(Index f) const { return _refToChild->getFaceChildEdges(f); }
│ │ │ │ -
266
│ │ │ │ -
268 ConstIndexArray GetEdgeChildEdges(Index e) const { return _refToChild->getEdgeChildEdges(e); }
│ │ │ │ -
269
│ │ │ │ -
271 Index GetFaceChildVertex( Index f) const { return _refToChild->getFaceChildVertex(f); }
│ │ │ │ -
272
│ │ │ │ -
274 Index GetEdgeChildVertex( Index e) const { return _refToChild->getEdgeChildVertex(e); }
│ │ │ │ -
275
│ │ │ │ -
277 Index GetVertexChildVertex(Index v) const { return _refToChild->getVertexChildVertex(v); }
│ │ │ │ -
278
│ │ │ │ -
280 Index GetFaceParentFace(Index f) const { return _refToParent->getChildFaceParentFace(f); }
│ │ │ │ -
282
│ │ │ │ +
260private:
│ │ │ │ +
261
│ │ │ │ +
262 Sdc::SchemeType _subdivType;
│ │ │ │ +
263 Sdc::Options _subdivOptions;
│ │ │ │ +
264
│ │ │ │ +
265 unsigned int _isUniform : 1;
│ │ │ │ +
266 unsigned int _hasHoles : 1;
│ │ │ │ +
267 unsigned int _hasIrregFaces : 1;
│ │ │ │ +
268 unsigned int _regFaceSize : 3;
│ │ │ │ +
269 unsigned int _maxLevel : 4;
│ │ │ │ +
270
│ │ │ │ +
271 // Options assigned on refinement:
│ │ │ │ +
272 UniformOptions _uniformOptions;
│ │ │ │ +
273 AdaptiveOptions _adaptiveOptions;
│ │ │ │ +
274
│ │ │ │ +
275 // Cumulative properties of all levels:
│ │ │ │ +
276 int _totalVertices;
│ │ │ │ +
277 int _totalEdges;
│ │ │ │ +
278 int _totalFaces;
│ │ │ │ +
279 int _totalFaceVertices;
│ │ │ │ +
280 int _maxValence;
│ │ │ │ +
281
│ │ │ │ +
282 // Note the base level may be shared with another instance
│ │ │ │ +
283 bool _baseLevelOwned;
│ │ │ │
284
│ │ │ │ -
285
│ │ │ │ -
286 bool ValidateTopology() const { return _level->validateTopology(); }
│ │ │ │ -
287 void PrintTopology(bool children = true) const { _level->print((children && _refToChild) ? _refToChild : 0); }
│ │ │ │ -
289
│ │ │ │ +
285 std::vector<Vtr::internal::Level *> _levels;
│ │ │ │ +
286 std::vector<Vtr::internal::Refinement *> _refinements;
│ │ │ │ +
287
│ │ │ │ +
288 std::vector<TopologyLevel> _farLevels;
│ │ │ │ +
289};
│ │ │ │ +
│ │ │ │
290
│ │ │ │ -
291private:
│ │ │ │ -
292 friend class TopologyRefiner;
│ │ │ │ -
293
│ │ │ │ -
294 Vtr::internal::Level const * _level;
│ │ │ │ -
295 Vtr::internal::Refinement const * _refToParent;
│ │ │ │ -
296 Vtr::internal::Refinement const * _refToChild;
│ │ │ │ -
297
│ │ │ │ -
298public:
│ │ │ │ -
299 // Not intended for public use, but required by std::vector, etc...
│ │ │ │ - │ │ │ │ - │ │ │ │ -
302};
│ │ │ │ -
│ │ │ │ -
303
│ │ │ │ -
304} // end namespace Far
│ │ │ │ -
305
│ │ │ │ -
306} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
307using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
308} // end namespace OpenSubdiv
│ │ │ │ -
309
│ │ │ │ -
310#endif /* OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H */
│ │ │ │ - │ │ │ │ - │ │ │ │ -
An interface for accessing data in a specific level of a refined topology hierarchy.
│ │ │ │ -
Index GetFaceParentFace(Index f) const
Return the parent face (in the previous level) of a given face.
│ │ │ │ - │ │ │ │ -
bool IsVertexValenceRegular(Index v) const
Return if the valence of the vertex is regular (must be manifold)
│ │ │ │ -
float GetEdgeSharpness(Index e) const
Return the sharpness assigned a given edge.
│ │ │ │ -
bool DoesFaceFVarTopologyMatch(Index f, int channel=0) const
Return if face-varying topology around a face matches.
│ │ │ │ -
Sdc::Crease::Rule GetVertexRule(Index v) const
Return the subdivision rule assigned a given vertex specific to this level.
│ │ │ │ -
bool IsVertexCorner(Index v) const
Return if the vertex is a corner (only one incident face)
│ │ │ │ -
Index GetVertexChildVertex(Index v) const
Return the child vertex (in the next level) of a given vertex.
│ │ │ │ -
ConstLocalIndexArray GetEdgeFaceLocalIndices(Index e) const
Access the local indices of an edge with respect to its incident faces.
│ │ │ │ -
ConstIndexArray GetFaceChildEdges(Index f) const
Access the child edges (in the next level) of a given face.
│ │ │ │ -
bool DoesEdgeFVarTopologyMatch(Index e, int channel=0) const
Return if face-varying topology across the edge only matches.
│ │ │ │ - │ │ │ │ -
ConstIndexArray GetFaceVertices(Index f) const
Access the vertices incident a given face.
│ │ │ │ -
ConstIndexArray GetFaceChildFaces(Index f) const
Access the child faces (in the next level) of a given face.
│ │ │ │ -
int GetNumEdges() const
Return the number of edges in this level.
│ │ │ │ - │ │ │ │ -
bool IsEdgeNonManifold(Index e) const
Return if the edge is non-manifold.
│ │ │ │ -
bool IsFaceHole(Index f) const
Return if a given face has been tagged as a hole.
│ │ │ │ -
ConstIndexArray GetVertexEdges(Index v) const
Access the edges incident a given vertex.
│ │ │ │ -
Index GetFaceChildVertex(Index f) const
Return the child vertex (in the next level) of a given face.
│ │ │ │ -
bool DoesVertexFVarTopologyMatch(Index v, int channel=0) const
Return if face-varying topology around a vertex matches.
│ │ │ │ -
ConstIndexArray GetEdgeChildEdges(Index e) const
Access the child edges (in the next level) of a given edge.
│ │ │ │ -
bool IsEdgeInfSharp(Index e) const
Return if the edge is infinitely-sharp.
│ │ │ │ -
ConstIndexArray GetVertexFaces(Index v) const
Access the faces incident a given vertex.
│ │ │ │ -
Index FindEdge(Index v0, Index v1) const
Identify the edge matching the given vertex pair.
│ │ │ │ -
ConstLocalIndexArray GetVertexEdgeLocalIndices(Index v) const
Access the local indices of a vertex with respect to its incident edges.
│ │ │ │ -
ConstIndexArray GetFaceEdges(Index f) const
Access the edges incident a given face.
│ │ │ │ -
int GetNumFaces() const
Return the number of faces in this level.
│ │ │ │ -
bool IsVertexBoundary(Index v) const
Return if the vertex is on a boundary (at least one incident boundary edge)
│ │ │ │ -
int GetNumFVarChannels() const
Return the number of face-varying channels (should be same for all levels)
│ │ │ │ -
int GetNumVertices() const
Return the number of vertices in this level.
│ │ │ │ -
ConstIndexArray GetEdgeFaces(Index e) const
Access the faces incident a given edge.
│ │ │ │ -
ConstIndexArray GetFaceFVarValues(Index f, int channel=0) const
Access the face-varying values associated with a particular face.
│ │ │ │ -
ConstIndexArray GetEdgeVertices(Index e) const
Access the vertices incident a given edge.
│ │ │ │ -
bool IsEdgeSemiSharp(Index e) const
Return if the edge is semi-sharp.
│ │ │ │ - │ │ │ │ -
float GetVertexSharpness(Index v) const
Return the sharpness assigned a given vertex.
│ │ │ │ -
Index GetEdgeChildVertex(Index e) const
Return the child vertex (in the next level) of a given edge.
│ │ │ │ -
bool IsVertexSemiSharp(Index v) const
Return if the vertex is semi-sharp.
│ │ │ │ -
int GetNumFaceVertices() const
Return the total number of face-vertices, i.e. the sum of all vertices for all faces.
│ │ │ │ -
bool IsVertexNonManifold(Index v) const
Return if the vertex is non-manifold.
│ │ │ │ -
bool IsEdgeBoundary(Index e) const
Return if the edge is a boundary (only one incident face)
│ │ │ │ -
bool IsVertexInfSharp(Index v) const
Return if the vertex is infinitely-sharp.
│ │ │ │ -
int GetNumFVarValues(int channel=0) const
Return the total number of face-varying values in a particular channel (the upper bound of a face-var...
│ │ │ │ -
ConstLocalIndexArray GetVertexFaceLocalIndices(Index v) const
Access the local indices of a vertex with respect to its incident faces.
│ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ - │ │ │ │ +
291
│ │ │ │ +
292inline int
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
294
│ │ │ │ +
295 return _levels[0]->getNumFVarChannels();
│ │ │ │ +
296}
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
│ │ │ │ + │ │ │ │ +
299
│ │ │ │ +
300 return _levels[0]->getFVarOptions(channel).GetFVarLinearInterpolation();
│ │ │ │ +
301}
│ │ │ │ +
│ │ │ │ +
302
│ │ │ │ +
303} // end namespace Far
│ │ │ │ +
304
│ │ │ │ +
305} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
306using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
307} // end namespace OpenSubdiv
│ │ │ │ +
308
│ │ │ │ +
309#endif /* OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H */
│ │ │ │ + │ │ │ │ +
Vtr::ConstIndexArray ConstIndexArray
Definition types.h:47
│ │ │ │ +
SchemeType
Enumerated type for all subdivision schemes supported by OpenSubdiv.
Definition types.h:37
│ │ │ │ +
Applies refinement operations to generic primvar data.
│ │ │ │ +
Object used to compute and query ptex face indices.
Definition ptexIndices.h:46
│ │ │ │ +
An interface for accessing data in a specific level of a refined topology hierarchy.
│ │ │ │ +
Factory for constructing TopologyRefiners from specific mesh classes.
│ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │ +
TopologyRefiner(TopologyRefiner const &source)
│ │ │ │ +
int GetMaxValence() const
Returns the maximum vertex valence in all levels.
│ │ │ │ +
Vtr::internal::Level const & getLevel(int l) const
│ │ │ │ +
bool HasHoles() const
Returns true if faces have been tagged as holes.
│ │ │ │ +
int GetNumLevels() const
Returns the number of refinement levels.
│ │ │ │ +
int GetNumFVarValuesTotal(int channel=0) const
Returns the total number of face-varying values in all levels.
│ │ │ │ +
Vtr::internal::Refinement const & getRefinement(int l) const
│ │ │ │ +
Sdc::Options GetSchemeOptions() const
Returns the subdivision options.
│ │ │ │ + │ │ │ │ +
bool IsUniform() const
Returns true if uniform refinement has been applied.
│ │ │ │ +
Sdc::SchemeType GetSchemeType() const
Returns the subdivision scheme.
│ │ │ │ +
int GetMaxLevel() const
Returns the highest level of refinement.
│ │ │ │ +
TopologyRefiner(Sdc::SchemeType type, Sdc::Options options=Sdc::Options())
Constructor.
│ │ │ │ +
int GetNumEdgesTotal() const
Returns the total number of edges in all levels.
│ │ │ │ + │ │ │ │ +
int GetNumFVarChannels() const
Returns the number of face-varying channels in the tables.
│ │ │ │ +
UniformOptions GetUniformOptions() const
Returns the options specified on refinement.
│ │ │ │ +
int GetNumFacesTotal() const
Returns the total number of edges in all levels.
│ │ │ │ +
int GetNumFaceVerticesTotal() const
Returns the total number of face vertices in all levels.
│ │ │ │ +
Vtr::internal::Refinement & getRefinement(int l)
│ │ │ │ +
void RefineUniform(UniformOptions options)
Refine the topology uniformly.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
TopologyLevel const & GetLevel(int level) const
Returns a handle to access data specific to a particular level.
│ │ │ │ +
int GetNumVerticesTotal() const
Returns the total number of vertices in all levels.
│ │ │ │ +
void Unrefine()
Unrefine the topology, keeping only the base level.
│ │ │ │ +
AdaptiveOptions GetAdaptiveOptions() const
Returns the options specified on refinement.
│ │ │ │ +
Sdc::Options::FVarLinearInterpolation GetFVarLinearInterpolation(int channel=0) const
Returns the face-varying interpolation rule set for a given channel.
│ │ │ │ +
void RefineAdaptive(AdaptiveOptions options, ConstIndexArray selectedFaces=ConstIndexArray())
Feature Adaptive topology refinement.
│ │ │ │ + │ │ │ │ +
unsigned int refinementLevel
Number of refinement iterations.
│ │ │ │ + │ │ │ │ +
void SetRefinementLevel(int level)
Set uniform refinement level.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
void SetSecondaryLevel(int level)
Set secondary isolation level.
│ │ │ │ +
Private base class of Factories for constructing TopologyRefiners.
│ │ │ │ +
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ + │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -topologyLevel.h │ │ │ │ │ +topologyRefiner.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2015 DreamWorks Animation LLC. │ │ │ │ │ +2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -23,387 +23,441 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H │ │ │ │ │ -25#define OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H │ │ │ │ │ +25#define OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ -29#include "../vtr/level.h" │ │ │ │ │ -30#include "../vtr/refinement.h" │ │ │ │ │ +29#include "../sdc/types.h" │ │ │ │ │ +30#include "../sdc/options.h" │ │ │ │ │ 31#include "../far/types.h" │ │ │ │ │ -32 │ │ │ │ │ -33#include │ │ │ │ │ -34 │ │ │ │ │ -35namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -36namespace OPENSUBDIV_VERSION { │ │ │ │ │ -37 │ │ │ │ │ -38namespace Far { │ │ │ │ │ +32#include "../far/topologyLevel.h" │ │ │ │ │ +33 │ │ │ │ │ +34#include │ │ │ │ │ +35 │ │ │ │ │ +36 │ │ │ │ │ +37namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +38namespace OPENSUBDIV_VERSION { │ │ │ │ │ 39 │ │ │ │ │ -_4_9class _T_o_p_o_l_o_g_y_L_e_v_e_l { │ │ │ │ │ -50 │ │ │ │ │ -51public: │ │ │ │ │ -53 │ │ │ │ │ +_4_0namespace Vtr { namespace internal { class SparseSelector; } } │ │ │ │ │ +41namespace Far { namespace internal { class FeatureMask; } } │ │ │ │ │ +42 │ │ │ │ │ +43namespace Far { │ │ │ │ │ +44 │ │ │ │ │ +45template class PrimvarRefinerReal; │ │ │ │ │ +46template class TopologyRefinerFactory; │ │ │ │ │ +47 │ │ │ │ │ +_5_1class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r { │ │ │ │ │ +52 │ │ │ │ │ +53public: │ │ │ │ │ +54 │ │ │ │ │ +_5_6 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r(_S_d_c_:_:_S_c_h_e_m_e_T_y_p_e type, _S_d_c_:_:_O_p_t_i_o_n_s options = _S_d_c_:_:_O_p_t_i_o_n_s │ │ │ │ │ +()); │ │ │ │ │ +57 │ │ │ │ │ +_5_9 _~_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r(); │ │ │ │ │ 60 │ │ │ │ │ -_6_2 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s() const { return _level->getNumVertices(); } │ │ │ │ │ +_6_2 _S_d_c_:_:_S_c_h_e_m_e_T_y_p_e _G_e_t_S_c_h_e_m_e_T_y_p_e() const { return _subdivType; } │ │ │ │ │ 63 │ │ │ │ │ -_6_5 int _G_e_t_N_u_m_F_a_c_e_s() const { return _level->getNumFaces(); } │ │ │ │ │ +_6_5 _S_d_c_:_:_O_p_t_i_o_n_s _G_e_t_S_c_h_e_m_e_O_p_t_i_o_n_s() const { return _subdivOptions; } │ │ │ │ │ 66 │ │ │ │ │ -_6_8 int _G_e_t_N_u_m_E_d_g_e_s() const { return _level->getNumEdges(); } │ │ │ │ │ +_6_8 bool _I_s_U_n_i_f_o_r_m() const { return _isUniform; } │ │ │ │ │ 69 │ │ │ │ │ -_7_1 int _G_e_t_N_u_m_F_a_c_e_V_e_r_t_i_c_e_s() const { return _level->getNumFaceVerticesTotal(); } │ │ │ │ │ -73 │ │ │ │ │ +_7_1 int _G_e_t_N_u_m_L_e_v_e_l_s() const { return (int)_farLevels.size(); } │ │ │ │ │ +72 │ │ │ │ │ +_7_4 int _G_e_t_M_a_x_L_e_v_e_l() const { return _maxLevel; } │ │ │ │ │ 75 │ │ │ │ │ -90 // │ │ │ │ │ -91 │ │ │ │ │ -_9_3 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_V_e_r_t_i_c_e_s(_I_n_d_e_x f) const { return _level- │ │ │ │ │ ->getFaceVertices(f); } │ │ │ │ │ -94 │ │ │ │ │ -_9_6 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_E_d_g_e_s(_I_n_d_e_x f) const { return _level->getFaceEdges │ │ │ │ │ -(f); } │ │ │ │ │ -97 │ │ │ │ │ -_9_9 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_E_d_g_e_V_e_r_t_i_c_e_s(_I_n_d_e_x e) const { return _level- │ │ │ │ │ ->getEdgeVertices(e); } │ │ │ │ │ -100 │ │ │ │ │ -_1_0_2 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_E_d_g_e_F_a_c_e_s(_I_n_d_e_x e) const { return _level->getEdgeFaces │ │ │ │ │ -(e); } │ │ │ │ │ -103 │ │ │ │ │ -_1_0_5 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_V_e_r_t_e_x_F_a_c_e_s(_I_n_d_e_x v) const { return _level- │ │ │ │ │ ->getVertexFaces(v); } │ │ │ │ │ -106 │ │ │ │ │ -_1_0_8 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_V_e_r_t_e_x_E_d_g_e_s(_I_n_d_e_x v) const { return _level- │ │ │ │ │ ->getVertexEdges(v); } │ │ │ │ │ -109 │ │ │ │ │ -_1_1_1 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y _G_e_t_V_e_r_t_e_x_F_a_c_e_L_o_c_a_l_I_n_d_i_c_e_s(_I_n_d_e_x v) const { return │ │ │ │ │ -_level->getVertexFaceLocalIndices(v); } │ │ │ │ │ -112 │ │ │ │ │ -_1_1_4 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y _G_e_t_V_e_r_t_e_x_E_d_g_e_L_o_c_a_l_I_n_d_i_c_e_s(_I_n_d_e_x v) const { return │ │ │ │ │ -_level->getVertexEdgeLocalIndices(v); } │ │ │ │ │ -115 │ │ │ │ │ -_1_1_7 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y _G_e_t_E_d_g_e_F_a_c_e_L_o_c_a_l_I_n_d_i_c_e_s(_I_n_d_e_x e) const { return │ │ │ │ │ -_level->getEdgeFaceLocalIndices(e); } │ │ │ │ │ -118 │ │ │ │ │ -_1_2_0 _I_n_d_e_x _F_i_n_d_E_d_g_e(_I_n_d_e_x v0, _I_n_d_e_x v1) const { return _level->findEdge(v0, v1); │ │ │ │ │ +_7_7 int _G_e_t_M_a_x_V_a_l_e_n_c_e() const { return _maxValence; } │ │ │ │ │ +78 │ │ │ │ │ +_8_0 bool _H_a_s_H_o_l_e_s() const { return _hasHoles; } │ │ │ │ │ +81 │ │ │ │ │ +_8_3 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s_T_o_t_a_l() const { return _totalVertices; } │ │ │ │ │ +84 │ │ │ │ │ +_8_6 int _G_e_t_N_u_m_E_d_g_e_s_T_o_t_a_l() const { return _totalEdges; } │ │ │ │ │ +87 │ │ │ │ │ +_8_9 int _G_e_t_N_u_m_F_a_c_e_s_T_o_t_a_l() const { return _totalFaces; } │ │ │ │ │ +90 │ │ │ │ │ +_9_2 int _G_e_t_N_u_m_F_a_c_e_V_e_r_t_i_c_e_s_T_o_t_a_l() const { return _totalFaceVertices; } │ │ │ │ │ +93 │ │ │ │ │ +_9_5 _T_o_p_o_l_o_g_y_L_e_v_e_l const & _G_e_t_L_e_v_e_l(int level) const { return _farLevels[level]; │ │ │ │ │ } │ │ │ │ │ -122 │ │ │ │ │ +96 │ │ │ │ │ +98 │ │ │ │ │ +100 │ │ │ │ │ +101 // │ │ │ │ │ +102 // Uniform refinement │ │ │ │ │ +103 // │ │ │ │ │ +104 │ │ │ │ │ +_1_1_8 struct _U_n_i_f_o_r_m_O_p_t_i_o_n_s { │ │ │ │ │ +119 │ │ │ │ │ +_1_2_0 _U_n_i_f_o_r_m_O_p_t_i_o_n_s(int level) : │ │ │ │ │ +121 _r_e_f_i_n_e_m_e_n_t_L_e_v_e_l(level & 0xf), │ │ │ │ │ +122 _o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t(false), │ │ │ │ │ +123 _f_u_l_l_T_o_p_o_l_o_g_y_I_n_L_a_s_t_L_e_v_e_l(false) { } │ │ │ │ │ 124 │ │ │ │ │ -126 │ │ │ │ │ -_1_2_8 bool _I_s_E_d_g_e_N_o_n_M_a_n_i_f_o_l_d(_I_n_d_e_x e) const { return _level->isEdgeNonManifold │ │ │ │ │ -(e); } │ │ │ │ │ -129 │ │ │ │ │ -_1_3_1 bool _I_s_V_e_r_t_e_x_N_o_n_M_a_n_i_f_o_l_d(_I_n_d_e_x v) const { return _level- │ │ │ │ │ ->isVertexNonManifold(v); } │ │ │ │ │ -132 │ │ │ │ │ -_1_3_4 bool _I_s_E_d_g_e_B_o_u_n_d_a_r_y(_I_n_d_e_x e) const { return _level->getEdgeTag │ │ │ │ │ -(e)._boundary; } │ │ │ │ │ +_1_2_6 void _S_e_t_R_e_f_i_n_e_m_e_n_t_L_e_v_e_l(int level) { _r_e_f_i_n_e_m_e_n_t_L_e_v_e_l = level & 0xf; } │ │ │ │ │ +127 │ │ │ │ │ +_1_2_8 unsigned int _r_e_f_i_n_e_m_e_n_t_L_e_v_e_l:4, │ │ │ │ │ +_1_2_9 _o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t:1, │ │ │ │ │ +_1_3_1 _f_u_l_l_T_o_p_o_l_o_g_y_I_n_L_a_s_t_L_e_v_e_l:1; │ │ │ │ │ +134 }; │ │ │ │ │ 135 │ │ │ │ │ -_1_3_7 bool _I_s_V_e_r_t_e_x_B_o_u_n_d_a_r_y(_I_n_d_e_x v) const { return _level->getVertexTag │ │ │ │ │ -(v)._boundary; } │ │ │ │ │ -138 │ │ │ │ │ -_1_4_0 bool _I_s_V_e_r_t_e_x_C_o_r_n_e_r(_I_n_d_e_x v) const { return (_level->getNumVertexFaces(v) │ │ │ │ │ -== 1); } │ │ │ │ │ -141 │ │ │ │ │ -_1_6_2 bool _I_s_V_e_r_t_e_x_V_a_l_e_n_c_e_R_e_g_u_l_a_r(_I_n_d_e_x v) const { return !_level->getVertexTag │ │ │ │ │ -(v)._xordinary || _I_s_V_e_r_t_e_x_C_o_r_n_e_r(v); } │ │ │ │ │ -164 │ │ │ │ │ -166 │ │ │ │ │ +_1_4_6 void _R_e_f_i_n_e_U_n_i_f_o_r_m(_U_n_i_f_o_r_m_O_p_t_i_o_n_s options); │ │ │ │ │ +147 │ │ │ │ │ +_1_4_9 _U_n_i_f_o_r_m_O_p_t_i_o_n_s _G_e_t_U_n_i_f_o_r_m_O_p_t_i_o_n_s() const { return _uniformOptions; } │ │ │ │ │ +150 │ │ │ │ │ +151 // │ │ │ │ │ +152 // Adaptive refinement │ │ │ │ │ +153 // │ │ │ │ │ +154 │ │ │ │ │ +_1_5_6 struct _A_d_a_p_t_i_v_e_O_p_t_i_o_n_s { │ │ │ │ │ +157 │ │ │ │ │ +_1_5_8 _A_d_a_p_t_i_v_e_O_p_t_i_o_n_s(int level) : │ │ │ │ │ +159 _i_s_o_l_a_t_i_o_n_L_e_v_e_l(level & 0xf), │ │ │ │ │ +160 _s_e_c_o_n_d_a_r_y_L_e_v_e_l(0xf), │ │ │ │ │ +161 _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h(false), │ │ │ │ │ +162 _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h(false), │ │ │ │ │ +163 _c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s(false), │ │ │ │ │ +164 _o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t(false) { } │ │ │ │ │ +165 │ │ │ │ │ +_1_6_7 void _S_e_t_I_s_o_l_a_t_i_o_n_L_e_v_e_l(int level) { _i_s_o_l_a_t_i_o_n_L_e_v_e_l = level & 0xf; } │ │ │ │ │ +168 │ │ │ │ │ +_1_7_0 void _S_e_t_S_e_c_o_n_d_a_r_y_L_e_v_e_l(int level) { _s_e_c_o_n_d_a_r_y_L_e_v_e_l = level & 0xf; } │ │ │ │ │ 171 │ │ │ │ │ -_1_7_3 float _G_e_t_E_d_g_e_S_h_a_r_p_n_e_s_s(_I_n_d_e_x e) const { return _level->getEdgeSharpness(e); │ │ │ │ │ +_1_7_2 unsigned int _i_s_o_l_a_t_i_o_n_L_e_v_e_l:4; │ │ │ │ │ +_1_7_4 unsigned int _s_e_c_o_n_d_a_r_y_L_e_v_e_l:4; │ │ │ │ │ +_1_7_6 unsigned int _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h:1; │ │ │ │ │ +_1_7_8 unsigned int _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h:1; │ │ │ │ │ +_1_8_0 unsigned int _c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s:1; │ │ │ │ │ +_1_8_2 unsigned int _o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t:1; │ │ │ │ │ +184 }; │ │ │ │ │ +185 │ │ │ │ │ +_1_9_2 void _R_e_f_i_n_e_A_d_a_p_t_i_v_e(_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s options, │ │ │ │ │ +193 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y selectedFaces = _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y()); │ │ │ │ │ +194 │ │ │ │ │ +_1_9_6 _A_d_a_p_t_i_v_e_O_p_t_i_o_n_s _G_e_t_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s() const { return _adaptiveOptions; } │ │ │ │ │ +197 │ │ │ │ │ +_1_9_9 void _U_n_r_e_f_i_n_e(); │ │ │ │ │ +200 │ │ │ │ │ +201 │ │ │ │ │ +203 │ │ │ │ │ +205 │ │ │ │ │ +207 int _G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const; │ │ │ │ │ +208 │ │ │ │ │ +210 _S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n _G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n(int │ │ │ │ │ +channel = 0) const; │ │ │ │ │ +211 │ │ │ │ │ +_2_1_3 int _G_e_t_N_u_m_F_V_a_r_V_a_l_u_e_s_T_o_t_a_l(int channel = 0) const; │ │ │ │ │ +214 │ │ │ │ │ +216 │ │ │ │ │ +217protected: │ │ │ │ │ +218 │ │ │ │ │ +219 // │ │ │ │ │ +220 // Lower level protected methods intended strictly for internal use: │ │ │ │ │ +221 // │ │ │ │ │ +222 template │ │ │ │ │ +_2_2_3 friend class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y; │ │ │ │ │ +_2_2_4 friend class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y_B_a_s_e; │ │ │ │ │ +_2_2_5 friend class _P_a_t_c_h_T_a_b_l_e_B_u_i_l_d_e_r; │ │ │ │ │ +_2_2_6 friend class _P_a_t_c_h_B_u_i_l_d_e_r; │ │ │ │ │ +_2_2_7 friend class _P_t_e_x_I_n_d_i_c_e_s; │ │ │ │ │ +228 template │ │ │ │ │ +_2_2_9 friend class _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l; │ │ │ │ │ +230 │ │ │ │ │ +231 // Copy constructor exposed via the factory class: │ │ │ │ │ +_2_3_2 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r(_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & source); │ │ │ │ │ +233 │ │ │ │ │ +234public: │ │ │ │ │ +235 // Levels and Refinements available internally (avoids need for more │ │ │ │ │ +friends) │ │ │ │ │ +_2_3_6 Vtr::internal::Level & _g_e_t_L_e_v_e_l(int l) { return *_levels[l]; } │ │ │ │ │ +_2_3_7 Vtr::internal::Level const & _g_e_t_L_e_v_e_l(int l) const { return *_levels[l]; } │ │ │ │ │ +238 │ │ │ │ │ +_2_3_9 Vtr::internal::Refinement & _g_e_t_R_e_f_i_n_e_m_e_n_t(int l) { return *_refinements[l]; │ │ │ │ │ } │ │ │ │ │ -174 │ │ │ │ │ -_1_7_6 float _G_e_t_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s(_I_n_d_e_x v) const { return _level->getVertexSharpness │ │ │ │ │ -(v); } │ │ │ │ │ -177 │ │ │ │ │ -_1_7_9 bool _I_s_E_d_g_e_I_n_f_S_h_a_r_p(_I_n_d_e_x e) const { return _level->getEdgeTag │ │ │ │ │ -(e)._infSharp; } │ │ │ │ │ -180 │ │ │ │ │ -_1_8_2 bool _I_s_V_e_r_t_e_x_I_n_f_S_h_a_r_p(_I_n_d_e_x v) const { return _level->getVertexTag │ │ │ │ │ -(v)._infSharp; } │ │ │ │ │ -183 │ │ │ │ │ -_1_8_5 bool _I_s_E_d_g_e_S_e_m_i_S_h_a_r_p(_I_n_d_e_x e) const { return _level->getEdgeTag │ │ │ │ │ -(e)._semiSharp; } │ │ │ │ │ -186 │ │ │ │ │ -_1_8_8 bool _I_s_V_e_r_t_e_x_S_e_m_i_S_h_a_r_p(_I_n_d_e_x v) const { return _level->getVertexTag │ │ │ │ │ -(v)._semiSharp; } │ │ │ │ │ -189 │ │ │ │ │ -_1_9_1 bool _I_s_F_a_c_e_H_o_l_e(_I_n_d_e_x f) const { return _level->isFaceHole(f); } │ │ │ │ │ -192 │ │ │ │ │ -_1_9_4 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e _G_e_t_V_e_r_t_e_x_R_u_l_e(_I_n_d_e_x v) const { return _level- │ │ │ │ │ ->getVertexRule(v); } │ │ │ │ │ -196 │ │ │ │ │ -198 │ │ │ │ │ -228 │ │ │ │ │ -_2_3_0 int _G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const { return _level->getNumFVarChannels(); } │ │ │ │ │ -231 │ │ │ │ │ -_2_3_4 int _G_e_t_N_u_m_F_V_a_r_V_a_l_u_e_s(int channel = 0) const { return _level- │ │ │ │ │ ->getNumFVarValues(channel); } │ │ │ │ │ -235 │ │ │ │ │ -_2_3_7 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_s(_I_n_d_e_x f, int channel = 0) const { │ │ │ │ │ -238 return _level->getFaceFVarValues(f, channel); │ │ │ │ │ -239 } │ │ │ │ │ -240 │ │ │ │ │ -_2_4_2 bool _D_o_e_s_V_e_r_t_e_x_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h(_I_n_d_e_x v, int channel = 0) const { │ │ │ │ │ -243 return _level->doesVertexFVarTopologyMatch(v, channel); │ │ │ │ │ -244 } │ │ │ │ │ -245 │ │ │ │ │ -_2_4_7 bool _D_o_e_s_E_d_g_e_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h(_I_n_d_e_x e, int channel = 0) const { │ │ │ │ │ -248 return _level->doesEdgeFVarTopologyMatch(e, channel); │ │ │ │ │ -249 } │ │ │ │ │ -250 │ │ │ │ │ -_2_5_2 bool _D_o_e_s_F_a_c_e_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h(_I_n_d_e_x f, int channel = 0) const { │ │ │ │ │ -253 return _level->doesFaceFVarTopologyMatch(f, channel); │ │ │ │ │ -254 } │ │ │ │ │ +_2_4_0 Vtr::internal::Refinement const & _g_e_t_R_e_f_i_n_e_m_e_n_t(int l) const { return │ │ │ │ │ +*_refinements[l]; } │ │ │ │ │ +241 │ │ │ │ │ +242private: │ │ │ │ │ +243 // Not default constructible or copyable: │ │ │ │ │ +244 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r() : _uniformOptions(0), _adaptiveOptions(0) { } │ │ │ │ │ +245 TopologyRefiner & operator=(TopologyRefiner const &) { return *this; } │ │ │ │ │ +246 │ │ │ │ │ +247 void selectFeatureAdaptiveComponents(Vtr::internal::SparseSelector& │ │ │ │ │ +selector, │ │ │ │ │ +248 internal::FeatureMask const & mask, │ │ │ │ │ +249 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y selectedFaces); │ │ │ │ │ +250 void selectLinearIrregularFaces(Vtr::internal::SparseSelector& selector, │ │ │ │ │ +251 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y selectedFaces); │ │ │ │ │ +252 │ │ │ │ │ +253 void initializeInventory(); │ │ │ │ │ +254 void updateInventory(Vtr::internal::Level const & newLevel); │ │ │ │ │ 255 │ │ │ │ │ -257 │ │ │ │ │ +256 void appendLevel(Vtr::internal::Level & newLevel); │ │ │ │ │ +257 void appendRefinement(Vtr::internal::Refinement & newRefinement); │ │ │ │ │ +258 void assembleFarLevels(); │ │ │ │ │ 259 │ │ │ │ │ -260 │ │ │ │ │ -_2_6_2 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_C_h_i_l_d_F_a_c_e_s(_I_n_d_e_x f) const { return _refToChild- │ │ │ │ │ ->getFaceChildFaces(f); } │ │ │ │ │ -263 │ │ │ │ │ -_2_6_5 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_C_h_i_l_d_E_d_g_e_s(_I_n_d_e_x f) const { return _refToChild- │ │ │ │ │ ->getFaceChildEdges(f); } │ │ │ │ │ -266 │ │ │ │ │ -_2_6_8 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_E_d_g_e_C_h_i_l_d_E_d_g_e_s(_I_n_d_e_x e) const { return _refToChild- │ │ │ │ │ ->getEdgeChildEdges(e); } │ │ │ │ │ -269 │ │ │ │ │ -_2_7_1 _I_n_d_e_x _G_e_t_F_a_c_e_C_h_i_l_d_V_e_r_t_e_x( _I_n_d_e_x f) const { return _refToChild- │ │ │ │ │ ->getFaceChildVertex(f); } │ │ │ │ │ -272 │ │ │ │ │ -_2_7_4 _I_n_d_e_x _G_e_t_E_d_g_e_C_h_i_l_d_V_e_r_t_e_x( _I_n_d_e_x e) const { return _refToChild- │ │ │ │ │ ->getEdgeChildVertex(e); } │ │ │ │ │ -275 │ │ │ │ │ -_2_7_7 _I_n_d_e_x _G_e_t_V_e_r_t_e_x_C_h_i_l_d_V_e_r_t_e_x(_I_n_d_e_x v) const { return _refToChild- │ │ │ │ │ ->getVertexChildVertex(v); } │ │ │ │ │ -278 │ │ │ │ │ -_2_8_0 _I_n_d_e_x _G_e_t_F_a_c_e_P_a_r_e_n_t_F_a_c_e(_I_n_d_e_x f) const { return _refToParent- │ │ │ │ │ ->getChildFaceParentFace(f); } │ │ │ │ │ -282 │ │ │ │ │ +260private: │ │ │ │ │ +261 │ │ │ │ │ +262 _S_d_c_:_:_S_c_h_e_m_e_T_y_p_e _subdivType; │ │ │ │ │ +263 _S_d_c_:_:_O_p_t_i_o_n_s _subdivOptions; │ │ │ │ │ +264 │ │ │ │ │ +265 unsigned int _isUniform : 1; │ │ │ │ │ +266 unsigned int _hasHoles : 1; │ │ │ │ │ +267 unsigned int _hasIrregFaces : 1; │ │ │ │ │ +268 unsigned int _regFaceSize : 3; │ │ │ │ │ +269 unsigned int _maxLevel : 4; │ │ │ │ │ +270 │ │ │ │ │ +271 // Options assigned on refinement: │ │ │ │ │ +272 UniformOptions _uniformOptions; │ │ │ │ │ +273 AdaptiveOptions _adaptiveOptions; │ │ │ │ │ +274 │ │ │ │ │ +275 // Cumulative properties of all levels: │ │ │ │ │ +276 int _totalVertices; │ │ │ │ │ +277 int _totalEdges; │ │ │ │ │ +278 int _totalFaces; │ │ │ │ │ +279 int _totalFaceVertices; │ │ │ │ │ +280 int _maxValence; │ │ │ │ │ +281 │ │ │ │ │ +282 // Note the base level may be shared with another instance │ │ │ │ │ +283 bool _baseLevelOwned; │ │ │ │ │ 284 │ │ │ │ │ -285 │ │ │ │ │ -_2_8_6 bool _V_a_l_i_d_a_t_e_T_o_p_o_l_o_g_y() const { return _level->validateTopology(); } │ │ │ │ │ -_2_8_7 void _P_r_i_n_t_T_o_p_o_l_o_g_y(bool children = true) const { _level->print((children && │ │ │ │ │ -_refToChild) ? _refToChild : 0); } │ │ │ │ │ -289 │ │ │ │ │ +285 std::vector _levels; │ │ │ │ │ +286 std::vector _refinements; │ │ │ │ │ +287 │ │ │ │ │ +288 std::vector _farLevels; │ │ │ │ │ +289}; │ │ │ │ │ 290 │ │ │ │ │ -291private: │ │ │ │ │ -_2_9_2 friend class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r; │ │ │ │ │ -293 │ │ │ │ │ -294 Vtr::internal::Level const * _level; │ │ │ │ │ -295 Vtr::internal::Refinement const * _refToParent; │ │ │ │ │ -296 Vtr::internal::Refinement const * _refToChild; │ │ │ │ │ -297 │ │ │ │ │ -298public: │ │ │ │ │ -299 // Not intended for public use, but required by std::vector, etc... │ │ │ │ │ -_3_0_0 _T_o_p_o_l_o_g_y_L_e_v_e_l() { } │ │ │ │ │ -_3_0_1 _~_T_o_p_o_l_o_g_y_L_e_v_e_l() { } │ │ │ │ │ -302}; │ │ │ │ │ -303 │ │ │ │ │ -304} // end namespace Far │ │ │ │ │ -305 │ │ │ │ │ -306} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -307using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -308} // end namespace OpenSubdiv │ │ │ │ │ -309 │ │ │ │ │ -310#endif /* OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H */ │ │ │ │ │ +291 │ │ │ │ │ +292inline int │ │ │ │ │ +_2_9_3_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const { │ │ │ │ │ +294 │ │ │ │ │ +295 return _levels[0]->getNumFVarChannels(); │ │ │ │ │ +296} │ │ │ │ │ +297inline _S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +_2_9_8_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n(int channel) const { │ │ │ │ │ +299 │ │ │ │ │ +300 return _levels[0]->getFVarOptions(channel).GetFVarLinearInterpolation(); │ │ │ │ │ +301} │ │ │ │ │ +302 │ │ │ │ │ +303} // end namespace Far │ │ │ │ │ +304 │ │ │ │ │ +305} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +306using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +307} // end namespace OpenSubdiv │ │ │ │ │ +308 │ │ │ │ │ +309#endif /* OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_I_n_d_e_x │ │ │ │ │ -Vtr::Index Index │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +Vtr::ConstIndexArray ConstIndexArray │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_T_y_p_e │ │ │ │ │ +SchemeType │ │ │ │ │ +Enumerated type for all subdivision schemes supported by OpenSubdiv. │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l │ │ │ │ │ +Applies refinement operations to generic primvar data. │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ +Object used to compute and query ptex face indices. │ │ │ │ │ +DDeeffiinniittiioonn _p_t_e_x_I_n_d_i_c_e_s_._h_:_4_6 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l │ │ │ │ │ An interface for accessing data in a specific level of a refined topology │ │ │ │ │ hierarchy. │ │ │ │ │ DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_4_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_P_a_r_e_n_t_F_a_c_e │ │ │ │ │ -Index GetFaceParentFace(Index f) const │ │ │ │ │ -Return the parent face (in the previous level) of a given face. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_8_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l │ │ │ │ │ -TopologyLevel() │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_3_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_V_a_l_e_n_c_e_R_e_g_u_l_a_r │ │ │ │ │ -bool IsVertexValenceRegular(Index v) const │ │ │ │ │ -Return if the valence of the vertex is regular (must be manifold) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_S_h_a_r_p_n_e_s_s │ │ │ │ │ -float GetEdgeSharpness(Index e) const │ │ │ │ │ -Return the sharpness assigned a given edge. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_D_o_e_s_F_a_c_e_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h │ │ │ │ │ -bool DoesFaceFVarTopologyMatch(Index f, int channel=0) const │ │ │ │ │ -Return if face-varying topology around a face matches. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_5_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_R_u_l_e │ │ │ │ │ -Sdc::Crease::Rule GetVertexRule(Index v) const │ │ │ │ │ -Return the subdivision rule assigned a given vertex specific to this level. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_9_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_C_o_r_n_e_r │ │ │ │ │ -bool IsVertexCorner(Index v) const │ │ │ │ │ -Return if the vertex is a corner (only one incident face) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_C_h_i_l_d_V_e_r_t_e_x │ │ │ │ │ -Index GetVertexChildVertex(Index v) const │ │ │ │ │ -Return the child vertex (in the next level) of a given vertex. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_7_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_F_a_c_e_L_o_c_a_l_I_n_d_i_c_e_s │ │ │ │ │ -ConstLocalIndexArray GetEdgeFaceLocalIndices(Index e) const │ │ │ │ │ -Access the local indices of an edge with respect to its incident faces. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_1_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_C_h_i_l_d_E_d_g_e_s │ │ │ │ │ -ConstIndexArray GetFaceChildEdges(Index f) const │ │ │ │ │ -Access the child edges (in the next level) of a given face. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_D_o_e_s_E_d_g_e_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h │ │ │ │ │ -bool DoesEdgeFVarTopologyMatch(Index e, int channel=0) const │ │ │ │ │ -Return if face-varying topology across the edge only matches. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_4_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_P_r_i_n_t_T_o_p_o_l_o_g_y │ │ │ │ │ -void PrintTopology(bool children=true) const │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_8_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_V_e_r_t_i_c_e_s │ │ │ │ │ -ConstIndexArray GetFaceVertices(Index f) const │ │ │ │ │ -Access the vertices incident a given face. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_9_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_C_h_i_l_d_F_a_c_e_s │ │ │ │ │ -ConstIndexArray GetFaceChildFaces(Index f) const │ │ │ │ │ -Access the child faces (in the next level) of a given face. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_E_d_g_e_s │ │ │ │ │ -int GetNumEdges() const │ │ │ │ │ -Return the number of edges in this level. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_V_a_l_i_d_a_t_e_T_o_p_o_l_o_g_y │ │ │ │ │ -bool ValidateTopology() const │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_E_d_g_e_N_o_n_M_a_n_i_f_o_l_d │ │ │ │ │ -bool IsEdgeNonManifold(Index e) const │ │ │ │ │ -Return if the edge is non-manifold. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_2_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_F_a_c_e_H_o_l_e │ │ │ │ │ -bool IsFaceHole(Index f) const │ │ │ │ │ -Return if a given face has been tagged as a hole. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_9_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_E_d_g_e_s │ │ │ │ │ -ConstIndexArray GetVertexEdges(Index v) const │ │ │ │ │ -Access the edges incident a given vertex. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_0_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_C_h_i_l_d_V_e_r_t_e_x │ │ │ │ │ -Index GetFaceChildVertex(Index f) const │ │ │ │ │ -Return the child vertex (in the next level) of a given face. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_D_o_e_s_V_e_r_t_e_x_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h │ │ │ │ │ -bool DoesVertexFVarTopologyMatch(Index v, int channel=0) const │ │ │ │ │ -Return if face-varying topology around a vertex matches. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_4_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_C_h_i_l_d_E_d_g_e_s │ │ │ │ │ -ConstIndexArray GetEdgeChildEdges(Index e) const │ │ │ │ │ -Access the child edges (in the next level) of a given edge. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_E_d_g_e_I_n_f_S_h_a_r_p │ │ │ │ │ -bool IsEdgeInfSharp(Index e) const │ │ │ │ │ -Return if the edge is infinitely-sharp. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_7_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_F_a_c_e_s │ │ │ │ │ -ConstIndexArray GetVertexFaces(Index v) const │ │ │ │ │ -Access the faces incident a given vertex. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_0_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_F_i_n_d_E_d_g_e │ │ │ │ │ -Index FindEdge(Index v0, Index v1) const │ │ │ │ │ -Identify the edge matching the given vertex pair. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_2_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_E_d_g_e_L_o_c_a_l_I_n_d_i_c_e_s │ │ │ │ │ -ConstLocalIndexArray GetVertexEdgeLocalIndices(Index v) const │ │ │ │ │ -Access the local indices of a vertex with respect to its incident edges. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_1_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_E_d_g_e_s │ │ │ │ │ -ConstIndexArray GetFaceEdges(Index f) const │ │ │ │ │ -Access the edges incident a given face. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_9_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_F_a_c_e_s │ │ │ │ │ -int GetNumFaces() const │ │ │ │ │ -Return the number of faces in this level. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_B_o_u_n_d_a_r_y │ │ │ │ │ -bool IsVertexBoundary(Index v) const │ │ │ │ │ -Return if the vertex is on a boundary (at least one incident boundary edge) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ -int GetNumFVarChannels() const │ │ │ │ │ -Return the number of face-varying channels (should be same for all levels) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_3_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s │ │ │ │ │ -int GetNumVertices() const │ │ │ │ │ -Return the number of vertices in this level. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_F_a_c_e_s │ │ │ │ │ -ConstIndexArray GetEdgeFaces(Index e) const │ │ │ │ │ -Access the faces incident a given edge. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_0_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_s │ │ │ │ │ -ConstIndexArray GetFaceFVarValues(Index f, int channel=0) const │ │ │ │ │ -Access the face-varying values associated with a particular face. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_V_e_r_t_i_c_e_s │ │ │ │ │ -ConstIndexArray GetEdgeVertices(Index e) const │ │ │ │ │ -Access the vertices incident a given edge. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_9_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_E_d_g_e_S_e_m_i_S_h_a_r_p │ │ │ │ │ -bool IsEdgeSemiSharp(Index e) const │ │ │ │ │ -Return if the edge is semi-sharp. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_8_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_~_T_o_p_o_l_o_g_y_L_e_v_e_l │ │ │ │ │ -~TopologyLevel() │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_3_0_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s │ │ │ │ │ -float GetVertexSharpness(Index v) const │ │ │ │ │ -Return the sharpness assigned a given vertex. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_7_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_C_h_i_l_d_V_e_r_t_e_x │ │ │ │ │ -Index GetEdgeChildVertex(Index e) const │ │ │ │ │ -Return the child vertex (in the next level) of a given edge. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_7_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_S_e_m_i_S_h_a_r_p │ │ │ │ │ -bool IsVertexSemiSharp(Index v) const │ │ │ │ │ -Return if the vertex is semi-sharp. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_8_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_F_a_c_e_V_e_r_t_i_c_e_s │ │ │ │ │ -int GetNumFaceVertices() const │ │ │ │ │ -Return the total number of face-vertices, i.e. the sum of all vertices for all │ │ │ │ │ -faces. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_N_o_n_M_a_n_i_f_o_l_d │ │ │ │ │ -bool IsVertexNonManifold(Index v) const │ │ │ │ │ -Return if the vertex is non-manifold. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_3_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_E_d_g_e_B_o_u_n_d_a_r_y │ │ │ │ │ -bool IsEdgeBoundary(Index e) const │ │ │ │ │ -Return if the edge is a boundary (only one incident face) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_3_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_I_n_f_S_h_a_r_p │ │ │ │ │ -bool IsVertexInfSharp(Index v) const │ │ │ │ │ -Return if the vertex is infinitely-sharp. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_8_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_F_V_a_r_V_a_l_u_e_s │ │ │ │ │ -int GetNumFVarValues(int channel=0) const │ │ │ │ │ -Return the total number of face-varying values in a particular channel (the │ │ │ │ │ -upper bound of a face-var... │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_3_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_F_a_c_e_L_o_c_a_l_I_n_d_i_c_e_s │ │ │ │ │ -ConstLocalIndexArray GetVertexFaceLocalIndices(Index v) const │ │ │ │ │ -Access the local indices of a vertex with respect to its incident faces. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_1_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y │ │ │ │ │ +Factory for constructing TopologyRefiners from specific mesh classes. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y_._h_:_7_8 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ Stores topology data for a specified set of refinement options. │ │ │ │ │ DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ -Rule │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ +TopologyRefiner(TopologyRefiner const &source) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_M_a_x_V_a_l_e_n_c_e │ │ │ │ │ +int GetMaxValence() const │ │ │ │ │ +Returns the maximum vertex valence in all levels. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_7_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_g_e_t_L_e_v_e_l │ │ │ │ │ +Vtr::internal::Level const & getLevel(int l) const │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_H_a_s_H_o_l_e_s │ │ │ │ │ +bool HasHoles() const │ │ │ │ │ +Returns true if faces have been tagged as holes. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_8_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_L_e_v_e_l_s │ │ │ │ │ +int GetNumLevels() const │ │ │ │ │ +Returns the number of refinement levels. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_V_a_r_V_a_l_u_e_s_T_o_t_a_l │ │ │ │ │ +int GetNumFVarValuesTotal(int channel=0) const │ │ │ │ │ +Returns the total number of face-varying values in all levels. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_g_e_t_R_e_f_i_n_e_m_e_n_t │ │ │ │ │ +Vtr::internal::Refinement const & getRefinement(int l) const │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_S_c_h_e_m_e_O_p_t_i_o_n_s │ │ │ │ │ +Sdc::Options GetSchemeOptions() const │ │ │ │ │ +Returns the subdivision options. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_g_e_t_L_e_v_e_l │ │ │ │ │ +Vtr::internal::Level & getLevel(int l) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_3_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_I_s_U_n_i_f_o_r_m │ │ │ │ │ +bool IsUniform() const │ │ │ │ │ +Returns true if uniform refinement has been applied. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_S_c_h_e_m_e_T_y_p_e │ │ │ │ │ +Sdc::SchemeType GetSchemeType() const │ │ │ │ │ +Returns the subdivision scheme. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_M_a_x_L_e_v_e_l │ │ │ │ │ +int GetMaxLevel() const │ │ │ │ │ +Returns the highest level of refinement. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_7_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ +TopologyRefiner(Sdc::SchemeType type, Sdc::Options options=Sdc::Options()) │ │ │ │ │ +Constructor. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_E_d_g_e_s_T_o_t_a_l │ │ │ │ │ +int GetNumEdgesTotal() const │ │ │ │ │ +Returns the total number of edges in all levels. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_P_a_t_c_h_B_u_i_l_d_e_r │ │ │ │ │ +friend class PatchBuilder │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_2_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ +int GetNumFVarChannels() const │ │ │ │ │ +Returns the number of face-varying channels in the tables. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_9_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_U_n_i_f_o_r_m_O_p_t_i_o_n_s │ │ │ │ │ +UniformOptions GetUniformOptions() const │ │ │ │ │ +Returns the options specified on refinement. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_4_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_a_c_e_s_T_o_t_a_l │ │ │ │ │ +int GetNumFacesTotal() const │ │ │ │ │ +Returns the total number of edges in all levels. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_8_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_a_c_e_V_e_r_t_i_c_e_s_T_o_t_a_l │ │ │ │ │ +int GetNumFaceVerticesTotal() const │ │ │ │ │ +Returns the total number of face vertices in all levels. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_9_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_g_e_t_R_e_f_i_n_e_m_e_n_t │ │ │ │ │ +Vtr::internal::Refinement & getRefinement(int l) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_3_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_R_e_f_i_n_e_U_n_i_f_o_r_m │ │ │ │ │ +void RefineUniform(UniformOptions options) │ │ │ │ │ +Refine the topology uniformly. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_~_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ +~TopologyRefiner() │ │ │ │ │ +Destructor. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_P_a_t_c_h_T_a_b_l_e_B_u_i_l_d_e_r │ │ │ │ │ +friend class PatchTableBuilder │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_2_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_L_e_v_e_l │ │ │ │ │ +TopologyLevel const & GetLevel(int level) const │ │ │ │ │ +Returns a handle to access data specific to a particular level. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_9_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s_T_o_t_a_l │ │ │ │ │ +int GetNumVerticesTotal() const │ │ │ │ │ +Returns the total number of vertices in all levels. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_8_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_r_e_f_i_n_e │ │ │ │ │ +void Unrefine() │ │ │ │ │ +Unrefine the topology, keeping only the base level. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ +AdaptiveOptions GetAdaptiveOptions() const │ │ │ │ │ +Returns the options specified on refinement. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_9_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_: │ │ │ │ │ +_G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +Sdc::Options::FVarLinearInterpolation GetFVarLinearInterpolation(int channel=0) │ │ │ │ │ +const │ │ │ │ │ +Returns the face-varying interpolation rule set for a given channel. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_R_e_f_i_n_e_A_d_a_p_t_i_v_e │ │ │ │ │ +void RefineAdaptive(AdaptiveOptions options, ConstIndexArray │ │ │ │ │ +selectedFaces=ConstIndexArray()) │ │ │ │ │ +Feature Adaptive topology refinement. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s │ │ │ │ │ +Uniform refinement options. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_1_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_r_e_f_i_n_e_m_e_n_t_L_e_v_e_l │ │ │ │ │ +unsigned int refinementLevel │ │ │ │ │ +Number of refinement iterations. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_2_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t │ │ │ │ │ +unsigned int orderVerticesFromFacesFirst │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_3_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_S_e_t_R_e_f_i_n_e_m_e_n_t_L_e_v_e_l │ │ │ │ │ +void SetRefinementLevel(int level) │ │ │ │ │ +Set uniform refinement level. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_2_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_f_u_l_l_T_o_p_o_l_o_g_y_I_n_L_a_s_t_L_e_v_e_l │ │ │ │ │ +unsigned int fullTopologyInLastLevel │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_3_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_U_n_i_f_o_r_m_O_p_t_i_o_n_s │ │ │ │ │ +UniformOptions(int level) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_2_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ +Adaptive refinement options. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_s_e_c_o_n_d_a_r_y_L_e_v_e_l │ │ │ │ │ +unsigned int secondaryLevel │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t │ │ │ │ │ +unsigned int orderVerticesFromFacesFirst │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ +AdaptiveOptions(int level) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_5_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_i_s_o_l_a_t_i_o_n_L_e_v_e_l │ │ │ │ │ +unsigned int isolationLevel │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h │ │ │ │ │ +unsigned int useSingleCreasePatch │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h │ │ │ │ │ +unsigned int useInfSharpPatch │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_S_e_t_I_s_o_l_a_t_i_o_n_L_e_v_e_l │ │ │ │ │ +void SetIsolationLevel(int level) │ │ │ │ │ +Set isolation level. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_6_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ +unsigned int considerFVarChannels │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_8_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_S_e_t_S_e_c_o_n_d_a_r_y_L_e_v_e_l │ │ │ │ │ +void SetSecondaryLevel(int level) │ │ │ │ │ +Set secondary isolation level. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ +Private base class of Factories for constructing TopologyRefiners. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y_._h_:_4_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s │ │ │ │ │ +All supported options applying to subdivision scheme. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +FVarLinearInterpolation │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_0 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y │ │ │ │ │ DDeeffiinniittiioonn _a_r_r_a_y_._h_:_5_3 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _t_o_p_o_l_o_g_y_L_e_v_e_l_._h │ │ │ │ │ + * _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00710.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/topologyRefiner.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/far/topologyLevel.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,53 +90,44 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
topologyRefiner.h File Reference
│ │ │ │ +
topologyLevel.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/types.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ +#include "../vtr/level.h"
│ │ │ │ +#include "../vtr/refinement.h"
│ │ │ │ #include "../far/types.h"
│ │ │ │ -#include "../far/topologyLevel.h"
│ │ │ │ #include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  TopologyRefiner
 Stores topology data for a specified set of refinement options. More...
 
struct  TopologyRefiner::UniformOptions
 Uniform refinement options. More...
 
struct  TopologyRefiner::AdaptiveOptions
 Adaptive refinement options. More...
class  TopologyLevel
 An interface for accessing data in a specific level of a refined topology hierarchy. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Vtr
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,37 +1,28 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -topologyRefiner.h File Reference │ │ │ │ │ +topologyLevel.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_l_e_v_e_l_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_r_e_f_i_n_e_m_e_n_t_._h" │ │ │ │ │ #include "_._._/_f_a_r_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_f_a_r_/_t_o_p_o_l_o_g_y_L_e_v_e_l_._h" │ │ │ │ │ #include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ - class   _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ -  Stores topology data for a specified set of refinement options. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -struct   _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s │ │ │ │ │ -  Uniform refinement options. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -struct   _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ -  Adaptive refinement options. _M_o_r_e_._._. │ │ │ │ │ +class   _T_o_p_o_l_o_g_y_L_e_v_e_l │ │ │ │ │ +  An interface for accessing data in a specific level of a refined │ │ │ │ │ + topology hierarchy. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r │ │ │ │ │ -  │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h │ │ │ │ │ + * _t_o_p_o_l_o_g_y_L_e_v_e_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00710.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,5 +1,3 @@ │ │ │ │ │ var a00710 = [ │ │ │ │ │ - ["TopologyRefiner", "a01121.html", "a01121"], │ │ │ │ │ - ["UniformOptions", "a01125.html", "a01125"], │ │ │ │ │ - ["AdaptiveOptions", "a01129.html", "a01129"] │ │ │ │ │ + ["TopologyLevel", "a01113.html", "a01113"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00710_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/topologyRefiner.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/far/topologyLevel.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
topologyRefiner.h
│ │ │ │ +
topologyLevel.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2014 DreamWorks Animation LLC.
│ │ │ │ +
2// Copyright 2015 DreamWorks Animation LLC.
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -118,305 +118,228 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24#ifndef OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H
│ │ │ │ -
25#define OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H
│ │ │ │ +
24#ifndef OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H
│ │ │ │ +
25#define OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H
│ │ │ │
26
│ │ │ │
27#include "../version.h"
│ │ │ │
28
│ │ │ │ -
29#include "../sdc/types.h"
│ │ │ │ -
30#include "../sdc/options.h"
│ │ │ │ +
29#include "../vtr/level.h"
│ │ │ │ +
30#include "../vtr/refinement.h"
│ │ │ │
31#include "../far/types.h"
│ │ │ │ -
32#include "../far/topologyLevel.h"
│ │ │ │ -
33
│ │ │ │ -
34#include <vector>
│ │ │ │ -
35
│ │ │ │ -
36
│ │ │ │ -
37namespace OpenSubdiv {
│ │ │ │ -
38namespace OPENSUBDIV_VERSION {
│ │ │ │ +
32
│ │ │ │ +
33#include <vector>
│ │ │ │ +
34
│ │ │ │ +
35namespace OpenSubdiv {
│ │ │ │ +
36namespace OPENSUBDIV_VERSION {
│ │ │ │ +
37
│ │ │ │ +
38namespace Far {
│ │ │ │
39
│ │ │ │ -
40namespace Vtr { namespace internal { class SparseSelector; } }
│ │ │ │ -
41namespace Far { namespace internal { class FeatureMask; } }
│ │ │ │ -
42
│ │ │ │ -
43namespace Far {
│ │ │ │ -
44
│ │ │ │ -
45template <typename REAL> class PrimvarRefinerReal;
│ │ │ │ -
46template <class MESH> class TopologyRefinerFactory;
│ │ │ │ -
47
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
52
│ │ │ │ -
53public:
│ │ │ │ -
54
│ │ │ │ - │ │ │ │ -
57
│ │ │ │ - │ │ │ │ +
│ │ │ │ + │ │ │ │ +
50
│ │ │ │ +
51public:
│ │ │ │ +
53
│ │ │ │
60
│ │ │ │ -
62 Sdc::SchemeType GetSchemeType() const { return _subdivType; }
│ │ │ │ +
62 int GetNumVertices() const { return _level->getNumVertices(); }
│ │ │ │
63
│ │ │ │ -
65 Sdc::Options GetSchemeOptions() const { return _subdivOptions; }
│ │ │ │ +
65 int GetNumFaces() const { return _level->getNumFaces(); }
│ │ │ │
66
│ │ │ │ -
68 bool IsUniform() const { return _isUniform; }
│ │ │ │ +
68 int GetNumEdges() const { return _level->getNumEdges(); }
│ │ │ │
69
│ │ │ │ -
71 int GetNumLevels() const { return (int)_farLevels.size(); }
│ │ │ │ -
72
│ │ │ │ -
74 int GetMaxLevel() const { return _maxLevel; }
│ │ │ │ +
71 int GetNumFaceVertices() const { return _level->getNumFaceVerticesTotal(); }
│ │ │ │ +
73
│ │ │ │
75
│ │ │ │ -
77 int GetMaxValence() const { return _maxValence; }
│ │ │ │ -
78
│ │ │ │ -
80 bool HasHoles() const { return _hasHoles; }
│ │ │ │ -
81
│ │ │ │ -
83 int GetNumVerticesTotal() const { return _totalVertices; }
│ │ │ │ -
84
│ │ │ │ -
86 int GetNumEdgesTotal() const { return _totalEdges; }
│ │ │ │ -
87
│ │ │ │ -
89 int GetNumFacesTotal() const { return _totalFaces; }
│ │ │ │ -
90
│ │ │ │ -
92 int GetNumFaceVerticesTotal() const { return _totalFaceVertices; }
│ │ │ │ -
93
│ │ │ │ -
95 TopologyLevel const & GetLevel(int level) const { return _farLevels[level]; }
│ │ │ │ -
96
│ │ │ │ -
98
│ │ │ │ +
90 //
│ │ │ │ +
91
│ │ │ │ +
93 ConstIndexArray GetFaceVertices(Index f) const { return _level->getFaceVertices(f); }
│ │ │ │ +
94
│ │ │ │ +
96 ConstIndexArray GetFaceEdges(Index f) const { return _level->getFaceEdges(f); }
│ │ │ │ +
97
│ │ │ │ +
99 ConstIndexArray GetEdgeVertices(Index e) const { return _level->getEdgeVertices(e); }
│ │ │ │
100
│ │ │ │ -
101 //
│ │ │ │ -
102 // Uniform refinement
│ │ │ │ -
103 //
│ │ │ │ -
104
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
119
│ │ │ │ -
│ │ │ │ -
120 UniformOptions(int level) :
│ │ │ │ -
121 refinementLevel(level & 0xf),
│ │ │ │ - │ │ │ │ -
123 fullTopologyInLastLevel(false) { }
│ │ │ │ -
│ │ │ │ +
102 ConstIndexArray GetEdgeFaces(Index e) const { return _level->getEdgeFaces(e); }
│ │ │ │ +
103
│ │ │ │ +
105 ConstIndexArray GetVertexFaces(Index v) const { return _level->getVertexFaces(v); }
│ │ │ │ +
106
│ │ │ │ +
108 ConstIndexArray GetVertexEdges(Index v) const { return _level->getVertexEdges(v); }
│ │ │ │ +
109
│ │ │ │ +
111 ConstLocalIndexArray GetVertexFaceLocalIndices(Index v) const { return _level->getVertexFaceLocalIndices(v); }
│ │ │ │ +
112
│ │ │ │ +
114 ConstLocalIndexArray GetVertexEdgeLocalIndices(Index v) const { return _level->getVertexEdgeLocalIndices(v); }
│ │ │ │ +
115
│ │ │ │ +
117 ConstLocalIndexArray GetEdgeFaceLocalIndices(Index e) const { return _level->getEdgeFaceLocalIndices(e); }
│ │ │ │ +
118
│ │ │ │ +
120 Index FindEdge(Index v0, Index v1) const { return _level->findEdge(v0, v1); }
│ │ │ │ +
122
│ │ │ │
124
│ │ │ │ -
126 void SetRefinementLevel(int level) { refinementLevel = level & 0xf; }
│ │ │ │ -
127
│ │ │ │ -
128 unsigned int refinementLevel:4,
│ │ │ │ - │ │ │ │ - │ │ │ │ -
134 };
│ │ │ │ -
│ │ │ │ +
126
│ │ │ │ +
128 bool IsEdgeNonManifold(Index e) const { return _level->isEdgeNonManifold(e); }
│ │ │ │ +
129
│ │ │ │ +
131 bool IsVertexNonManifold(Index v) const { return _level->isVertexNonManifold(v); }
│ │ │ │ +
132
│ │ │ │ +
134 bool IsEdgeBoundary(Index e) const { return _level->getEdgeTag(e)._boundary; }
│ │ │ │
135
│ │ │ │ - │ │ │ │ -
147
│ │ │ │ -
149 UniformOptions GetUniformOptions() const { return _uniformOptions; }
│ │ │ │ -
150
│ │ │ │ -
151 //
│ │ │ │ -
152 // Adaptive refinement
│ │ │ │ -
153 //
│ │ │ │ -
154
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
157
│ │ │ │ -
│ │ │ │ -
158 AdaptiveOptions(int level) :
│ │ │ │ -
159 isolationLevel(level & 0xf),
│ │ │ │ -
160 secondaryLevel(0xf),
│ │ │ │ - │ │ │ │ -
162 useInfSharpPatch(false),
│ │ │ │ - │ │ │ │ - │ │ │ │ -
│ │ │ │ -
165
│ │ │ │ -
167 void SetIsolationLevel(int level) { isolationLevel = level & 0xf; }
│ │ │ │ -
168
│ │ │ │ -
170 void SetSecondaryLevel(int level) { secondaryLevel = level & 0xf; }
│ │ │ │ +
137 bool IsVertexBoundary(Index v) const { return _level->getVertexTag(v)._boundary; }
│ │ │ │ +
138
│ │ │ │ +
140 bool IsVertexCorner(Index v) const { return (_level->getNumVertexFaces(v) == 1); }
│ │ │ │ +
141
│ │ │ │ +
162 bool IsVertexValenceRegular(Index v) const { return !_level->getVertexTag(v)._xordinary || IsVertexCorner(v); }
│ │ │ │ +
164
│ │ │ │ +
166
│ │ │ │
171
│ │ │ │ -
172 unsigned int isolationLevel:4;
│ │ │ │ -
174 unsigned int secondaryLevel:4;
│ │ │ │ -
176 unsigned int useSingleCreasePatch:1;
│ │ │ │ -
178 unsigned int useInfSharpPatch:1;
│ │ │ │ -
180 unsigned int considerFVarChannels:1;
│ │ │ │ - │ │ │ │ -
184 };
│ │ │ │ -
│ │ │ │ -
185
│ │ │ │ - │ │ │ │ -
193 ConstIndexArray selectedFaces = ConstIndexArray());
│ │ │ │ -
194
│ │ │ │ -
196 AdaptiveOptions GetAdaptiveOptions() const { return _adaptiveOptions; }
│ │ │ │ -
197
│ │ │ │ -
199 void Unrefine();
│ │ │ │ -
200
│ │ │ │ -
201
│ │ │ │ -
203
│ │ │ │ -
205
│ │ │ │ -
207 int GetNumFVarChannels() const;
│ │ │ │ -
208
│ │ │ │ - │ │ │ │ -
211
│ │ │ │ -
213 int GetNumFVarValuesTotal(int channel = 0) const;
│ │ │ │ -
214
│ │ │ │ -
216
│ │ │ │ -
217protected:
│ │ │ │ -
218
│ │ │ │ -
219 //
│ │ │ │ -
220 // Lower level protected methods intended strictly for internal use:
│ │ │ │ -
221 //
│ │ │ │ -
222 template <class MESH>
│ │ │ │ - │ │ │ │ - │ │ │ │ -
225 friend class PatchTableBuilder;
│ │ │ │ -
226 friend class PatchBuilder;
│ │ │ │ -
227 friend class PtexIndices;
│ │ │ │ -
228 template <typename REAL>
│ │ │ │ -
229 friend class PrimvarRefinerReal;
│ │ │ │ -
230
│ │ │ │ -
231 // Copy constructor exposed via the factory class:
│ │ │ │ - │ │ │ │ -
233
│ │ │ │ -
234public:
│ │ │ │ -
235 // Levels and Refinements available internally (avoids need for more friends)
│ │ │ │ -
236 Vtr::internal::Level & getLevel(int l) { return *_levels[l]; }
│ │ │ │ -
237 Vtr::internal::Level const & getLevel(int l) const { return *_levels[l]; }
│ │ │ │ -
238
│ │ │ │ -
239 Vtr::internal::Refinement & getRefinement(int l) { return *_refinements[l]; }
│ │ │ │ -
240 Vtr::internal::Refinement const & getRefinement(int l) const { return *_refinements[l]; }
│ │ │ │ -
241
│ │ │ │ -
242private:
│ │ │ │ -
243 // Not default constructible or copyable:
│ │ │ │ -
244 TopologyRefiner() : _uniformOptions(0), _adaptiveOptions(0) { }
│ │ │ │ -
245 TopologyRefiner & operator=(TopologyRefiner const &) { return *this; }
│ │ │ │ -
246
│ │ │ │ -
247 void selectFeatureAdaptiveComponents(Vtr::internal::SparseSelector& selector,
│ │ │ │ -
248 internal::FeatureMask const & mask,
│ │ │ │ -
249 ConstIndexArray selectedFaces);
│ │ │ │ -
250 void selectLinearIrregularFaces(Vtr::internal::SparseSelector& selector,
│ │ │ │ -
251 ConstIndexArray selectedFaces);
│ │ │ │ -
252
│ │ │ │ -
253 void initializeInventory();
│ │ │ │ -
254 void updateInventory(Vtr::internal::Level const & newLevel);
│ │ │ │ +
173 float GetEdgeSharpness(Index e) const { return _level->getEdgeSharpness(e); }
│ │ │ │ +
174
│ │ │ │ +
176 float GetVertexSharpness(Index v) const { return _level->getVertexSharpness(v); }
│ │ │ │ +
177
│ │ │ │ +
179 bool IsEdgeInfSharp(Index e) const { return _level->getEdgeTag(e)._infSharp; }
│ │ │ │ +
180
│ │ │ │ +
182 bool IsVertexInfSharp(Index v) const { return _level->getVertexTag(v)._infSharp; }
│ │ │ │ +
183
│ │ │ │ +
185 bool IsEdgeSemiSharp(Index e) const { return _level->getEdgeTag(e)._semiSharp; }
│ │ │ │ +
186
│ │ │ │ +
188 bool IsVertexSemiSharp(Index v) const { return _level->getVertexTag(v)._semiSharp; }
│ │ │ │ +
189
│ │ │ │ +
191 bool IsFaceHole(Index f) const { return _level->isFaceHole(f); }
│ │ │ │ +
192
│ │ │ │ +
194 Sdc::Crease::Rule GetVertexRule(Index v) const { return _level->getVertexRule(v); }
│ │ │ │ +
196
│ │ │ │ +
198
│ │ │ │ +
228
│ │ │ │ +
230 int GetNumFVarChannels() const { return _level->getNumFVarChannels(); }
│ │ │ │ +
231
│ │ │ │ +
234 int GetNumFVarValues(int channel = 0) const { return _level->getNumFVarValues(channel); }
│ │ │ │ +
235
│ │ │ │ +
│ │ │ │ +
237 ConstIndexArray GetFaceFVarValues(Index f, int channel = 0) const {
│ │ │ │ +
238 return _level->getFaceFVarValues(f, channel);
│ │ │ │ +
239 }
│ │ │ │ +
│ │ │ │ +
240
│ │ │ │ +
│ │ │ │ +
242 bool DoesVertexFVarTopologyMatch(Index v, int channel = 0) const {
│ │ │ │ +
243 return _level->doesVertexFVarTopologyMatch(v, channel);
│ │ │ │ +
244 }
│ │ │ │ +
│ │ │ │ +
245
│ │ │ │ +
│ │ │ │ +
247 bool DoesEdgeFVarTopologyMatch(Index e, int channel = 0) const {
│ │ │ │ +
248 return _level->doesEdgeFVarTopologyMatch(e, channel);
│ │ │ │ +
249 }
│ │ │ │ +
│ │ │ │ +
250
│ │ │ │ +
│ │ │ │ +
252 bool DoesFaceFVarTopologyMatch(Index f, int channel = 0) const {
│ │ │ │ +
253 return _level->doesFaceFVarTopologyMatch(f, channel);
│ │ │ │ +
254 }
│ │ │ │ +
│ │ │ │
255
│ │ │ │ -
256 void appendLevel(Vtr::internal::Level & newLevel);
│ │ │ │ -
257 void appendRefinement(Vtr::internal::Refinement & newRefinement);
│ │ │ │ -
258 void assembleFarLevels();
│ │ │ │ +
257
│ │ │ │
259
│ │ │ │ -
260private:
│ │ │ │ -
261
│ │ │ │ -
262 Sdc::SchemeType _subdivType;
│ │ │ │ -
263 Sdc::Options _subdivOptions;
│ │ │ │ -
264
│ │ │ │ -
265 unsigned int _isUniform : 1;
│ │ │ │ -
266 unsigned int _hasHoles : 1;
│ │ │ │ -
267 unsigned int _hasIrregFaces : 1;
│ │ │ │ -
268 unsigned int _regFaceSize : 3;
│ │ │ │ -
269 unsigned int _maxLevel : 4;
│ │ │ │ -
270
│ │ │ │ -
271 // Options assigned on refinement:
│ │ │ │ -
272 UniformOptions _uniformOptions;
│ │ │ │ -
273 AdaptiveOptions _adaptiveOptions;
│ │ │ │ -
274
│ │ │ │ -
275 // Cumulative properties of all levels:
│ │ │ │ -
276 int _totalVertices;
│ │ │ │ -
277 int _totalEdges;
│ │ │ │ -
278 int _totalFaces;
│ │ │ │ -
279 int _totalFaceVertices;
│ │ │ │ -
280 int _maxValence;
│ │ │ │ -
281
│ │ │ │ -
282 // Note the base level may be shared with another instance
│ │ │ │ -
283 bool _baseLevelOwned;
│ │ │ │ +
260
│ │ │ │ +
262 ConstIndexArray GetFaceChildFaces(Index f) const { return _refToChild->getFaceChildFaces(f); }
│ │ │ │ +
263
│ │ │ │ +
265 ConstIndexArray GetFaceChildEdges(Index f) const { return _refToChild->getFaceChildEdges(f); }
│ │ │ │ +
266
│ │ │ │ +
268 ConstIndexArray GetEdgeChildEdges(Index e) const { return _refToChild->getEdgeChildEdges(e); }
│ │ │ │ +
269
│ │ │ │ +
271 Index GetFaceChildVertex( Index f) const { return _refToChild->getFaceChildVertex(f); }
│ │ │ │ +
272
│ │ │ │ +
274 Index GetEdgeChildVertex( Index e) const { return _refToChild->getEdgeChildVertex(e); }
│ │ │ │ +
275
│ │ │ │ +
277 Index GetVertexChildVertex(Index v) const { return _refToChild->getVertexChildVertex(v); }
│ │ │ │ +
278
│ │ │ │ +
280 Index GetFaceParentFace(Index f) const { return _refToParent->getChildFaceParentFace(f); }
│ │ │ │ +
282
│ │ │ │
284
│ │ │ │ -
285 std::vector<Vtr::internal::Level *> _levels;
│ │ │ │ -
286 std::vector<Vtr::internal::Refinement *> _refinements;
│ │ │ │ -
287
│ │ │ │ -
288 std::vector<TopologyLevel> _farLevels;
│ │ │ │ -
289};
│ │ │ │ -
│ │ │ │ +
285
│ │ │ │ +
286 bool ValidateTopology() const { return _level->validateTopology(); }
│ │ │ │ +
287 void PrintTopology(bool children = true) const { _level->print((children && _refToChild) ? _refToChild : 0); }
│ │ │ │ +
289
│ │ │ │
290
│ │ │ │ -
291
│ │ │ │ -
292inline int
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
294
│ │ │ │ -
295 return _levels[0]->getNumFVarChannels();
│ │ │ │ -
296}
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
│ │ │ │ - │ │ │ │ -
299
│ │ │ │ -
300 return _levels[0]->getFVarOptions(channel).GetFVarLinearInterpolation();
│ │ │ │ -
301}
│ │ │ │ -
│ │ │ │ -
302
│ │ │ │ -
303} // end namespace Far
│ │ │ │ -
304
│ │ │ │ -
305} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
306using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
307} // end namespace OpenSubdiv
│ │ │ │ -
308
│ │ │ │ -
309#endif /* OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H */
│ │ │ │ - │ │ │ │ -
Vtr::ConstIndexArray ConstIndexArray
Definition types.h:47
│ │ │ │ -
SchemeType
Enumerated type for all subdivision schemes supported by OpenSubdiv.
Definition types.h:37
│ │ │ │ -
Applies refinement operations to generic primvar data.
│ │ │ │ -
Object used to compute and query ptex face indices.
Definition ptexIndices.h:46
│ │ │ │ -
An interface for accessing data in a specific level of a refined topology hierarchy.
│ │ │ │ -
Factory for constructing TopologyRefiners from specific mesh classes.
│ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ -
TopologyRefiner(TopologyRefiner const &source)
│ │ │ │ -
int GetMaxValence() const
Returns the maximum vertex valence in all levels.
│ │ │ │ -
Vtr::internal::Level const & getLevel(int l) const
│ │ │ │ -
bool HasHoles() const
Returns true if faces have been tagged as holes.
│ │ │ │ -
int GetNumLevels() const
Returns the number of refinement levels.
│ │ │ │ -
int GetNumFVarValuesTotal(int channel=0) const
Returns the total number of face-varying values in all levels.
│ │ │ │ -
Vtr::internal::Refinement const & getRefinement(int l) const
│ │ │ │ -
Sdc::Options GetSchemeOptions() const
Returns the subdivision options.
│ │ │ │ - │ │ │ │ -
bool IsUniform() const
Returns true if uniform refinement has been applied.
│ │ │ │ -
Sdc::SchemeType GetSchemeType() const
Returns the subdivision scheme.
│ │ │ │ -
int GetMaxLevel() const
Returns the highest level of refinement.
│ │ │ │ -
TopologyRefiner(Sdc::SchemeType type, Sdc::Options options=Sdc::Options())
Constructor.
│ │ │ │ -
int GetNumEdgesTotal() const
Returns the total number of edges in all levels.
│ │ │ │ - │ │ │ │ -
int GetNumFVarChannels() const
Returns the number of face-varying channels in the tables.
│ │ │ │ -
UniformOptions GetUniformOptions() const
Returns the options specified on refinement.
│ │ │ │ -
int GetNumFacesTotal() const
Returns the total number of edges in all levels.
│ │ │ │ -
int GetNumFaceVerticesTotal() const
Returns the total number of face vertices in all levels.
│ │ │ │ -
Vtr::internal::Refinement & getRefinement(int l)
│ │ │ │ -
void RefineUniform(UniformOptions options)
Refine the topology uniformly.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
TopologyLevel const & GetLevel(int level) const
Returns a handle to access data specific to a particular level.
│ │ │ │ -
int GetNumVerticesTotal() const
Returns the total number of vertices in all levels.
│ │ │ │ -
void Unrefine()
Unrefine the topology, keeping only the base level.
│ │ │ │ -
AdaptiveOptions GetAdaptiveOptions() const
Returns the options specified on refinement.
│ │ │ │ -
Sdc::Options::FVarLinearInterpolation GetFVarLinearInterpolation(int channel=0) const
Returns the face-varying interpolation rule set for a given channel.
│ │ │ │ -
void RefineAdaptive(AdaptiveOptions options, ConstIndexArray selectedFaces=ConstIndexArray())
Feature Adaptive topology refinement.
│ │ │ │ - │ │ │ │ -
unsigned int refinementLevel
Number of refinement iterations.
│ │ │ │ - │ │ │ │ -
void SetRefinementLevel(int level)
Set uniform refinement level.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
void SetSecondaryLevel(int level)
Set secondary isolation level.
│ │ │ │ -
Private base class of Factories for constructing TopologyRefiners.
│ │ │ │ -
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ - │ │ │ │ +
291private:
│ │ │ │ +
292 friend class TopologyRefiner;
│ │ │ │ +
293
│ │ │ │ +
294 Vtr::internal::Level const * _level;
│ │ │ │ +
295 Vtr::internal::Refinement const * _refToParent;
│ │ │ │ +
296 Vtr::internal::Refinement const * _refToChild;
│ │ │ │ +
297
│ │ │ │ +
298public:
│ │ │ │ +
299 // Not intended for public use, but required by std::vector, etc...
│ │ │ │ + │ │ │ │ + │ │ │ │ +
302};
│ │ │ │ +
│ │ │ │ +
303
│ │ │ │ +
304} // end namespace Far
│ │ │ │ +
305
│ │ │ │ +
306} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
307using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
308} // end namespace OpenSubdiv
│ │ │ │ +
309
│ │ │ │ +
310#endif /* OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H */
│ │ │ │ + │ │ │ │ + │ │ │ │ +
An interface for accessing data in a specific level of a refined topology hierarchy.
│ │ │ │ +
Index GetFaceParentFace(Index f) const
Return the parent face (in the previous level) of a given face.
│ │ │ │ + │ │ │ │ +
bool IsVertexValenceRegular(Index v) const
Return if the valence of the vertex is regular (must be manifold)
│ │ │ │ +
float GetEdgeSharpness(Index e) const
Return the sharpness assigned a given edge.
│ │ │ │ +
bool DoesFaceFVarTopologyMatch(Index f, int channel=0) const
Return if face-varying topology around a face matches.
│ │ │ │ +
Sdc::Crease::Rule GetVertexRule(Index v) const
Return the subdivision rule assigned a given vertex specific to this level.
│ │ │ │ +
bool IsVertexCorner(Index v) const
Return if the vertex is a corner (only one incident face)
│ │ │ │ +
Index GetVertexChildVertex(Index v) const
Return the child vertex (in the next level) of a given vertex.
│ │ │ │ +
ConstLocalIndexArray GetEdgeFaceLocalIndices(Index e) const
Access the local indices of an edge with respect to its incident faces.
│ │ │ │ +
ConstIndexArray GetFaceChildEdges(Index f) const
Access the child edges (in the next level) of a given face.
│ │ │ │ +
bool DoesEdgeFVarTopologyMatch(Index e, int channel=0) const
Return if face-varying topology across the edge only matches.
│ │ │ │ + │ │ │ │ +
ConstIndexArray GetFaceVertices(Index f) const
Access the vertices incident a given face.
│ │ │ │ +
ConstIndexArray GetFaceChildFaces(Index f) const
Access the child faces (in the next level) of a given face.
│ │ │ │ +
int GetNumEdges() const
Return the number of edges in this level.
│ │ │ │ + │ │ │ │ +
bool IsEdgeNonManifold(Index e) const
Return if the edge is non-manifold.
│ │ │ │ +
bool IsFaceHole(Index f) const
Return if a given face has been tagged as a hole.
│ │ │ │ +
ConstIndexArray GetVertexEdges(Index v) const
Access the edges incident a given vertex.
│ │ │ │ +
Index GetFaceChildVertex(Index f) const
Return the child vertex (in the next level) of a given face.
│ │ │ │ +
bool DoesVertexFVarTopologyMatch(Index v, int channel=0) const
Return if face-varying topology around a vertex matches.
│ │ │ │ +
ConstIndexArray GetEdgeChildEdges(Index e) const
Access the child edges (in the next level) of a given edge.
│ │ │ │ +
bool IsEdgeInfSharp(Index e) const
Return if the edge is infinitely-sharp.
│ │ │ │ +
ConstIndexArray GetVertexFaces(Index v) const
Access the faces incident a given vertex.
│ │ │ │ +
Index FindEdge(Index v0, Index v1) const
Identify the edge matching the given vertex pair.
│ │ │ │ +
ConstLocalIndexArray GetVertexEdgeLocalIndices(Index v) const
Access the local indices of a vertex with respect to its incident edges.
│ │ │ │ +
ConstIndexArray GetFaceEdges(Index f) const
Access the edges incident a given face.
│ │ │ │ +
int GetNumFaces() const
Return the number of faces in this level.
│ │ │ │ +
bool IsVertexBoundary(Index v) const
Return if the vertex is on a boundary (at least one incident boundary edge)
│ │ │ │ +
int GetNumFVarChannels() const
Return the number of face-varying channels (should be same for all levels)
│ │ │ │ +
int GetNumVertices() const
Return the number of vertices in this level.
│ │ │ │ +
ConstIndexArray GetEdgeFaces(Index e) const
Access the faces incident a given edge.
│ │ │ │ +
ConstIndexArray GetFaceFVarValues(Index f, int channel=0) const
Access the face-varying values associated with a particular face.
│ │ │ │ +
ConstIndexArray GetEdgeVertices(Index e) const
Access the vertices incident a given edge.
│ │ │ │ +
bool IsEdgeSemiSharp(Index e) const
Return if the edge is semi-sharp.
│ │ │ │ + │ │ │ │ +
float GetVertexSharpness(Index v) const
Return the sharpness assigned a given vertex.
│ │ │ │ +
Index GetEdgeChildVertex(Index e) const
Return the child vertex (in the next level) of a given edge.
│ │ │ │ +
bool IsVertexSemiSharp(Index v) const
Return if the vertex is semi-sharp.
│ │ │ │ +
int GetNumFaceVertices() const
Return the total number of face-vertices, i.e. the sum of all vertices for all faces.
│ │ │ │ +
bool IsVertexNonManifold(Index v) const
Return if the vertex is non-manifold.
│ │ │ │ +
bool IsEdgeBoundary(Index e) const
Return if the edge is a boundary (only one incident face)
│ │ │ │ +
bool IsVertexInfSharp(Index v) const
Return if the vertex is infinitely-sharp.
│ │ │ │ +
int GetNumFVarValues(int channel=0) const
Return the total number of face-varying values in a particular channel (the upper bound of a face-var...
│ │ │ │ +
ConstLocalIndexArray GetVertexFaceLocalIndices(Index v) const
Access the local indices of a vertex with respect to its incident faces.
│ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │ + │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -topologyRefiner.h │ │ │ │ │ +topologyLevel.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ +2// Copyright 2015 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -23,441 +23,387 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H │ │ │ │ │ -25#define OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H │ │ │ │ │ +25#define OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ -29#include "../sdc/types.h" │ │ │ │ │ -30#include "../sdc/options.h" │ │ │ │ │ +29#include "../vtr/level.h" │ │ │ │ │ +30#include "../vtr/refinement.h" │ │ │ │ │ 31#include "../far/types.h" │ │ │ │ │ -32#include "../far/topologyLevel.h" │ │ │ │ │ -33 │ │ │ │ │ -34#include │ │ │ │ │ -35 │ │ │ │ │ -36 │ │ │ │ │ -37namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -38namespace OPENSUBDIV_VERSION { │ │ │ │ │ +32 │ │ │ │ │ +33#include │ │ │ │ │ +34 │ │ │ │ │ +35namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +36namespace OPENSUBDIV_VERSION { │ │ │ │ │ +37 │ │ │ │ │ +38namespace Far { │ │ │ │ │ 39 │ │ │ │ │ -_4_0namespace Vtr { namespace internal { class SparseSelector; } } │ │ │ │ │ -41namespace Far { namespace internal { class FeatureMask; } } │ │ │ │ │ -42 │ │ │ │ │ -43namespace Far { │ │ │ │ │ -44 │ │ │ │ │ -45template class PrimvarRefinerReal; │ │ │ │ │ -46template class TopologyRefinerFactory; │ │ │ │ │ -47 │ │ │ │ │ -_5_1class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r { │ │ │ │ │ -52 │ │ │ │ │ -53public: │ │ │ │ │ -54 │ │ │ │ │ -_5_6 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r(_S_d_c_:_:_S_c_h_e_m_e_T_y_p_e type, _S_d_c_:_:_O_p_t_i_o_n_s options = _S_d_c_:_:_O_p_t_i_o_n_s │ │ │ │ │ -()); │ │ │ │ │ -57 │ │ │ │ │ -_5_9 _~_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r(); │ │ │ │ │ +_4_9class _T_o_p_o_l_o_g_y_L_e_v_e_l { │ │ │ │ │ +50 │ │ │ │ │ +51public: │ │ │ │ │ +53 │ │ │ │ │ 60 │ │ │ │ │ -_6_2 _S_d_c_:_:_S_c_h_e_m_e_T_y_p_e _G_e_t_S_c_h_e_m_e_T_y_p_e() const { return _subdivType; } │ │ │ │ │ +_6_2 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s() const { return _level->getNumVertices(); } │ │ │ │ │ 63 │ │ │ │ │ -_6_5 _S_d_c_:_:_O_p_t_i_o_n_s _G_e_t_S_c_h_e_m_e_O_p_t_i_o_n_s() const { return _subdivOptions; } │ │ │ │ │ +_6_5 int _G_e_t_N_u_m_F_a_c_e_s() const { return _level->getNumFaces(); } │ │ │ │ │ 66 │ │ │ │ │ -_6_8 bool _I_s_U_n_i_f_o_r_m() const { return _isUniform; } │ │ │ │ │ +_6_8 int _G_e_t_N_u_m_E_d_g_e_s() const { return _level->getNumEdges(); } │ │ │ │ │ 69 │ │ │ │ │ -_7_1 int _G_e_t_N_u_m_L_e_v_e_l_s() const { return (int)_farLevels.size(); } │ │ │ │ │ -72 │ │ │ │ │ -_7_4 int _G_e_t_M_a_x_L_e_v_e_l() const { return _maxLevel; } │ │ │ │ │ +_7_1 int _G_e_t_N_u_m_F_a_c_e_V_e_r_t_i_c_e_s() const { return _level->getNumFaceVerticesTotal(); } │ │ │ │ │ +73 │ │ │ │ │ 75 │ │ │ │ │ -_7_7 int _G_e_t_M_a_x_V_a_l_e_n_c_e() const { return _maxValence; } │ │ │ │ │ -78 │ │ │ │ │ -_8_0 bool _H_a_s_H_o_l_e_s() const { return _hasHoles; } │ │ │ │ │ -81 │ │ │ │ │ -_8_3 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s_T_o_t_a_l() const { return _totalVertices; } │ │ │ │ │ -84 │ │ │ │ │ -_8_6 int _G_e_t_N_u_m_E_d_g_e_s_T_o_t_a_l() const { return _totalEdges; } │ │ │ │ │ -87 │ │ │ │ │ -_8_9 int _G_e_t_N_u_m_F_a_c_e_s_T_o_t_a_l() const { return _totalFaces; } │ │ │ │ │ -90 │ │ │ │ │ -_9_2 int _G_e_t_N_u_m_F_a_c_e_V_e_r_t_i_c_e_s_T_o_t_a_l() const { return _totalFaceVertices; } │ │ │ │ │ -93 │ │ │ │ │ -_9_5 _T_o_p_o_l_o_g_y_L_e_v_e_l const & _G_e_t_L_e_v_e_l(int level) const { return _farLevels[level]; │ │ │ │ │ -} │ │ │ │ │ -96 │ │ │ │ │ -98 │ │ │ │ │ +90 // │ │ │ │ │ +91 │ │ │ │ │ +_9_3 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_V_e_r_t_i_c_e_s(_I_n_d_e_x f) const { return _level- │ │ │ │ │ +>getFaceVertices(f); } │ │ │ │ │ +94 │ │ │ │ │ +_9_6 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_E_d_g_e_s(_I_n_d_e_x f) const { return _level->getFaceEdges │ │ │ │ │ +(f); } │ │ │ │ │ +97 │ │ │ │ │ +_9_9 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_E_d_g_e_V_e_r_t_i_c_e_s(_I_n_d_e_x e) const { return _level- │ │ │ │ │ +>getEdgeVertices(e); } │ │ │ │ │ 100 │ │ │ │ │ -101 // │ │ │ │ │ -102 // Uniform refinement │ │ │ │ │ -103 // │ │ │ │ │ -104 │ │ │ │ │ -_1_1_8 struct _U_n_i_f_o_r_m_O_p_t_i_o_n_s { │ │ │ │ │ -119 │ │ │ │ │ -_1_2_0 _U_n_i_f_o_r_m_O_p_t_i_o_n_s(int level) : │ │ │ │ │ -121 _r_e_f_i_n_e_m_e_n_t_L_e_v_e_l(level & 0xf), │ │ │ │ │ -122 _o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t(false), │ │ │ │ │ -123 _f_u_l_l_T_o_p_o_l_o_g_y_I_n_L_a_s_t_L_e_v_e_l(false) { } │ │ │ │ │ +_1_0_2 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_E_d_g_e_F_a_c_e_s(_I_n_d_e_x e) const { return _level->getEdgeFaces │ │ │ │ │ +(e); } │ │ │ │ │ +103 │ │ │ │ │ +_1_0_5 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_V_e_r_t_e_x_F_a_c_e_s(_I_n_d_e_x v) const { return _level- │ │ │ │ │ +>getVertexFaces(v); } │ │ │ │ │ +106 │ │ │ │ │ +_1_0_8 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_V_e_r_t_e_x_E_d_g_e_s(_I_n_d_e_x v) const { return _level- │ │ │ │ │ +>getVertexEdges(v); } │ │ │ │ │ +109 │ │ │ │ │ +_1_1_1 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y _G_e_t_V_e_r_t_e_x_F_a_c_e_L_o_c_a_l_I_n_d_i_c_e_s(_I_n_d_e_x v) const { return │ │ │ │ │ +_level->getVertexFaceLocalIndices(v); } │ │ │ │ │ +112 │ │ │ │ │ +_1_1_4 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y _G_e_t_V_e_r_t_e_x_E_d_g_e_L_o_c_a_l_I_n_d_i_c_e_s(_I_n_d_e_x v) const { return │ │ │ │ │ +_level->getVertexEdgeLocalIndices(v); } │ │ │ │ │ +115 │ │ │ │ │ +_1_1_7 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y _G_e_t_E_d_g_e_F_a_c_e_L_o_c_a_l_I_n_d_i_c_e_s(_I_n_d_e_x e) const { return │ │ │ │ │ +_level->getEdgeFaceLocalIndices(e); } │ │ │ │ │ +118 │ │ │ │ │ +_1_2_0 _I_n_d_e_x _F_i_n_d_E_d_g_e(_I_n_d_e_x v0, _I_n_d_e_x v1) const { return _level->findEdge(v0, v1); │ │ │ │ │ +} │ │ │ │ │ +122 │ │ │ │ │ 124 │ │ │ │ │ -_1_2_6 void _S_e_t_R_e_f_i_n_e_m_e_n_t_L_e_v_e_l(int level) { _r_e_f_i_n_e_m_e_n_t_L_e_v_e_l = level & 0xf; } │ │ │ │ │ -127 │ │ │ │ │ -_1_2_8 unsigned int _r_e_f_i_n_e_m_e_n_t_L_e_v_e_l:4, │ │ │ │ │ -_1_2_9 _o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t:1, │ │ │ │ │ -_1_3_1 _f_u_l_l_T_o_p_o_l_o_g_y_I_n_L_a_s_t_L_e_v_e_l:1; │ │ │ │ │ -134 }; │ │ │ │ │ +126 │ │ │ │ │ +_1_2_8 bool _I_s_E_d_g_e_N_o_n_M_a_n_i_f_o_l_d(_I_n_d_e_x e) const { return _level->isEdgeNonManifold │ │ │ │ │ +(e); } │ │ │ │ │ +129 │ │ │ │ │ +_1_3_1 bool _I_s_V_e_r_t_e_x_N_o_n_M_a_n_i_f_o_l_d(_I_n_d_e_x v) const { return _level- │ │ │ │ │ +>isVertexNonManifold(v); } │ │ │ │ │ +132 │ │ │ │ │ +_1_3_4 bool _I_s_E_d_g_e_B_o_u_n_d_a_r_y(_I_n_d_e_x e) const { return _level->getEdgeTag │ │ │ │ │ +(e)._boundary; } │ │ │ │ │ 135 │ │ │ │ │ -_1_4_6 void _R_e_f_i_n_e_U_n_i_f_o_r_m(_U_n_i_f_o_r_m_O_p_t_i_o_n_s options); │ │ │ │ │ -147 │ │ │ │ │ -_1_4_9 _U_n_i_f_o_r_m_O_p_t_i_o_n_s _G_e_t_U_n_i_f_o_r_m_O_p_t_i_o_n_s() const { return _uniformOptions; } │ │ │ │ │ -150 │ │ │ │ │ -151 // │ │ │ │ │ -152 // Adaptive refinement │ │ │ │ │ -153 // │ │ │ │ │ -154 │ │ │ │ │ -_1_5_6 struct _A_d_a_p_t_i_v_e_O_p_t_i_o_n_s { │ │ │ │ │ -157 │ │ │ │ │ -_1_5_8 _A_d_a_p_t_i_v_e_O_p_t_i_o_n_s(int level) : │ │ │ │ │ -159 _i_s_o_l_a_t_i_o_n_L_e_v_e_l(level & 0xf), │ │ │ │ │ -160 _s_e_c_o_n_d_a_r_y_L_e_v_e_l(0xf), │ │ │ │ │ -161 _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h(false), │ │ │ │ │ -162 _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h(false), │ │ │ │ │ -163 _c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s(false), │ │ │ │ │ -164 _o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t(false) { } │ │ │ │ │ -165 │ │ │ │ │ -_1_6_7 void _S_e_t_I_s_o_l_a_t_i_o_n_L_e_v_e_l(int level) { _i_s_o_l_a_t_i_o_n_L_e_v_e_l = level & 0xf; } │ │ │ │ │ -168 │ │ │ │ │ -_1_7_0 void _S_e_t_S_e_c_o_n_d_a_r_y_L_e_v_e_l(int level) { _s_e_c_o_n_d_a_r_y_L_e_v_e_l = level & 0xf; } │ │ │ │ │ +_1_3_7 bool _I_s_V_e_r_t_e_x_B_o_u_n_d_a_r_y(_I_n_d_e_x v) const { return _level->getVertexTag │ │ │ │ │ +(v)._boundary; } │ │ │ │ │ +138 │ │ │ │ │ +_1_4_0 bool _I_s_V_e_r_t_e_x_C_o_r_n_e_r(_I_n_d_e_x v) const { return (_level->getNumVertexFaces(v) │ │ │ │ │ +== 1); } │ │ │ │ │ +141 │ │ │ │ │ +_1_6_2 bool _I_s_V_e_r_t_e_x_V_a_l_e_n_c_e_R_e_g_u_l_a_r(_I_n_d_e_x v) const { return !_level->getVertexTag │ │ │ │ │ +(v)._xordinary || _I_s_V_e_r_t_e_x_C_o_r_n_e_r(v); } │ │ │ │ │ +164 │ │ │ │ │ +166 │ │ │ │ │ 171 │ │ │ │ │ -_1_7_2 unsigned int _i_s_o_l_a_t_i_o_n_L_e_v_e_l:4; │ │ │ │ │ -_1_7_4 unsigned int _s_e_c_o_n_d_a_r_y_L_e_v_e_l:4; │ │ │ │ │ -_1_7_6 unsigned int _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h:1; │ │ │ │ │ -_1_7_8 unsigned int _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h:1; │ │ │ │ │ -_1_8_0 unsigned int _c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s:1; │ │ │ │ │ -_1_8_2 unsigned int _o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t:1; │ │ │ │ │ -184 }; │ │ │ │ │ -185 │ │ │ │ │ -_1_9_2 void _R_e_f_i_n_e_A_d_a_p_t_i_v_e(_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s options, │ │ │ │ │ -193 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y selectedFaces = _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y()); │ │ │ │ │ -194 │ │ │ │ │ -_1_9_6 _A_d_a_p_t_i_v_e_O_p_t_i_o_n_s _G_e_t_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s() const { return _adaptiveOptions; } │ │ │ │ │ -197 │ │ │ │ │ -_1_9_9 void _U_n_r_e_f_i_n_e(); │ │ │ │ │ -200 │ │ │ │ │ -201 │ │ │ │ │ -203 │ │ │ │ │ -205 │ │ │ │ │ -207 int _G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const; │ │ │ │ │ -208 │ │ │ │ │ -210 _S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n _G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n(int │ │ │ │ │ -channel = 0) const; │ │ │ │ │ -211 │ │ │ │ │ -_2_1_3 int _G_e_t_N_u_m_F_V_a_r_V_a_l_u_e_s_T_o_t_a_l(int channel = 0) const; │ │ │ │ │ -214 │ │ │ │ │ -216 │ │ │ │ │ -217protected: │ │ │ │ │ -218 │ │ │ │ │ -219 // │ │ │ │ │ -220 // Lower level protected methods intended strictly for internal use: │ │ │ │ │ -221 // │ │ │ │ │ -222 template │ │ │ │ │ -_2_2_3 friend class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y; │ │ │ │ │ -_2_2_4 friend class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y_B_a_s_e; │ │ │ │ │ -_2_2_5 friend class _P_a_t_c_h_T_a_b_l_e_B_u_i_l_d_e_r; │ │ │ │ │ -_2_2_6 friend class _P_a_t_c_h_B_u_i_l_d_e_r; │ │ │ │ │ -_2_2_7 friend class _P_t_e_x_I_n_d_i_c_e_s; │ │ │ │ │ -228 template │ │ │ │ │ -_2_2_9 friend class _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l; │ │ │ │ │ -230 │ │ │ │ │ -231 // Copy constructor exposed via the factory class: │ │ │ │ │ -_2_3_2 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r(_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & source); │ │ │ │ │ -233 │ │ │ │ │ -234public: │ │ │ │ │ -235 // Levels and Refinements available internally (avoids need for more │ │ │ │ │ -friends) │ │ │ │ │ -_2_3_6 Vtr::internal::Level & _g_e_t_L_e_v_e_l(int l) { return *_levels[l]; } │ │ │ │ │ -_2_3_7 Vtr::internal::Level const & _g_e_t_L_e_v_e_l(int l) const { return *_levels[l]; } │ │ │ │ │ -238 │ │ │ │ │ -_2_3_9 Vtr::internal::Refinement & _g_e_t_R_e_f_i_n_e_m_e_n_t(int l) { return *_refinements[l]; │ │ │ │ │ +_1_7_3 float _G_e_t_E_d_g_e_S_h_a_r_p_n_e_s_s(_I_n_d_e_x e) const { return _level->getEdgeSharpness(e); │ │ │ │ │ } │ │ │ │ │ -_2_4_0 Vtr::internal::Refinement const & _g_e_t_R_e_f_i_n_e_m_e_n_t(int l) const { return │ │ │ │ │ -*_refinements[l]; } │ │ │ │ │ -241 │ │ │ │ │ -242private: │ │ │ │ │ -243 // Not default constructible or copyable: │ │ │ │ │ -244 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r() : _uniformOptions(0), _adaptiveOptions(0) { } │ │ │ │ │ -245 TopologyRefiner & operator=(TopologyRefiner const &) { return *this; } │ │ │ │ │ -246 │ │ │ │ │ -247 void selectFeatureAdaptiveComponents(Vtr::internal::SparseSelector& │ │ │ │ │ -selector, │ │ │ │ │ -248 internal::FeatureMask const & mask, │ │ │ │ │ -249 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y selectedFaces); │ │ │ │ │ -250 void selectLinearIrregularFaces(Vtr::internal::SparseSelector& selector, │ │ │ │ │ -251 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y selectedFaces); │ │ │ │ │ -252 │ │ │ │ │ -253 void initializeInventory(); │ │ │ │ │ -254 void updateInventory(Vtr::internal::Level const & newLevel); │ │ │ │ │ +174 │ │ │ │ │ +_1_7_6 float _G_e_t_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s(_I_n_d_e_x v) const { return _level->getVertexSharpness │ │ │ │ │ +(v); } │ │ │ │ │ +177 │ │ │ │ │ +_1_7_9 bool _I_s_E_d_g_e_I_n_f_S_h_a_r_p(_I_n_d_e_x e) const { return _level->getEdgeTag │ │ │ │ │ +(e)._infSharp; } │ │ │ │ │ +180 │ │ │ │ │ +_1_8_2 bool _I_s_V_e_r_t_e_x_I_n_f_S_h_a_r_p(_I_n_d_e_x v) const { return _level->getVertexTag │ │ │ │ │ +(v)._infSharp; } │ │ │ │ │ +183 │ │ │ │ │ +_1_8_5 bool _I_s_E_d_g_e_S_e_m_i_S_h_a_r_p(_I_n_d_e_x e) const { return _level->getEdgeTag │ │ │ │ │ +(e)._semiSharp; } │ │ │ │ │ +186 │ │ │ │ │ +_1_8_8 bool _I_s_V_e_r_t_e_x_S_e_m_i_S_h_a_r_p(_I_n_d_e_x v) const { return _level->getVertexTag │ │ │ │ │ +(v)._semiSharp; } │ │ │ │ │ +189 │ │ │ │ │ +_1_9_1 bool _I_s_F_a_c_e_H_o_l_e(_I_n_d_e_x f) const { return _level->isFaceHole(f); } │ │ │ │ │ +192 │ │ │ │ │ +_1_9_4 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e _G_e_t_V_e_r_t_e_x_R_u_l_e(_I_n_d_e_x v) const { return _level- │ │ │ │ │ +>getVertexRule(v); } │ │ │ │ │ +196 │ │ │ │ │ +198 │ │ │ │ │ +228 │ │ │ │ │ +_2_3_0 int _G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const { return _level->getNumFVarChannels(); } │ │ │ │ │ +231 │ │ │ │ │ +_2_3_4 int _G_e_t_N_u_m_F_V_a_r_V_a_l_u_e_s(int channel = 0) const { return _level- │ │ │ │ │ +>getNumFVarValues(channel); } │ │ │ │ │ +235 │ │ │ │ │ +_2_3_7 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_s(_I_n_d_e_x f, int channel = 0) const { │ │ │ │ │ +238 return _level->getFaceFVarValues(f, channel); │ │ │ │ │ +239 } │ │ │ │ │ +240 │ │ │ │ │ +_2_4_2 bool _D_o_e_s_V_e_r_t_e_x_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h(_I_n_d_e_x v, int channel = 0) const { │ │ │ │ │ +243 return _level->doesVertexFVarTopologyMatch(v, channel); │ │ │ │ │ +244 } │ │ │ │ │ +245 │ │ │ │ │ +_2_4_7 bool _D_o_e_s_E_d_g_e_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h(_I_n_d_e_x e, int channel = 0) const { │ │ │ │ │ +248 return _level->doesEdgeFVarTopologyMatch(e, channel); │ │ │ │ │ +249 } │ │ │ │ │ +250 │ │ │ │ │ +_2_5_2 bool _D_o_e_s_F_a_c_e_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h(_I_n_d_e_x f, int channel = 0) const { │ │ │ │ │ +253 return _level->doesFaceFVarTopologyMatch(f, channel); │ │ │ │ │ +254 } │ │ │ │ │ 255 │ │ │ │ │ -256 void appendLevel(Vtr::internal::Level & newLevel); │ │ │ │ │ -257 void appendRefinement(Vtr::internal::Refinement & newRefinement); │ │ │ │ │ -258 void assembleFarLevels(); │ │ │ │ │ +257 │ │ │ │ │ 259 │ │ │ │ │ -260private: │ │ │ │ │ -261 │ │ │ │ │ -262 _S_d_c_:_:_S_c_h_e_m_e_T_y_p_e _subdivType; │ │ │ │ │ -263 _S_d_c_:_:_O_p_t_i_o_n_s _subdivOptions; │ │ │ │ │ -264 │ │ │ │ │ -265 unsigned int _isUniform : 1; │ │ │ │ │ -266 unsigned int _hasHoles : 1; │ │ │ │ │ -267 unsigned int _hasIrregFaces : 1; │ │ │ │ │ -268 unsigned int _regFaceSize : 3; │ │ │ │ │ -269 unsigned int _maxLevel : 4; │ │ │ │ │ -270 │ │ │ │ │ -271 // Options assigned on refinement: │ │ │ │ │ -272 UniformOptions _uniformOptions; │ │ │ │ │ -273 AdaptiveOptions _adaptiveOptions; │ │ │ │ │ -274 │ │ │ │ │ -275 // Cumulative properties of all levels: │ │ │ │ │ -276 int _totalVertices; │ │ │ │ │ -277 int _totalEdges; │ │ │ │ │ -278 int _totalFaces; │ │ │ │ │ -279 int _totalFaceVertices; │ │ │ │ │ -280 int _maxValence; │ │ │ │ │ -281 │ │ │ │ │ -282 // Note the base level may be shared with another instance │ │ │ │ │ -283 bool _baseLevelOwned; │ │ │ │ │ +260 │ │ │ │ │ +_2_6_2 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_C_h_i_l_d_F_a_c_e_s(_I_n_d_e_x f) const { return _refToChild- │ │ │ │ │ +>getFaceChildFaces(f); } │ │ │ │ │ +263 │ │ │ │ │ +_2_6_5 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_F_a_c_e_C_h_i_l_d_E_d_g_e_s(_I_n_d_e_x f) const { return _refToChild- │ │ │ │ │ +>getFaceChildEdges(f); } │ │ │ │ │ +266 │ │ │ │ │ +_2_6_8 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y _G_e_t_E_d_g_e_C_h_i_l_d_E_d_g_e_s(_I_n_d_e_x e) const { return _refToChild- │ │ │ │ │ +>getEdgeChildEdges(e); } │ │ │ │ │ +269 │ │ │ │ │ +_2_7_1 _I_n_d_e_x _G_e_t_F_a_c_e_C_h_i_l_d_V_e_r_t_e_x( _I_n_d_e_x f) const { return _refToChild- │ │ │ │ │ +>getFaceChildVertex(f); } │ │ │ │ │ +272 │ │ │ │ │ +_2_7_4 _I_n_d_e_x _G_e_t_E_d_g_e_C_h_i_l_d_V_e_r_t_e_x( _I_n_d_e_x e) const { return _refToChild- │ │ │ │ │ +>getEdgeChildVertex(e); } │ │ │ │ │ +275 │ │ │ │ │ +_2_7_7 _I_n_d_e_x _G_e_t_V_e_r_t_e_x_C_h_i_l_d_V_e_r_t_e_x(_I_n_d_e_x v) const { return _refToChild- │ │ │ │ │ +>getVertexChildVertex(v); } │ │ │ │ │ +278 │ │ │ │ │ +_2_8_0 _I_n_d_e_x _G_e_t_F_a_c_e_P_a_r_e_n_t_F_a_c_e(_I_n_d_e_x f) const { return _refToParent- │ │ │ │ │ +>getChildFaceParentFace(f); } │ │ │ │ │ +282 │ │ │ │ │ 284 │ │ │ │ │ -285 std::vector _levels; │ │ │ │ │ -286 std::vector _refinements; │ │ │ │ │ -287 │ │ │ │ │ -288 std::vector _farLevels; │ │ │ │ │ -289}; │ │ │ │ │ +285 │ │ │ │ │ +_2_8_6 bool _V_a_l_i_d_a_t_e_T_o_p_o_l_o_g_y() const { return _level->validateTopology(); } │ │ │ │ │ +_2_8_7 void _P_r_i_n_t_T_o_p_o_l_o_g_y(bool children = true) const { _level->print((children && │ │ │ │ │ +_refToChild) ? _refToChild : 0); } │ │ │ │ │ +289 │ │ │ │ │ 290 │ │ │ │ │ -291 │ │ │ │ │ -292inline int │ │ │ │ │ -_2_9_3_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const { │ │ │ │ │ -294 │ │ │ │ │ -295 return _levels[0]->getNumFVarChannels(); │ │ │ │ │ -296} │ │ │ │ │ -297inline _S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -_2_9_8_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n(int channel) const { │ │ │ │ │ -299 │ │ │ │ │ -300 return _levels[0]->getFVarOptions(channel).GetFVarLinearInterpolation(); │ │ │ │ │ -301} │ │ │ │ │ -302 │ │ │ │ │ -303} // end namespace Far │ │ │ │ │ -304 │ │ │ │ │ -305} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -306using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -307} // end namespace OpenSubdiv │ │ │ │ │ -308 │ │ │ │ │ -309#endif /* OPENSUBDIV3_FAR_TOPOLOGY_REFINER_H */ │ │ │ │ │ +291private: │ │ │ │ │ +_2_9_2 friend class _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r; │ │ │ │ │ +293 │ │ │ │ │ +294 Vtr::internal::Level const * _level; │ │ │ │ │ +295 Vtr::internal::Refinement const * _refToParent; │ │ │ │ │ +296 Vtr::internal::Refinement const * _refToChild; │ │ │ │ │ +297 │ │ │ │ │ +298public: │ │ │ │ │ +299 // Not intended for public use, but required by std::vector, etc... │ │ │ │ │ +_3_0_0 _T_o_p_o_l_o_g_y_L_e_v_e_l() { } │ │ │ │ │ +_3_0_1 _~_T_o_p_o_l_o_g_y_L_e_v_e_l() { } │ │ │ │ │ +302}; │ │ │ │ │ +303 │ │ │ │ │ +304} // end namespace Far │ │ │ │ │ +305 │ │ │ │ │ +306} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +307using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +308} // end namespace OpenSubdiv │ │ │ │ │ +309 │ │ │ │ │ +310#endif /* OPENSUBDIV3_FAR_TOPOLOGY_LEVEL_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -Vtr::ConstIndexArray ConstIndexArray │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_T_y_p_e │ │ │ │ │ -SchemeType │ │ │ │ │ -Enumerated type for all subdivision schemes supported by OpenSubdiv. │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l │ │ │ │ │ -Applies refinement operations to generic primvar data. │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ -Object used to compute and query ptex face indices. │ │ │ │ │ -DDeeffiinniittiioonn _p_t_e_x_I_n_d_i_c_e_s_._h_:_4_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_I_n_d_e_x │ │ │ │ │ +Vtr::Index Index │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_1 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l │ │ │ │ │ An interface for accessing data in a specific level of a refined topology │ │ │ │ │ hierarchy. │ │ │ │ │ DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_4_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y │ │ │ │ │ -Factory for constructing TopologyRefiners from specific mesh classes. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y_._h_:_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_P_a_r_e_n_t_F_a_c_e │ │ │ │ │ +Index GetFaceParentFace(Index f) const │ │ │ │ │ +Return the parent face (in the previous level) of a given face. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_8_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l │ │ │ │ │ +TopologyLevel() │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_3_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_V_a_l_e_n_c_e_R_e_g_u_l_a_r │ │ │ │ │ +bool IsVertexValenceRegular(Index v) const │ │ │ │ │ +Return if the valence of the vertex is regular (must be manifold) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_S_h_a_r_p_n_e_s_s │ │ │ │ │ +float GetEdgeSharpness(Index e) const │ │ │ │ │ +Return the sharpness assigned a given edge. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_D_o_e_s_F_a_c_e_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h │ │ │ │ │ +bool DoesFaceFVarTopologyMatch(Index f, int channel=0) const │ │ │ │ │ +Return if face-varying topology around a face matches. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_5_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_R_u_l_e │ │ │ │ │ +Sdc::Crease::Rule GetVertexRule(Index v) const │ │ │ │ │ +Return the subdivision rule assigned a given vertex specific to this level. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_9_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_C_o_r_n_e_r │ │ │ │ │ +bool IsVertexCorner(Index v) const │ │ │ │ │ +Return if the vertex is a corner (only one incident face) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_C_h_i_l_d_V_e_r_t_e_x │ │ │ │ │ +Index GetVertexChildVertex(Index v) const │ │ │ │ │ +Return the child vertex (in the next level) of a given vertex. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_7_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_F_a_c_e_L_o_c_a_l_I_n_d_i_c_e_s │ │ │ │ │ +ConstLocalIndexArray GetEdgeFaceLocalIndices(Index e) const │ │ │ │ │ +Access the local indices of an edge with respect to its incident faces. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_1_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_C_h_i_l_d_E_d_g_e_s │ │ │ │ │ +ConstIndexArray GetFaceChildEdges(Index f) const │ │ │ │ │ +Access the child edges (in the next level) of a given face. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_D_o_e_s_E_d_g_e_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h │ │ │ │ │ +bool DoesEdgeFVarTopologyMatch(Index e, int channel=0) const │ │ │ │ │ +Return if face-varying topology across the edge only matches. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_4_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_P_r_i_n_t_T_o_p_o_l_o_g_y │ │ │ │ │ +void PrintTopology(bool children=true) const │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_8_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_V_e_r_t_i_c_e_s │ │ │ │ │ +ConstIndexArray GetFaceVertices(Index f) const │ │ │ │ │ +Access the vertices incident a given face. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_9_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_C_h_i_l_d_F_a_c_e_s │ │ │ │ │ +ConstIndexArray GetFaceChildFaces(Index f) const │ │ │ │ │ +Access the child faces (in the next level) of a given face. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_E_d_g_e_s │ │ │ │ │ +int GetNumEdges() const │ │ │ │ │ +Return the number of edges in this level. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_V_a_l_i_d_a_t_e_T_o_p_o_l_o_g_y │ │ │ │ │ +bool ValidateTopology() const │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_E_d_g_e_N_o_n_M_a_n_i_f_o_l_d │ │ │ │ │ +bool IsEdgeNonManifold(Index e) const │ │ │ │ │ +Return if the edge is non-manifold. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_2_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_F_a_c_e_H_o_l_e │ │ │ │ │ +bool IsFaceHole(Index f) const │ │ │ │ │ +Return if a given face has been tagged as a hole. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_9_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_E_d_g_e_s │ │ │ │ │ +ConstIndexArray GetVertexEdges(Index v) const │ │ │ │ │ +Access the edges incident a given vertex. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_0_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_C_h_i_l_d_V_e_r_t_e_x │ │ │ │ │ +Index GetFaceChildVertex(Index f) const │ │ │ │ │ +Return the child vertex (in the next level) of a given face. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_D_o_e_s_V_e_r_t_e_x_F_V_a_r_T_o_p_o_l_o_g_y_M_a_t_c_h │ │ │ │ │ +bool DoesVertexFVarTopologyMatch(Index v, int channel=0) const │ │ │ │ │ +Return if face-varying topology around a vertex matches. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_4_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_C_h_i_l_d_E_d_g_e_s │ │ │ │ │ +ConstIndexArray GetEdgeChildEdges(Index e) const │ │ │ │ │ +Access the child edges (in the next level) of a given edge. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_E_d_g_e_I_n_f_S_h_a_r_p │ │ │ │ │ +bool IsEdgeInfSharp(Index e) const │ │ │ │ │ +Return if the edge is infinitely-sharp. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_7_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_F_a_c_e_s │ │ │ │ │ +ConstIndexArray GetVertexFaces(Index v) const │ │ │ │ │ +Access the faces incident a given vertex. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_0_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_F_i_n_d_E_d_g_e │ │ │ │ │ +Index FindEdge(Index v0, Index v1) const │ │ │ │ │ +Identify the edge matching the given vertex pair. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_2_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_E_d_g_e_L_o_c_a_l_I_n_d_i_c_e_s │ │ │ │ │ +ConstLocalIndexArray GetVertexEdgeLocalIndices(Index v) const │ │ │ │ │ +Access the local indices of a vertex with respect to its incident edges. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_1_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_E_d_g_e_s │ │ │ │ │ +ConstIndexArray GetFaceEdges(Index f) const │ │ │ │ │ +Access the edges incident a given face. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_9_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_F_a_c_e_s │ │ │ │ │ +int GetNumFaces() const │ │ │ │ │ +Return the number of faces in this level. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_B_o_u_n_d_a_r_y │ │ │ │ │ +bool IsVertexBoundary(Index v) const │ │ │ │ │ +Return if the vertex is on a boundary (at least one incident boundary edge) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ +int GetNumFVarChannels() const │ │ │ │ │ +Return the number of face-varying channels (should be same for all levels) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_3_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s │ │ │ │ │ +int GetNumVertices() const │ │ │ │ │ +Return the number of vertices in this level. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_F_a_c_e_s │ │ │ │ │ +ConstIndexArray GetEdgeFaces(Index e) const │ │ │ │ │ +Access the faces incident a given edge. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_0_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_F_a_c_e_F_V_a_r_V_a_l_u_e_s │ │ │ │ │ +ConstIndexArray GetFaceFVarValues(Index f, int channel=0) const │ │ │ │ │ +Access the face-varying values associated with a particular face. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_V_e_r_t_i_c_e_s │ │ │ │ │ +ConstIndexArray GetEdgeVertices(Index e) const │ │ │ │ │ +Access the vertices incident a given edge. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_9_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_E_d_g_e_S_e_m_i_S_h_a_r_p │ │ │ │ │ +bool IsEdgeSemiSharp(Index e) const │ │ │ │ │ +Return if the edge is semi-sharp. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_8_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_~_T_o_p_o_l_o_g_y_L_e_v_e_l │ │ │ │ │ +~TopologyLevel() │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_3_0_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s │ │ │ │ │ +float GetVertexSharpness(Index v) const │ │ │ │ │ +Return the sharpness assigned a given vertex. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_7_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_E_d_g_e_C_h_i_l_d_V_e_r_t_e_x │ │ │ │ │ +Index GetEdgeChildVertex(Index e) const │ │ │ │ │ +Return the child vertex (in the next level) of a given edge. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_7_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_S_e_m_i_S_h_a_r_p │ │ │ │ │ +bool IsVertexSemiSharp(Index v) const │ │ │ │ │ +Return if the vertex is semi-sharp. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_8_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_F_a_c_e_V_e_r_t_i_c_e_s │ │ │ │ │ +int GetNumFaceVertices() const │ │ │ │ │ +Return the total number of face-vertices, i.e. the sum of all vertices for all │ │ │ │ │ +faces. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_N_o_n_M_a_n_i_f_o_l_d │ │ │ │ │ +bool IsVertexNonManifold(Index v) const │ │ │ │ │ +Return if the vertex is non-manifold. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_3_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_E_d_g_e_B_o_u_n_d_a_r_y │ │ │ │ │ +bool IsEdgeBoundary(Index e) const │ │ │ │ │ +Return if the edge is a boundary (only one incident face) │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_3_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_I_s_V_e_r_t_e_x_I_n_f_S_h_a_r_p │ │ │ │ │ +bool IsVertexInfSharp(Index v) const │ │ │ │ │ +Return if the vertex is infinitely-sharp. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_N_u_m_F_V_a_r_V_a_l_u_e_s │ │ │ │ │ +int GetNumFVarValues(int channel=0) const │ │ │ │ │ +Return the total number of face-varying values in a particular channel (the │ │ │ │ │ +upper bound of a face-var... │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_2_3_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_L_e_v_e_l_:_:_G_e_t_V_e_r_t_e_x_F_a_c_e_L_o_c_a_l_I_n_d_i_c_e_s │ │ │ │ │ +ConstLocalIndexArray GetVertexFaceLocalIndices(Index v) const │ │ │ │ │ +Access the local indices of a vertex with respect to its incident faces. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_L_e_v_e_l_._h_:_1_1_1 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ Stores topology data for a specified set of refinement options. │ │ │ │ │ DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ -TopologyRefiner(TopologyRefiner const &source) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_M_a_x_V_a_l_e_n_c_e │ │ │ │ │ -int GetMaxValence() const │ │ │ │ │ -Returns the maximum vertex valence in all levels. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_7_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_g_e_t_L_e_v_e_l │ │ │ │ │ -Vtr::internal::Level const & getLevel(int l) const │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_H_a_s_H_o_l_e_s │ │ │ │ │ -bool HasHoles() const │ │ │ │ │ -Returns true if faces have been tagged as holes. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_8_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_L_e_v_e_l_s │ │ │ │ │ -int GetNumLevels() const │ │ │ │ │ -Returns the number of refinement levels. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_V_a_r_V_a_l_u_e_s_T_o_t_a_l │ │ │ │ │ -int GetNumFVarValuesTotal(int channel=0) const │ │ │ │ │ -Returns the total number of face-varying values in all levels. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_g_e_t_R_e_f_i_n_e_m_e_n_t │ │ │ │ │ -Vtr::internal::Refinement const & getRefinement(int l) const │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_S_c_h_e_m_e_O_p_t_i_o_n_s │ │ │ │ │ -Sdc::Options GetSchemeOptions() const │ │ │ │ │ -Returns the subdivision options. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_g_e_t_L_e_v_e_l │ │ │ │ │ -Vtr::internal::Level & getLevel(int l) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_3_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_I_s_U_n_i_f_o_r_m │ │ │ │ │ -bool IsUniform() const │ │ │ │ │ -Returns true if uniform refinement has been applied. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_S_c_h_e_m_e_T_y_p_e │ │ │ │ │ -Sdc::SchemeType GetSchemeType() const │ │ │ │ │ -Returns the subdivision scheme. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_M_a_x_L_e_v_e_l │ │ │ │ │ -int GetMaxLevel() const │ │ │ │ │ -Returns the highest level of refinement. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_7_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ -TopologyRefiner(Sdc::SchemeType type, Sdc::Options options=Sdc::Options()) │ │ │ │ │ -Constructor. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_E_d_g_e_s_T_o_t_a_l │ │ │ │ │ -int GetNumEdgesTotal() const │ │ │ │ │ -Returns the total number of edges in all levels. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_P_a_t_c_h_B_u_i_l_d_e_r │ │ │ │ │ -friend class PatchBuilder │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_2_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ -int GetNumFVarChannels() const │ │ │ │ │ -Returns the number of face-varying channels in the tables. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_9_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_U_n_i_f_o_r_m_O_p_t_i_o_n_s │ │ │ │ │ -UniformOptions GetUniformOptions() const │ │ │ │ │ -Returns the options specified on refinement. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_4_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_a_c_e_s_T_o_t_a_l │ │ │ │ │ -int GetNumFacesTotal() const │ │ │ │ │ -Returns the total number of edges in all levels. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_8_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_F_a_c_e_V_e_r_t_i_c_e_s_T_o_t_a_l │ │ │ │ │ -int GetNumFaceVerticesTotal() const │ │ │ │ │ -Returns the total number of face vertices in all levels. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_9_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_g_e_t_R_e_f_i_n_e_m_e_n_t │ │ │ │ │ -Vtr::internal::Refinement & getRefinement(int l) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_3_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_R_e_f_i_n_e_U_n_i_f_o_r_m │ │ │ │ │ -void RefineUniform(UniformOptions options) │ │ │ │ │ -Refine the topology uniformly. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_~_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ -~TopologyRefiner() │ │ │ │ │ -Destructor. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_P_a_t_c_h_T_a_b_l_e_B_u_i_l_d_e_r │ │ │ │ │ -friend class PatchTableBuilder │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_2_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_L_e_v_e_l │ │ │ │ │ -TopologyLevel const & GetLevel(int level) const │ │ │ │ │ -Returns a handle to access data specific to a particular level. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_9_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s_T_o_t_a_l │ │ │ │ │ -int GetNumVerticesTotal() const │ │ │ │ │ -Returns the total number of vertices in all levels. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_8_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_r_e_f_i_n_e │ │ │ │ │ -void Unrefine() │ │ │ │ │ -Unrefine the topology, keeping only the base level. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_G_e_t_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ -AdaptiveOptions GetAdaptiveOptions() const │ │ │ │ │ -Returns the options specified on refinement. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_9_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_: │ │ │ │ │ -_G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -Sdc::Options::FVarLinearInterpolation GetFVarLinearInterpolation(int channel=0) │ │ │ │ │ -const │ │ │ │ │ -Returns the face-varying interpolation rule set for a given channel. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_2_9_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_R_e_f_i_n_e_A_d_a_p_t_i_v_e │ │ │ │ │ -void RefineAdaptive(AdaptiveOptions options, ConstIndexArray │ │ │ │ │ -selectedFaces=ConstIndexArray()) │ │ │ │ │ -Feature Adaptive topology refinement. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s │ │ │ │ │ -Uniform refinement options. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_1_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_r_e_f_i_n_e_m_e_n_t_L_e_v_e_l │ │ │ │ │ -unsigned int refinementLevel │ │ │ │ │ -Number of refinement iterations. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_2_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t │ │ │ │ │ -unsigned int orderVerticesFromFacesFirst │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_3_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_S_e_t_R_e_f_i_n_e_m_e_n_t_L_e_v_e_l │ │ │ │ │ -void SetRefinementLevel(int level) │ │ │ │ │ -Set uniform refinement level. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_2_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_f_u_l_l_T_o_p_o_l_o_g_y_I_n_L_a_s_t_L_e_v_e_l │ │ │ │ │ -unsigned int fullTopologyInLastLevel │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_3_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_U_n_i_f_o_r_m_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_U_n_i_f_o_r_m_O_p_t_i_o_n_s │ │ │ │ │ -UniformOptions(int level) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_2_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ -Adaptive refinement options. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_s_e_c_o_n_d_a_r_y_L_e_v_e_l │ │ │ │ │ -unsigned int secondaryLevel │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_o_r_d_e_r_V_e_r_t_i_c_e_s_F_r_o_m_F_a_c_e_s_F_i_r_s_t │ │ │ │ │ -unsigned int orderVerticesFromFacesFirst │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_8_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ -AdaptiveOptions(int level) │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_5_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_i_s_o_l_a_t_i_o_n_L_e_v_e_l │ │ │ │ │ -unsigned int isolationLevel │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h │ │ │ │ │ -unsigned int useSingleCreasePatch │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h │ │ │ │ │ -unsigned int useInfSharpPatch │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_S_e_t_I_s_o_l_a_t_i_o_n_L_e_v_e_l │ │ │ │ │ -void SetIsolationLevel(int level) │ │ │ │ │ -Set isolation level. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_6_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ -unsigned int considerFVarChannels │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_8_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_S_e_t_S_e_c_o_n_d_a_r_y_L_e_v_e_l │ │ │ │ │ -void SetSecondaryLevel(int level) │ │ │ │ │ -Set secondary isolation level. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y_B_a_s_e │ │ │ │ │ -Private base class of Factories for constructing TopologyRefiners. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_F_a_c_t_o_r_y_._h_:_4_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s │ │ │ │ │ -All supported options applying to subdivision scheme. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -FVarLinearInterpolation │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ +Rule │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y │ │ │ │ │ DDeeffiinniittiioonn _a_r_r_a_y_._h_:_5_3 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h │ │ │ │ │ + * _t_o_p_o_l_o_g_y_L_e_v_e_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00713.html │ │ │ │ @@ -94,15 +94,15 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
topologyDescriptor.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/topologyRefiner.h"
│ │ │ │ +#include "../far/topologyRefiner.h"
│ │ │ │ #include "../far/topologyRefinerFactory.h"
│ │ │ │ #include "../far/error.h"
│ │ │ │ #include <cassert>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00713_source.html │ │ │ │ @@ -217,15 +217,15 @@ │ │ │ │
121} // end namespace Far
│ │ │ │
122
│ │ │ │
123} // end namespace OPENSUBDIV_VERSION
│ │ │ │
124using namespace OPENSUBDIV_VERSION;
│ │ │ │
125} // end namespace OpenSubdiv
│ │ │ │
126
│ │ │ │
127#endif /* OPENSUBDIV3_FAR_TOPOLOGY_DESCRIPTOR_H */
│ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │
A simple reference to raw topology data for use with TopologyRefinerFactory.
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -245,15 +245,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
static bool assignComponentTopology(TopologyRefiner &newRefiner, MESH const &mesh)
Specify the relationships between vertices, faces, etc. ie the face-vertices, vertex-faces,...
│ │ │ │
static void reportInvalidTopology(TopologyError errCode, char const *msg, MESH const &mesh)
(Optional) Control run-time topology validation and error reporting
│ │ │ │
static bool assignComponentTags(TopologyRefiner &newRefiner, MESH const &mesh)
(Optional) Specify edge or vertex sharpness or face holes
│ │ │ │
static bool resizeComponentTopology(TopologyRefiner &newRefiner, MESH const &mesh)
Specify the number of vertices, faces, face-vertices, etc.
│ │ │ │
static bool assignFaceVaryingTopology(TopologyRefiner &newRefiner, MESH const &mesh)
(Optional) Specify face-varying data per face
│ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
stencilTable.h File Reference
│ │ │ │ +
stencilTableFactory.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/types.h"
│ │ │ │ -#include <cassert>
│ │ │ │ -#include <cstring>
│ │ │ │ +#include "../far/patchTable.h"
│ │ │ │ #include <vector>
│ │ │ │ -#include <iostream>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  StencilReal< REAL >
 Vertex stencil descriptor. More...
class  StencilTableFactoryReal< REAL >
 A specialized factory for StencilTable. More...
 
class  Stencil
 Vertex stencil class wrapping the template for compatibility. More...
struct  StencilTableFactoryReal< REAL >::Options
 
class  StencilTableReal< REAL >
 Table of subdivision stencils. More...
class  LimitStencilTableFactoryReal< REAL >
 A specialized factory for LimitStencilTable. More...
 
class  StencilTable
 Stencil table class wrapping the template for compatibility. More...
struct  LimitStencilTableFactoryReal< REAL >::Options
 
class  LimitStencilReal< REAL >
 Limit point stencil descriptor. More...
struct  LimitStencilTableFactoryReal< REAL >::LocationArray
 Descriptor for limit surface locations. More...
 
class  LimitStencil
 Limit point stencil class wrapping the template for compatibility. More...
class  StencilTableFactory
 Stencil table factory class wrapping the template for compatibility. More...
 
class  LimitStencilTableReal< REAL >
 Table of limit subdivision stencils. More...
 
class  LimitStencilTable
 Limit stencil table class wrapping the template for compatibility. More...
class  LimitStencilTableFactory
 Stencil table factory class wrapping the template for compatibility. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -143,13 +135,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,51 +1,43 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -stencilTable.h File Reference │ │ │ │ │ +stencilTableFactory.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_f_a_r_/_t_y_p_e_s_._h" │ │ │ │ │ -#include │ │ │ │ │ -#include │ │ │ │ │ +#include "_._._/_f_a_r_/_p_a_t_c_h_T_a_b_l_e_._h" │ │ │ │ │ #include │ │ │ │ │ -#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _S_t_e_n_c_i_l_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ -  Vertex stencil descriptor. _M_o_r_e_._._. │ │ │ │ │ + class   _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ +  A specialized factory for _S_t_e_n_c_i_l_T_a_b_l_e. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -class   _S_t_e_n_c_i_l │ │ │ │ │ -  Vertex stencil class wrapping the template for compatibility. _M_o_r_e_._._. │ │ │ │ │ +struct   _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _>_:_:_O_p_t_i_o_n_s │ │ │ │ │   │ │ │ │ │ -class   _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ -  Table of subdivision stencils. _M_o_r_e_._._. │ │ │ │ │ + class   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ +  A specialized factory for _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -class   _S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -  _S_t_e_n_c_i_l table class wrapping the template for compatibility. _M_o_r_e_._._. │ │ │ │ │ +struct   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _>_:_:_O_p_t_i_o_n_s │ │ │ │ │   │ │ │ │ │ -class   _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ -  Limit point stencil descriptor. _M_o_r_e_._._. │ │ │ │ │ +struct   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _>_:_:_L_o_c_a_t_i_o_n_A_r_r_a_y │ │ │ │ │ +  Descriptor for limit surface locations. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -class   _L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ -  Limit point stencil class wrapping the template for compatibility. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ + class   _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ +  _S_t_e_n_c_i_l table factory class wrapping the template for compatibility. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -class   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ -  Table of limit subdivision stencils. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -class   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -  Limit stencil table class wrapping the template for compatibility. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ + class   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ +  _S_t_e_n_c_i_l table factory class wrapping the template for compatibility. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _s_t_e_n_c_i_l_T_a_b_l_e_._h │ │ │ │ │ + * _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00716.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,10 +1,9 @@ │ │ │ │ │ var a00716 = [ │ │ │ │ │ - ["StencilReal< REAL >", "a01053.html", "a01053"], │ │ │ │ │ - ["Stencil", "a01057.html", "a01057"], │ │ │ │ │ - ["StencilTableReal< REAL >", "a01061.html", "a01061"], │ │ │ │ │ - ["StencilTable", "a01065.html", "a01065"], │ │ │ │ │ - ["LimitStencilReal< REAL >", "a01069.html", "a01069"], │ │ │ │ │ - ["LimitStencil", "a01073.html", "a01073"], │ │ │ │ │ - ["LimitStencilTableReal< REAL >", "a01077.html", "a01077"], │ │ │ │ │ - ["LimitStencilTable", "a01081.html", "a01081"] │ │ │ │ │ + ["StencilTableFactoryReal< REAL >", "a01045.html", "a01045"], │ │ │ │ │ + ["Options", "a01085.html", "a01085"], │ │ │ │ │ + ["LimitStencilTableFactoryReal< REAL >", "a01049.html", "a01049"], │ │ │ │ │ + ["Options", "a01089.html", "a01089"], │ │ │ │ │ + ["LocationArray", "a01093.html", "a01093"], │ │ │ │ │ + ["StencilTableFactory", "a01097.html", null], │ │ │ │ │ + ["LimitStencilTableFactory", "a01101.html", null] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00716_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/stencilTable.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/far/stencilTableFactory.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
stencilTable.h
│ │ │ │ +
stencilTableFactory.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,892 +119,357 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_FAR_STENCILTABLE_H
│ │ │ │ -
26#define OPENSUBDIV3_FAR_STENCILTABLE_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H
│ │ │ │ +
26#define OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │
29
│ │ │ │ -
30#include "../far/types.h"
│ │ │ │ +
30#include "../far/patchTable.h"
│ │ │ │
31
│ │ │ │ -
32#include <cassert>
│ │ │ │ -
33#include <cstring>
│ │ │ │ -
34#include <vector>
│ │ │ │ -
35#include <iostream>
│ │ │ │ +
32#include <vector>
│ │ │ │ +
33
│ │ │ │ +
34namespace OpenSubdiv {
│ │ │ │ +
35namespace OPENSUBDIV_VERSION {
│ │ │ │
36
│ │ │ │ -
37namespace OpenSubdiv {
│ │ │ │ -
38namespace OPENSUBDIV_VERSION {
│ │ │ │ -
39
│ │ │ │ -
40namespace Far {
│ │ │ │ -
41
│ │ │ │ -
42// Forward declarations for friends:
│ │ │ │ -
43class PatchTableBuilder;
│ │ │ │ -
44
│ │ │ │ -
45template <typename REAL> class StencilTableFactoryReal;
│ │ │ │ -
46template <typename REAL> class LimitStencilTableFactoryReal;
│ │ │ │ +
37namespace Far {
│ │ │ │ +
38
│ │ │ │ +
39class TopologyRefiner;
│ │ │ │ +
40
│ │ │ │ +
41template <typename REAL> class StencilReal;
│ │ │ │ +
42template <typename REAL> class StencilTableReal;
│ │ │ │ +
43
│ │ │ │ +
44template <typename REAL> class LimitStencilReal;
│ │ │ │ +
45template <typename REAL> class LimitStencilTableReal;
│ │ │ │ +
46
│ │ │ │
47
│ │ │ │ -
52template <typename REAL>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
54public:
│ │ │ │ -
55
│ │ │ │ - │ │ │ │ -
58
│ │ │ │ -
│ │ │ │ -
67 StencilReal(int * size, Index * indices, REAL * weights)
│ │ │ │ -
68 : _size(size), _indices(indices), _weights(weights) { }
│ │ │ │ -
│ │ │ │ -
69
│ │ │ │ -
│ │ │ │ -
71 StencilReal(StencilReal const & other) {
│ │ │ │ -
72 _size = other._size;
│ │ │ │ -
73 _indices = other._indices;
│ │ │ │ -
74 _weights = other._weights;
│ │ │ │ -
75 }
│ │ │ │ -
│ │ │ │ -
76
│ │ │ │ -
│ │ │ │ -
78 int GetSize() const {
│ │ │ │ -
79 return *_size;
│ │ │ │ -
80 }
│ │ │ │ -
│ │ │ │ -
81
│ │ │ │ -
│ │ │ │ -
83 int * GetSizePtr() const {
│ │ │ │ -
84 return _size;
│ │ │ │ -
85 }
│ │ │ │ -
│ │ │ │ -
86
│ │ │ │ -
│ │ │ │ -
88 Index const * GetVertexIndices() const {
│ │ │ │ -
89 return _indices;
│ │ │ │ -
90 }
│ │ │ │ -
│ │ │ │ -
91
│ │ │ │ -
│ │ │ │ -
93 REAL const * GetWeights() const {
│ │ │ │ -
94 return _weights;
│ │ │ │ -
95 }
│ │ │ │ -
│ │ │ │ +
50template <typename REAL>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
52
│ │ │ │ +
53public:
│ │ │ │ +
54
│ │ │ │ +
│ │ │ │ +
55 enum Mode {
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
59 };
│ │ │ │ +
│ │ │ │ +
60
│ │ │ │ +
│ │ │ │ +
61 struct Options {
│ │ │ │ +
62
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
64 generateOffsets(false),
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
68 maxLevel(10),
│ │ │ │ +
69 fvarChannel(0) { }
│ │ │ │ +
│ │ │ │ +
70
│ │ │ │ +
71 unsigned int interpolationMode : 2,
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
79 unsigned int fvarChannel;
│ │ │ │ +
81 };
│ │ │ │ +
│ │ │ │ +
82
│ │ │ │ + │ │ │ │ +
95 TopologyRefiner const & refiner, Options options = Options());
│ │ │ │
96
│ │ │ │ -
98 void Next() {
│ │ │ │ -
99 int stride = *_size;
│ │ │ │ -
100 ++_size;
│ │ │ │ -
101 _indices += stride;
│ │ │ │ -
102 _weights += stride;
│ │ │ │ -
103 }
│ │ │ │ -
104
│ │ │ │ -
105protected:
│ │ │ │ -
106 friend class StencilTableFactoryReal<REAL>;
│ │ │ │ -
107 friend class LimitStencilTableFactoryReal<REAL>;
│ │ │ │ -
108
│ │ │ │ -
109 int * _size;
│ │ │ │ - │ │ │ │ -
111 REAL * _weights;
│ │ │ │ -
112};
│ │ │ │ -
│ │ │ │ +
97
│ │ │ │ + │ │ │ │ +
111 int numTables, StencilTableReal<REAL> const ** tables);
│ │ │ │ +
112
│ │ │ │
113
│ │ │ │ -
│ │ │ │ -
116class Stencil : public StencilReal<float> {
│ │ │ │ -
117protected:
│ │ │ │ - │ │ │ │ -
119
│ │ │ │ -
120public:
│ │ │ │ - │ │ │ │ -
122 Stencil(BaseStencil const & other) : BaseStencil(other) { }
│ │ │ │ -
│ │ │ │ -
123 Stencil(int * size, Index * indices, float * weights)
│ │ │ │ -
124 : BaseStencil(size, indices, weights) { }
│ │ │ │ -
│ │ │ │ -
125};
│ │ │ │ -
│ │ │ │ -
126
│ │ │ │ -
127
│ │ │ │ -
140template <typename REAL>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
142protected:
│ │ │ │ -
143 StencilTableReal(int numControlVerts,
│ │ │ │ -
144 std::vector<int> const& offsets,
│ │ │ │ -
145 std::vector<int> const& sizes,
│ │ │ │ -
146 std::vector<int> const& sources,
│ │ │ │ -
147 std::vector<REAL> const& weights,
│ │ │ │ -
148 bool includeCoarseVerts,
│ │ │ │ -
149 size_t firstOffset);
│ │ │ │ -
150
│ │ │ │ -
151public:
│ │ │ │ -
152
│ │ │ │ -
153 virtual ~StencilTableReal() {};
│ │ │ │ -
154
│ │ │ │ -
│ │ │ │ -
156 int GetNumStencils() const {
│ │ │ │ -
157 return (int)_sizes.size();
│ │ │ │ -
158 }
│ │ │ │ -
│ │ │ │ -
159
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
162 return _numControlVertices;
│ │ │ │ -
163 }
│ │ │ │ -
│ │ │ │ -
164
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
167
│ │ │ │ -
│ │ │ │ -
169 std::vector<int> const & GetSizes() const {
│ │ │ │ -
170 return _sizes;
│ │ │ │ -
171 }
│ │ │ │ -
│ │ │ │ -
172
│ │ │ │ -
│ │ │ │ -
174 std::vector<Index> const & GetOffsets() const {
│ │ │ │ -
175 return _offsets;
│ │ │ │ -
176 }
│ │ │ │ -
│ │ │ │ -
177
│ │ │ │ -
│ │ │ │ -
179 std::vector<Index> const & GetControlIndices() const {
│ │ │ │ -
180 return _indices;
│ │ │ │ -
181 }
│ │ │ │ -
│ │ │ │ + │ │ │ │ +
129 TopologyRefiner const &refiner,
│ │ │ │ +
130 StencilTableReal<REAL> const *baseStencilTable,
│ │ │ │ +
131 StencilTableReal<REAL> const *localPointStencilTable,
│ │ │ │ +
132 bool factorize = true);
│ │ │ │ +
133
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
149 TopologyRefiner const &refiner,
│ │ │ │ +
150 StencilTableReal<REAL> const *baseStencilTable,
│ │ │ │ +
151 StencilTableReal<REAL> const *localPointStencilTable,
│ │ │ │ +
152 bool factorize = true) {
│ │ │ │ + │ │ │ │ +
154 refiner, baseStencilTable, localPointStencilTable, factorize);
│ │ │ │ +
155 }
│ │ │ │ +
│ │ │ │ +
156
│ │ │ │ + │ │ │ │ +
175 TopologyRefiner const &refiner,
│ │ │ │ +
176 StencilTableReal<REAL> const *baseStencilTable,
│ │ │ │ +
177 StencilTableReal<REAL> const *localPointStencilTable,
│ │ │ │ +
178 int channel = 0,
│ │ │ │ +
179 bool factorize = true);
│ │ │ │ +
180
│ │ │ │ +
181private:
│ │ │ │
182
│ │ │ │ -
│ │ │ │ -
184 std::vector<REAL> const & GetWeights() const {
│ │ │ │ -
185 return _weights;
│ │ │ │ -
186 }
│ │ │ │ -
│ │ │ │ +
183 // Generate stencils for the coarse control-vertices (single weight = 1.0f)
│ │ │ │ +
184 static void generateControlVertStencils(
│ │ │ │ +
185 int numControlVerts,
│ │ │ │ +
186 StencilReal<REAL> & dst);
│ │ │ │
187
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
190
│ │ │ │ -
204 template <class T, class U>
│ │ │ │ -
│ │ │ │ -
205 void UpdateValues(T const &srcValues, U &dstValues, Index start=-1, Index end=-1) const {
│ │ │ │ -
206 this->update(srcValues, dstValues, _weights, start, end);
│ │ │ │ -
207 }
│ │ │ │ -
│ │ │ │ -
208
│ │ │ │ -
209 template <class T1, class T2, class U>
│ │ │ │ -
│ │ │ │ -
210 void UpdateValues(T1 const &srcBase, int numBase, T2 const &srcRef,
│ │ │ │ -
211 U &dstValues, Index start=-1, Index end=-1) const {
│ │ │ │ -
212 this->update(srcBase, numBase, srcRef, dstValues, _weights, start, end);
│ │ │ │ -
213 }
│ │ │ │ -
│ │ │ │ -
214
│ │ │ │ -
215 // Pointer interface for backward compatibility
│ │ │ │ -
216 template <class T, class U>
│ │ │ │ -
│ │ │ │ -
217 void UpdateValues(T const *src, U *dst, Index start=-1, Index end=-1) const {
│ │ │ │ -
218 this->update(src, dst, _weights, start, end);
│ │ │ │ -
219 }
│ │ │ │ -
│ │ │ │ -
220 template <class T1, class T2, class U>
│ │ │ │ +
188 // Internal method to splice local point stencils
│ │ │ │ +
189 static StencilTableReal<REAL> const * appendLocalPointStencilTable(
│ │ │ │ +
190 TopologyRefiner const &refiner,
│ │ │ │ +
191 StencilTableReal<REAL> const * baseStencilTable,
│ │ │ │ +
192 StencilTableReal<REAL> const * localPointStencilTable,
│ │ │ │ +
193 int channel,
│ │ │ │ +
194 bool factorize);
│ │ │ │ +
195};
│ │ │ │ +
│ │ │ │ +
196
│ │ │ │ +
208template <typename REAL>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
210
│ │ │ │ +
211public:
│ │ │ │ +
212
│ │ │ │ +
│ │ │ │ +
213 enum Mode {
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
217 };
│ │ │ │ +
│ │ │ │ +
218
│ │ │ │ +
│ │ │ │ +
219 struct Options {
│ │ │ │ +
220
│ │ │ │
│ │ │ │ -
221 void UpdateValues(T1 const *srcBase, int numBase, T2 const *srcRef,
│ │ │ │ -
222 U *dst, Index start=-1, Index end=-1) const {
│ │ │ │ -
223 this->update(srcBase, numBase, srcRef, dst, _weights, start, end);
│ │ │ │ -
224 }
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
224 fvarChannel(0) { }
│ │ │ │
│ │ │ │
225
│ │ │ │ -
227 void Clear();
│ │ │ │ -
228
│ │ │ │ -
229protected:
│ │ │ │ -
230
│ │ │ │ -
231 // Update values by applying cached stencil weights to new control values
│ │ │ │ -
232 template <class T, class U>
│ │ │ │ -
│ │ │ │ -
233 void update( T const &srcValues, U &dstValues,
│ │ │ │ -
234 std::vector<REAL> const & valueWeights, Index start, Index end) const;
│ │ │ │ -
235 template <class T1, class T2, class U>
│ │ │ │ -
│ │ │ │ -
236 void update( T1 const &srcBase, int numBase, T2 const &srcRef, U &dstValues,
│ │ │ │ -
237 std::vector<REAL> const & valueWeights, Index start, Index end) const;
│ │ │ │ -
238
│ │ │ │ -
239 // Populate the offsets table from the stencil sizes in _sizes (factory helper)
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
241
│ │ │ │ -
242 // Resize the table arrays (factory helper)
│ │ │ │ -
│ │ │ │ -
243 void resize(int nstencils, int nelems);
│ │ │ │ -
244
│ │ │ │ -
245 // Reserves the table arrays (factory helper)
│ │ │ │ -
│ │ │ │ -
246 void reserve(int nstencils, int nelems);
│ │ │ │ -
247
│ │ │ │ -
248 // Reallocates the table arrays to remove excess capacity (factory helper)
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
250
│ │ │ │ -
251 // Performs any final operations on internal tables (factory helper)
│ │ │ │ -
│ │ │ │ -
252 void finalize();
│ │ │ │ -
253
│ │ │ │ -
254protected:
│ │ │ │ - │ │ │ │ -
256 StencilTableReal(int numControlVerts)
│ │ │ │ -
257 : _numControlVertices(numControlVerts)
│ │ │ │ -
258 { }
│ │ │ │ -
259
│ │ │ │ -
260 friend class StencilTableFactoryReal<REAL>;
│ │ │ │ - │ │ │ │ -
262
│ │ │ │ -
263 int _numControlVertices; // number of control vertices
│ │ │ │ -
264
│ │ │ │ -
265 std::vector<int> _sizes; // number of coefficients for each stencil
│ │ │ │ -
266 std::vector<Index> _offsets, // offset to the start of each stencil
│ │ │ │ -
267 _indices; // indices of contributing coarse vertices
│ │ │ │ -
268 std::vector<REAL> _weights; // stencil weight coefficients
│ │ │ │ -
269};
│ │ │ │ -
270
│ │ │ │ -
│ │ │ │ -
273class StencilTable : public StencilTableReal<float> {
│ │ │ │ -
274protected:
│ │ │ │ - │ │ │ │ -
276
│ │ │ │ -
277public:
│ │ │ │ -
│ │ │ │ -
278 Stencil GetStencil(Index index) const {
│ │ │ │ -
279 return Stencil(BaseTable::GetStencil(index));
│ │ │ │ -
280 }
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
281 Stencil operator[] (Index index) const {
│ │ │ │ -
282 return Stencil(BaseTable::GetStencil(index));
│ │ │ │ -
283 }
│ │ │ │ -
│ │ │ │ +
226 unsigned int interpolationMode : 2,
│ │ │ │ + │ │ │ │ + │ │ │ │ +
229 unsigned int fvarChannel;
│ │ │ │ +
230 };
│ │ │ │ +
│ │ │ │ +
231
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
234
│ │ │ │ +
235 LocationArray() : ptexIdx(-1), numLocations(0), s(0), t(0) { }
│ │ │ │ +
236
│ │ │ │ + │ │ │ │ + │ │ │ │ +
239
│ │ │ │ +
240 REAL const * s,
│ │ │ │ +
241 * t;
│ │ │ │ +
242 };
│ │ │ │ +
│ │ │ │ +
243
│ │ │ │ +
244 typedef std::vector<LocationArray> LocationArrayVec;
│ │ │ │ +
245
│ │ │ │ + │ │ │ │ +
270 TopologyRefiner const & refiner,
│ │ │ │ +
271 LocationArrayVec const & locationArrays,
│ │ │ │ +
272 StencilTableReal<REAL> const * cvStencils = 0,
│ │ │ │ +
273 PatchTable const * patchTable = 0,
│ │ │ │ +
274 Options options = Options());
│ │ │ │ +
275
│ │ │ │ +
276};
│ │ │ │ +
│ │ │ │ +
277
│ │ │ │ +
278
│ │ │ │ +
279//
│ │ │ │ +
280// Public wrapper classes for the templates
│ │ │ │ +
281//
│ │ │ │ +
282class Stencil;
│ │ │ │ +
283class StencilTable;
│ │ │ │
284
│ │ │ │ -
285protected:
│ │ │ │ - │ │ │ │ -
287 StencilTable(int numControlVerts) : BaseTable(numControlVerts) { }
│ │ │ │ -
│ │ │ │ -
288 StencilTable(int numControlVerts,
│ │ │ │ -
289 std::vector<int> const& offsets,
│ │ │ │ -
290 std::vector<int> const& sizes,
│ │ │ │ -
291 std::vector<int> const& sources,
│ │ │ │ -
292 std::vector<float> const& weights,
│ │ │ │ -
293 bool includeCoarseVerts,
│ │ │ │ -
294 size_t firstOffset)
│ │ │ │ -
295 : BaseTable(numControlVerts, offsets,
│ │ │ │ -
296 sizes, sources, weights, includeCoarseVerts, firstOffset) { }
│ │ │ │ -
│ │ │ │ -
297};
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
288private:
│ │ │ │ + │ │ │ │ + │ │ │ │ +
291
│ │ │ │ +
292public:
│ │ │ │ +
│ │ │ │ +
293 static StencilTable const * Create(
│ │ │ │ +
294 TopologyRefiner const & refiner, Options options = Options()) {
│ │ │ │ +
295
│ │ │ │ +
296 return static_cast<StencilTable const *>(
│ │ │ │ +
297 BaseFactory::Create(refiner, options));
│ │ │ │ +
298 }
│ │ │ │
│ │ │ │ -
298
│ │ │ │
299
│ │ │ │ -
302template <typename REAL>
│ │ │ │ -
│ │ │ │ -
303class LimitStencilReal : public StencilReal<REAL> {
│ │ │ │ -
304public:
│ │ │ │ -
305
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
325 Index * indices,
│ │ │ │ -
326 REAL * weights,
│ │ │ │ -
327 REAL * duWeights=0,
│ │ │ │ -
328 REAL * dvWeights=0,
│ │ │ │ -
329 REAL * duuWeights=0,
│ │ │ │ -
330 REAL * duvWeights=0,
│ │ │ │ -
331 REAL * dvvWeights=0)
│ │ │ │ -
332 : StencilReal<REAL>(size, indices, weights),
│ │ │ │ -
333 _duWeights(duWeights),
│ │ │ │ -
334 _dvWeights(dvWeights),
│ │ │ │ -
335 _duuWeights(duuWeights),
│ │ │ │ -
336 _duvWeights(duvWeights),
│ │ │ │ -
337 _dvvWeights(dvvWeights) {
│ │ │ │ -
338 }
│ │ │ │ -
│ │ │ │ -
339
│ │ │ │ -
│ │ │ │ -
341 REAL const * GetDuWeights() const {
│ │ │ │ -
342 return _duWeights;
│ │ │ │ -
343 }
│ │ │ │ -
│ │ │ │ -
344
│ │ │ │ -
│ │ │ │ -
346 REAL const * GetDvWeights() const {
│ │ │ │ -
347 return _dvWeights;
│ │ │ │ -
348 }
│ │ │ │ -
│ │ │ │ -
349
│ │ │ │ -
│ │ │ │ -
351 REAL const * GetDuuWeights() const {
│ │ │ │ -
352 return _duuWeights;
│ │ │ │ -
353 }
│ │ │ │ -
│ │ │ │ -
354
│ │ │ │ -
│ │ │ │ -
356 REAL const * GetDuvWeights() const {
│ │ │ │ -
357 return _duvWeights;
│ │ │ │ -
358 }
│ │ │ │ -
│ │ │ │ -
359
│ │ │ │ -
│ │ │ │ -
361 REAL const * GetDvvWeights() const {
│ │ │ │ -
362 return _dvvWeights;
│ │ │ │ -
363 }
│ │ │ │ -
│ │ │ │ -
364
│ │ │ │ -
366 void Next() {
│ │ │ │ -
367 int stride = *this->_size;
│ │ │ │ -
368 ++this->_size;
│ │ │ │ -
369 this->_indices += stride;
│ │ │ │ -
370 this->_weights += stride;
│ │ │ │ -
371 if (_duWeights) _duWeights += stride;
│ │ │ │ -
372 if (_dvWeights) _dvWeights += stride;
│ │ │ │ -
373 if (_duuWeights) _duuWeights += stride;
│ │ │ │ -
374 if (_duvWeights) _duvWeights += stride;
│ │ │ │ -
375 if (_dvvWeights) _dvvWeights += stride;
│ │ │ │ -
376 }
│ │ │ │ -
377
│ │ │ │ -
378private:
│ │ │ │ -
379
│ │ │ │ -
380 friend class StencilTableFactoryReal<REAL>;
│ │ │ │ -
381 friend class LimitStencilTableFactoryReal<REAL>;
│ │ │ │ -
382
│ │ │ │ -
383 REAL * _duWeights, // pointer to stencil u derivative limit weights
│ │ │ │ -
384 * _dvWeights, // pointer to stencil v derivative limit weights
│ │ │ │ -
385 * _duuWeights, // pointer to stencil uu derivative limit weights
│ │ │ │ -
386 * _duvWeights, // pointer to stencil uv derivative limit weights
│ │ │ │ -
387 * _dvvWeights; // pointer to stencil vv derivative limit weights
│ │ │ │ -
388};
│ │ │ │ -
│ │ │ │ -
389
│ │ │ │ -
│ │ │ │ -
392class LimitStencil : public LimitStencilReal<float> {
│ │ │ │ -
393protected:
│ │ │ │ - │ │ │ │ -
395
│ │ │ │ -
396public:
│ │ │ │ -
397 LimitStencil(BaseStencil const & other) : BaseStencil(other) { }
│ │ │ │ -
│ │ │ │ -
398 LimitStencil(int* size, Index * indices, float * weights,
│ │ │ │ -
399 float * duWeights=0, float * dvWeights=0,
│ │ │ │ -
400 float * duuWeights=0, float * duvWeights=0, float * dvvWeights=0)
│ │ │ │ -
401 : BaseStencil(size, indices, weights,
│ │ │ │ -
402 duWeights, dvWeights, duuWeights, duvWeights, dvvWeights) { }
│ │ │ │ -
│ │ │ │ -
403};
│ │ │ │ -
│ │ │ │ -
404
│ │ │ │ -
405
│ │ │ │ -
408template <typename REAL>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
410protected:
│ │ │ │ - │ │ │ │ -
412 int numControlVerts,
│ │ │ │ -
413 std::vector<int> const& offsets,
│ │ │ │ -
414 std::vector<int> const& sizes,
│ │ │ │ -
415 std::vector<int> const& sources,
│ │ │ │ -
416 std::vector<REAL> const& weights,
│ │ │ │ -
417 std::vector<REAL> const& duWeights,
│ │ │ │ -
418 std::vector<REAL> const& dvWeights,
│ │ │ │ -
419 std::vector<REAL> const& duuWeights,
│ │ │ │ -
420 std::vector<REAL> const& duvWeights,
│ │ │ │ -
421 std::vector<REAL> const& dvvWeights,
│ │ │ │ -
422 bool includeCoarseVerts,
│ │ │ │ -
423 size_t firstOffset);
│ │ │ │ -
424
│ │ │ │ -
425public:
│ │ │ │ -
426
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
429
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
432
│ │ │ │ -
│ │ │ │ -
434 std::vector<REAL> const & GetDuWeights() const {
│ │ │ │ -
435 return _duWeights;
│ │ │ │ -
436 }
│ │ │ │ -
│ │ │ │ -
437
│ │ │ │ -
│ │ │ │ -
439 std::vector<REAL> const & GetDvWeights() const {
│ │ │ │ -
440 return _dvWeights;
│ │ │ │ -
441 }
│ │ │ │ -
│ │ │ │ -
442
│ │ │ │ -
│ │ │ │ -
444 std::vector<REAL> const & GetDuuWeights() const {
│ │ │ │ -
445 return _duuWeights;
│ │ │ │ -
446 }
│ │ │ │ -
│ │ │ │ -
447
│ │ │ │ -
│ │ │ │ -
449 std::vector<REAL> const & GetDuvWeights() const {
│ │ │ │ -
450 return _duvWeights;
│ │ │ │ -
451 }
│ │ │ │ -
│ │ │ │ -
452
│ │ │ │ -
│ │ │ │ -
454 std::vector<REAL> const & GetDvvWeights() const {
│ │ │ │ -
455 return _dvvWeights;
│ │ │ │ -
456 }
│ │ │ │ -
│ │ │ │ -
457
│ │ │ │ -
475 template <class T, class U>
│ │ │ │ -
│ │ │ │ -
476 void UpdateDerivs(T const & srcValues, U & uderivs, U & vderivs,
│ │ │ │ -
477 int start=-1, int end=-1) const {
│ │ │ │ -
478
│ │ │ │ -
479 this->update(srcValues, uderivs, _duWeights, start, end);
│ │ │ │ -
480 this->update(srcValues, vderivs, _dvWeights, start, end);
│ │ │ │ -
481 }
│ │ │ │ -
│ │ │ │ -
482
│ │ │ │ -
483 template <class T1, class T2, class U>
│ │ │ │ -
│ │ │ │ -
484 void UpdateDerivs(T1 const & srcBase, int numBase, T2 const & srcRef,
│ │ │ │ -
485 U & uderivs, U & vderivs, int start=-1, int end=-1) const {
│ │ │ │ -
486
│ │ │ │ -
487 this->update(srcBase, numBase, srcRef, uderivs, _duWeights, start, end);
│ │ │ │ -
488 this->update(srcBase, numBase, srcRef, vderivs, _dvWeights, start, end);
│ │ │ │ -
489 }
│ │ │ │ -
│ │ │ │ -
490
│ │ │ │ -
491 // Pointer interface for backward compatibility
│ │ │ │ -
492 template <class T, class U>
│ │ │ │ -
│ │ │ │ -
493 void UpdateDerivs(T const *src, U *uderivs, U *vderivs,
│ │ │ │ -
494 int start=-1, int end=-1) const {
│ │ │ │ -
495
│ │ │ │ -
496 this->update(src, uderivs, _duWeights, start, end);
│ │ │ │ -
497 this->update(src, vderivs, _dvWeights, start, end);
│ │ │ │ -
498 }
│ │ │ │ -
│ │ │ │ -
499 template <class T1, class T2, class U>
│ │ │ │ -
│ │ │ │ -
500 void UpdateDerivs(T1 const *srcBase, int numBase, T2 const *srcRef,
│ │ │ │ -
501 U *uderivs, U *vderivs, int start=-1, int end=-1) const {
│ │ │ │ -
502
│ │ │ │ -
503 this->update(srcBase, numBase, srcRef, uderivs, _duWeights, start, end);
│ │ │ │ -
504 this->update(srcBase, numBase, srcRef, vderivs, _dvWeights, start, end);
│ │ │ │ -
505 }
│ │ │ │ -
│ │ │ │ -
506
│ │ │ │ -
527 template <class T, class U>
│ │ │ │ -
│ │ │ │ -
528 void Update2ndDerivs(T const & srcValues,
│ │ │ │ -
529 U & uuderivs, U & uvderivs, U & vvderivs,
│ │ │ │ -
530 int start=-1, int end=-1) const {
│ │ │ │ -
531
│ │ │ │ -
532 this->update(srcValues, uuderivs, _duuWeights, start, end);
│ │ │ │ -
533 this->update(srcValues, uvderivs, _duvWeights, start, end);
│ │ │ │ -
534 this->update(srcValues, vvderivs, _dvvWeights, start, end);
│ │ │ │ -
535 }
│ │ │ │ -
│ │ │ │ -
536
│ │ │ │ -
537 template <class T1, class T2, class U>
│ │ │ │ -
│ │ │ │ -
538 void Update2ndDerivs(T1 const & srcBase, int numBase, T2 const & srcRef,
│ │ │ │ -
539 U & uuderivs, U & uvderivs, U & vvderivs, int start=-1, int end=-1) const {
│ │ │ │ -
540
│ │ │ │ -
541 this->update(srcBase, numBase, srcRef, uuderivs, _duuWeights, start, end);
│ │ │ │ -
542 this->update(srcBase, numBase, srcRef, uvderivs, _duvWeights, start, end);
│ │ │ │ -
543 this->update(srcBase, numBase, srcRef, vvderivs, _dvvWeights, start, end);
│ │ │ │ -
544 }
│ │ │ │ -
│ │ │ │ -
545
│ │ │ │ -
546 // Pointer interface for backward compatibility
│ │ │ │ -
547 template <class T, class U>
│ │ │ │ -
│ │ │ │ -
548 void Update2ndDerivs(T const *src, T *uuderivs, U *uvderivs, U *vvderivs,
│ │ │ │ -
549 int start=-1, int end=-1) const {
│ │ │ │ -
550
│ │ │ │ -
551 this->update(src, uuderivs, _duuWeights, start, end);
│ │ │ │ -
552 this->update(src, uvderivs, _duvWeights, start, end);
│ │ │ │ -
553 this->update(src, vvderivs, _dvvWeights, start, end);
│ │ │ │ -
554 }
│ │ │ │ -
│ │ │ │ -
555 template <class T1, class T2, class U>
│ │ │ │ -
│ │ │ │ -
556 void Update2ndDerivs(T1 const *srcBase, int numBase, T2 const *srcRef,
│ │ │ │ -
557 U *uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const {
│ │ │ │ -
558
│ │ │ │ -
559 this->update(srcBase, numBase, srcRef, uuderivs, _duuWeights, start, end);
│ │ │ │ -
560 this->update(srcBase, numBase, srcRef, uvderivs, _duvWeights, start, end);
│ │ │ │ -
561 this->update(srcBase, numBase, srcRef, vvderivs, _dvvWeights, start, end);
│ │ │ │ -
562 }
│ │ │ │ -
│ │ │ │ -
563
│ │ │ │ -
565 void Clear();
│ │ │ │ -
566
│ │ │ │ -
567private:
│ │ │ │ -
568 friend class LimitStencilTableFactoryReal<REAL>;
│ │ │ │ -
569
│ │ │ │ -
570 // Resize the table arrays (factory helper)
│ │ │ │ -
571 void resize(int nstencils, int nelems);
│ │ │ │ -
572
│ │ │ │ -
573private:
│ │ │ │ -
574 std::vector<REAL> _duWeights, // u derivative limit stencil weights
│ │ │ │ -
575 _dvWeights, // v derivative limit stencil weights
│ │ │ │ -
576 _duuWeights, // uu derivative limit stencil weights
│ │ │ │ -
577 _duvWeights, // uv derivative limit stencil weights
│ │ │ │ -
578 _dvvWeights; // vv derivative limit stencil weights
│ │ │ │ -
579};
│ │ │ │ -
580
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
584protected:
│ │ │ │ - │ │ │ │ -
586
│ │ │ │ -
587public:
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ -
590 }
│ │ │ │ -
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ -
593 }
│ │ │ │ -
│ │ │ │ -
594
│ │ │ │ -
595protected:
│ │ │ │ -
│ │ │ │ -
596 LimitStencilTable(int numControlVerts,
│ │ │ │ -
597 std::vector<int> const& offsets,
│ │ │ │ -
598 std::vector<int> const& sizes,
│ │ │ │ -
599 std::vector<int> const& sources,
│ │ │ │ -
600 std::vector<float> const& weights,
│ │ │ │ -
601 std::vector<float> const& duWeights,
│ │ │ │ -
602 std::vector<float> const& dvWeights,
│ │ │ │ -
603 std::vector<float> const& duuWeights,
│ │ │ │ -
604 std::vector<float> const& duvWeights,
│ │ │ │ -
605 std::vector<float> const& dvvWeights,
│ │ │ │ -
606 bool includeCoarseVerts,
│ │ │ │ -
607 size_t firstOffset)
│ │ │ │ -
608 : BaseTable(numControlVerts,
│ │ │ │ -
609 offsets, sizes, sources, weights,
│ │ │ │ -
610 duWeights, dvWeights, duuWeights, duvWeights, dvvWeights,
│ │ │ │ -
611 includeCoarseVerts, firstOffset) { }
│ │ │ │ -
│ │ │ │ -
612};
│ │ │ │ -
│ │ │ │ -
613
│ │ │ │ -
614
│ │ │ │ -
615// Update values by applying cached stencil weights to new control values
│ │ │ │ -
616template <typename REAL>
│ │ │ │ -
617template <class T1, class T2, class U> void
│ │ │ │ -
│ │ │ │ -
618StencilTableReal<REAL>::update(T1 const &srcBase, int numBase,
│ │ │ │ -
619 T2 const &srcRef, U &dstValues,
│ │ │ │ -
620 std::vector<REAL> const &valueWeights, Index start, Index end) const {
│ │ │ │ -
621
│ │ │ │ -
622 int const * sizes = &_sizes.at(0);
│ │ │ │ -
623 Index const * indices = &_indices.at(0);
│ │ │ │ -
624 REAL const * weights = &valueWeights.at(0);
│ │ │ │ -
625
│ │ │ │ -
626 if (start > 0) {
│ │ │ │ -
627 assert(start < (Index)_offsets.size());
│ │ │ │ -
628 sizes += start;
│ │ │ │ -
629 indices += _offsets[start];
│ │ │ │ -
630 weights += _offsets[start];
│ │ │ │ -
631 } else {
│ │ │ │ -
632 start = 0;
│ │ │ │ -
633 }
│ │ │ │ -
634
│ │ │ │ -
635 int nstencils = ((end < start) ? GetNumStencils() : end) - start;
│ │ │ │ -
636
│ │ │ │ -
637 for (int i = 0; i < nstencils; ++i, ++sizes) {
│ │ │ │ -
638 dstValues[start + i].Clear();
│ │ │ │ -
639 for (int j = 0; j < *sizes; ++j, ++indices, ++weights) {
│ │ │ │ -
640 if (*indices < numBase) {
│ │ │ │ -
641 dstValues[start + i].AddWithWeight(srcBase[*indices], *weights);
│ │ │ │ -
642 } else {
│ │ │ │ -
643 dstValues[start + i].AddWithWeight(srcRef[*indices - numBase], *weights);
│ │ │ │ -
644 }
│ │ │ │ -
645 }
│ │ │ │ -
646 }
│ │ │ │ -
647}
│ │ │ │ -
│ │ │ │ -
648template <typename REAL>
│ │ │ │ -
649template <class T, class U> void
│ │ │ │ -
│ │ │ │ -
650StencilTableReal<REAL>::update(T const &srcValues, U &dstValues,
│ │ │ │ -
651 std::vector<REAL> const &valueWeights, Index start, Index end) const {
│ │ │ │ -
652
│ │ │ │ -
653 int const * sizes = &_sizes.at(0);
│ │ │ │ -
654 Index const * indices = &_indices.at(0);
│ │ │ │ -
655 REAL const * weights = &valueWeights.at(0);
│ │ │ │ -
656
│ │ │ │ -
657 if (start > 0) {
│ │ │ │ -
658 assert(start < (Index)_offsets.size());
│ │ │ │ -
659 sizes += start;
│ │ │ │ -
660 indices += _offsets[start];
│ │ │ │ -
661 weights += _offsets[start];
│ │ │ │ -
662 } else {
│ │ │ │ -
663 start = 0;
│ │ │ │ -
664 }
│ │ │ │ -
665
│ │ │ │ -
666 int nstencils = ((end < start) ? GetNumStencils() : end) - start;
│ │ │ │ -
667
│ │ │ │ -
668 for (int i = 0; i < nstencils; ++i, ++sizes) {
│ │ │ │ -
669 dstValues[start + i].Clear();
│ │ │ │ -
670 for (int j = 0; j < *sizes; ++j, ++indices, ++weights) {
│ │ │ │ -
671 dstValues[start + i].AddWithWeight(srcValues[*indices], *weights);
│ │ │ │ -
672 }
│ │ │ │ -
673 }
│ │ │ │ -
674}
│ │ │ │ -
│ │ │ │ -
675
│ │ │ │ -
676template <typename REAL>
│ │ │ │ -
677inline void
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
679 Index offset=0;
│ │ │ │ -
680 int noffsets = (int)_sizes.size();
│ │ │ │ -
681 _offsets.resize(noffsets);
│ │ │ │ -
682 for (int i=0; i<(int)_sizes.size(); ++i ) {
│ │ │ │ -
683 _offsets[i]=offset;
│ │ │ │ -
684 offset+=_sizes[i];
│ │ │ │ -
685 }
│ │ │ │ -
686}
│ │ │ │ -
│ │ │ │ -
687
│ │ │ │ -
688template <typename REAL>
│ │ │ │ -
689inline void
│ │ │ │ -
│ │ │ │ -
690StencilTableReal<REAL>::resize(int nstencils, int nelems) {
│ │ │ │ -
691 _sizes.resize(nstencils);
│ │ │ │ -
692 _indices.resize(nelems);
│ │ │ │ -
693 _weights.resize(nelems);
│ │ │ │ -
694}
│ │ │ │ -
│ │ │ │ -
695
│ │ │ │ -
696template <typename REAL>
│ │ │ │ -
697inline void
│ │ │ │ -
│ │ │ │ -
698StencilTableReal<REAL>::reserve(int nstencils, int nelems) {
│ │ │ │ -
699 _sizes.reserve(nstencils);
│ │ │ │ -
700 _indices.reserve(nelems);
│ │ │ │ -
701 _weights.reserve(nelems);
│ │ │ │ -
702}
│ │ │ │ -
│ │ │ │ -
703
│ │ │ │ -
704template <typename REAL>
│ │ │ │ -
705inline void
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
707 std::vector<int>(_sizes).swap(_sizes);
│ │ │ │ -
708 std::vector<Index>(_indices).swap(_indices);
│ │ │ │ -
709 std::vector<REAL>(_weights).swap(_weights);
│ │ │ │ -
710}
│ │ │ │ -
│ │ │ │ -
711
│ │ │ │ -
712template <typename REAL>
│ │ │ │ -
713inline void
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
715 shrinkToFit();
│ │ │ │ -
716 generateOffsets();
│ │ │ │ -
717}
│ │ │ │ -
│ │ │ │ -
718
│ │ │ │ -
719// Returns a Stencil at index i in the table
│ │ │ │ -
720template <typename REAL>
│ │ │ │ - │ │ │ │ -
│ │ │ │ - │ │ │ │ -
723 assert((! _offsets.empty()) && i<(int)_offsets.size());
│ │ │ │ -
724
│ │ │ │ -
725 Index ofs = _offsets[i];
│ │ │ │ -
726
│ │ │ │ -
727 return StencilReal<REAL>(const_cast<int*>(&_sizes[i]),
│ │ │ │ -
728 const_cast<Index*>(&_indices[ofs]),
│ │ │ │ -
729 const_cast<REAL*>(&_weights[ofs]));
│ │ │ │ -
730}
│ │ │ │ -
│ │ │ │ -
731
│ │ │ │ -
732template <typename REAL>
│ │ │ │ - │ │ │ │ -
│ │ │ │ - │ │ │ │ -
735 return GetStencil(index);
│ │ │ │ -
736}
│ │ │ │ -
│ │ │ │ -
737
│ │ │ │ -
738template <typename REAL>
│ │ │ │ -
739inline void
│ │ │ │ -
740LimitStencilTableReal<REAL>::resize(int nstencils, int nelems) {
│ │ │ │ -
741 StencilTableReal<REAL>::resize(nstencils, nelems);
│ │ │ │ -
742 _duWeights.resize(nelems);
│ │ │ │ -
743 _dvWeights.resize(nelems);
│ │ │ │ -
744}
│ │ │ │ -
745
│ │ │ │ -
746// Returns a LimitStencil at index i in the table
│ │ │ │ -
747template <typename REAL>
│ │ │ │ -
748inline LimitStencilReal<REAL>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
750 assert((! this->GetOffsets().empty()) && i<(int)this->GetOffsets().size());
│ │ │ │ -
751
│ │ │ │ -
752 Index ofs = this->GetOffsets()[i];
│ │ │ │ -
753
│ │ │ │ -
754 if (!_duWeights.empty() && !_dvWeights.empty() &&
│ │ │ │ -
755 !_duuWeights.empty() && !_duvWeights.empty() && !_dvvWeights.empty()) {
│ │ │ │ - │ │ │ │ -
757 const_cast<int *>(&this->GetSizes()[i]),
│ │ │ │ -
758 const_cast<Index *>(&this->GetControlIndices()[ofs]),
│ │ │ │ -
759 const_cast<REAL *>(&this->GetWeights()[ofs]),
│ │ │ │ -
760 const_cast<REAL *>(&GetDuWeights()[ofs]),
│ │ │ │ -
761 const_cast<REAL *>(&GetDvWeights()[ofs]),
│ │ │ │ -
762 const_cast<REAL *>(&GetDuuWeights()[ofs]),
│ │ │ │ -
763 const_cast<REAL *>(&GetDuvWeights()[ofs]),
│ │ │ │ -
764 const_cast<REAL *>(&GetDvvWeights()[ofs]) );
│ │ │ │ -
765 } else if (!_duWeights.empty() && !_dvWeights.empty()) {
│ │ │ │ - │ │ │ │ -
767 const_cast<int *>(&this->GetSizes()[i]),
│ │ │ │ -
768 const_cast<Index *>(&this->GetControlIndices()[ofs]),
│ │ │ │ -
769 const_cast<REAL *>(&this->GetWeights()[ofs]),
│ │ │ │ -
770 const_cast<REAL *>(&GetDuWeights()[ofs]),
│ │ │ │ -
771 const_cast<REAL *>(&GetDvWeights()[ofs]) );
│ │ │ │ -
772 } else {
│ │ │ │ - │ │ │ │ -
774 const_cast<int *>(&this->GetSizes()[i]),
│ │ │ │ -
775 const_cast<Index *>(&this->GetControlIndices()[ofs]),
│ │ │ │ -
776 const_cast<REAL *>(&this->GetWeights()[ofs]) );
│ │ │ │ -
777 }
│ │ │ │ -
778}
│ │ │ │ -
│ │ │ │ -
779
│ │ │ │ -
780template <typename REAL>
│ │ │ │ - │ │ │ │ -
│ │ │ │ - │ │ │ │ -
783 return GetLimitStencil(index);
│ │ │ │ -
784}
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
785
│ │ │ │ -
786} // end namespace Far
│ │ │ │ -
787
│ │ │ │ -
788} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
789using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
790
│ │ │ │ -
791} // end namespace OpenSubdiv
│ │ │ │ -
792
│ │ │ │ -
793#endif // OPENSUBDIV3_FAR_STENCILTABLE_H
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
StencilReal(int *size, Index *indices, REAL *weights)
Constructor.
│ │ │ │ -
void Next()
Advance to the next stencil in the table.
│ │ │ │ -
StencilReal(StencilReal const &other)
Copy constructor.
│ │ │ │ - │ │ │ │ -
Index const * GetVertexIndices() const
Returns the control vertices' indices.
│ │ │ │ -
int GetSize() const
Returns the size of the stencil.
│ │ │ │ - │ │ │ │ -
int * GetSizePtr() const
Returns the size of the stencil as a pointer.
│ │ │ │ -
REAL const * GetWeights() const
Returns the interpolation weights.
│ │ │ │ -
Vertex stencil class wrapping the template for compatibility.
│ │ │ │ - │ │ │ │ -
Stencil(int *size, Index *indices, float *weights)
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
int GetNumControlVertices() const
Returns the number of control vertices indexed in the table.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
void update(T1 const &srcBase, int numBase, T2 const &srcRef, U &dstValues, std::vector< REAL > const &valueWeights, Index start, Index end) const
│ │ │ │ -
void UpdateValues(T1 const &srcBase, int numBase, T2 const &srcRef, U &dstValues, Index start=-1, Index end=-1) const
│ │ │ │ -
std::vector< Index > const & GetControlIndices() const
Returns the indices of the control vertices.
│ │ │ │ - │ │ │ │ -
StencilReal< REAL > operator[](Index index) const
Returns the stencil at index i in the table.
│ │ │ │ - │ │ │ │ -
void update(T const &srcValues, U &dstValues, std::vector< REAL > const &valueWeights, Index start, Index end) const
│ │ │ │ -
std::vector< int > const & GetSizes() const
Returns the number of control vertices of each stencil in the table.
│ │ │ │ -
int GetNumStencils() const
Returns the number of stencils in the table.
│ │ │ │ - │ │ │ │ -
std::vector< Index > const & GetOffsets() const
Returns the offset to a given stencil (factory may leave empty)
│ │ │ │ -
StencilReal< REAL > GetStencil(Index i) const
Returns a Stencil at index i in the table.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
void Clear()
Clears the stencils from the table.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
std::vector< REAL > const & GetWeights() const
Returns the stencil interpolation weights.
│ │ │ │ -
void UpdateValues(T1 const *srcBase, int numBase, T2 const *srcRef, U *dst, Index start=-1, Index end=-1) const
│ │ │ │ -
StencilTableReal(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< REAL > const &weights, bool includeCoarseVerts, size_t firstOffset)
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
void UpdateValues(T const *src, U *dst, Index start=-1, Index end=-1) const
│ │ │ │ -
void UpdateValues(T const &srcValues, U &dstValues, Index start=-1, Index end=-1) const
Updates point values based on the control values.
│ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ -
StencilTable(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< float > const &weights, bool includeCoarseVerts, size_t firstOffset)
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
REAL const * GetDuvWeights() const
Returns the uv derivative weights.
│ │ │ │ -
REAL const * GetDvWeights() const
Returns the v derivative weights.
│ │ │ │ -
void Next()
Advance to the next stencil in the table.
│ │ │ │ -
REAL const * GetDvvWeights() const
Returns the vv derivative weights.
│ │ │ │ -
LimitStencilReal(int *size, Index *indices, REAL *weights, REAL *duWeights=0, REAL *dvWeights=0, REAL *duuWeights=0, REAL *duvWeights=0, REAL *dvvWeights=0)
Constructor.
│ │ │ │ -
REAL const * GetDuWeights() const
Returns the u derivative weights.
│ │ │ │ -
REAL const * GetDuuWeights() const
Returns the uu derivative weights.
│ │ │ │ -
Limit point stencil class wrapping the template for compatibility.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
LimitStencil(int *size, Index *indices, float *weights, float *duWeights=0, float *dvWeights=0, float *duuWeights=0, float *duvWeights=0, float *dvvWeights=0)
│ │ │ │ - │ │ │ │ -
std::vector< REAL > const & GetDuuWeights() const
Returns the 'uu' derivative stencil interpolation weights.
│ │ │ │ -
LimitStencilReal< REAL > operator[](Index index) const
Returns the limit stencil at index i in the table.
│ │ │ │ -
std::vector< REAL > const & GetDvvWeights() const
Returns the 'vv' derivative stencil interpolation weights.
│ │ │ │ -
void UpdateDerivs(T const *src, U *uderivs, U *vderivs, int start=-1, int end=-1) const
│ │ │ │ -
void Update2ndDerivs(T const *src, T *uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const
│ │ │ │ -
std::vector< REAL > const & GetDvWeights() const
Returns the 'v' derivative stencil interpolation weights.
│ │ │ │ -
void Update2ndDerivs(T1 const *srcBase, int numBase, T2 const *srcRef, U *uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const
│ │ │ │ -
void UpdateDerivs(T const &srcValues, U &uderivs, U &vderivs, int start=-1, int end=-1) const
Updates derivative values based on the control values.
│ │ │ │ -
LimitStencilReal< REAL > GetLimitStencil(Index i) const
Returns a LimitStencil at index i in the table.
│ │ │ │ -
LimitStencilTableReal(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< REAL > const &weights, std::vector< REAL > const &duWeights, std::vector< REAL > const &dvWeights, std::vector< REAL > const &duuWeights, std::vector< REAL > const &duvWeights, std::vector< REAL > const &dvvWeights, bool includeCoarseVerts, size_t firstOffset)
│ │ │ │ -
void Update2ndDerivs(T const &srcValues, U &uuderivs, U &uvderivs, U &vvderivs, int start=-1, int end=-1) const
Updates 2nd derivative values based on the control values.
│ │ │ │ -
std::vector< REAL > const & GetDuWeights() const
Returns the 'u' derivative stencil interpolation weights.
│ │ │ │ -
void Clear()
Clears the stencils from the table.
│ │ │ │ -
void Update2ndDerivs(T1 const &srcBase, int numBase, T2 const &srcRef, U &uuderivs, U &uvderivs, U &vvderivs, int start=-1, int end=-1) const
│ │ │ │ -
std::vector< REAL > const & GetDuvWeights() const
Returns the 'uv' derivative stencil interpolation weights.
│ │ │ │ -
void UpdateDerivs(T1 const &srcBase, int numBase, T2 const &srcRef, U &uderivs, U &vderivs, int start=-1, int end=-1) const
│ │ │ │ -
void UpdateDerivs(T1 const *srcBase, int numBase, T2 const *srcRef, U *uderivs, U *vderivs, int start=-1, int end=-1) const
│ │ │ │ -
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
LimitStencilTable(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< float > const &weights, std::vector< float > const &duWeights, std::vector< float > const &dvWeights, std::vector< float > const &duuWeights, std::vector< float > const &duvWeights, std::vector< float > const &dvvWeights, bool includeCoarseVerts, size_t firstOffset)
│ │ │ │ - │ │ │ │ +
│ │ │ │ +
300 static StencilTable const * Create(
│ │ │ │ +
301 int numTables, StencilTable const ** tables) {
│ │ │ │ +
302
│ │ │ │ +
303 return static_cast<StencilTable const *>(
│ │ │ │ +
304 BaseFactory::Create(numTables,
│ │ │ │ +
305 reinterpret_cast<BaseTable const **>(tables)));
│ │ │ │ +
306 }
│ │ │ │ +
│ │ │ │ +
307
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
309 TopologyRefiner const &refiner,
│ │ │ │ +
310 StencilTable const *baseStencilTable,
│ │ │ │ +
311 StencilTable const *localPointStencilTable,
│ │ │ │ +
312 bool factorize = true) {
│ │ │ │ +
313
│ │ │ │ +
314 return static_cast<StencilTable const *>(
│ │ │ │ + │ │ │ │ +
316 static_cast<BaseTable const *>(baseStencilTable),
│ │ │ │ +
317 static_cast<BaseTable const *>(localPointStencilTable),
│ │ │ │ +
318 factorize));
│ │ │ │ +
319 }
│ │ │ │ +
│ │ │ │ +
320
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
322 TopologyRefiner const &refiner,
│ │ │ │ +
323 StencilTable const *baseStencilTable,
│ │ │ │ +
324 StencilTable const *localPointStencilTable,
│ │ │ │ +
325 bool factorize = true) {
│ │ │ │ +
326
│ │ │ │ +
327 return static_cast<StencilTable const *>(
│ │ │ │ + │ │ │ │ +
329 static_cast<BaseTable const *>(baseStencilTable),
│ │ │ │ +
330 static_cast<BaseTable const *>(localPointStencilTable),
│ │ │ │ +
331 factorize));
│ │ │ │ +
332 }
│ │ │ │ +
│ │ │ │ +
333
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
335 TopologyRefiner const &refiner,
│ │ │ │ +
336 StencilTable const *baseStencilTable,
│ │ │ │ +
337 StencilTable const *localPointStencilTable,
│ │ │ │ +
338 int channel = 0,
│ │ │ │ +
339 bool factorize = true) {
│ │ │ │ +
340
│ │ │ │ +
341 return static_cast<StencilTable const *>(
│ │ │ │ + │ │ │ │ +
343 static_cast<BaseTable const *>(baseStencilTable),
│ │ │ │ +
344 static_cast<BaseTable const *>(localPointStencilTable),
│ │ │ │ +
345 channel, factorize));
│ │ │ │ +
346 }
│ │ │ │ +
│ │ │ │ +
347};
│ │ │ │ +
│ │ │ │ +
348
│ │ │ │ +
349class LimitStencil;
│ │ │ │ +
350class LimitStencilTable;
│ │ │ │ +
351
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
355private:
│ │ │ │ + │ │ │ │ + │ │ │ │ +
358
│ │ │ │ +
359public:
│ │ │ │ +
│ │ │ │ +
360 static LimitStencilTable const * Create(
│ │ │ │ +
361 TopologyRefiner const & refiner,
│ │ │ │ +
362 LocationArrayVec const & locationArrays,
│ │ │ │ +
363 StencilTable const * cvStencils = 0,
│ │ │ │ +
364 PatchTable const * patchTable = 0,
│ │ │ │ +
365 Options options = Options()) {
│ │ │ │ +
366
│ │ │ │ +
367 return static_cast<LimitStencilTable const *>(
│ │ │ │ + │ │ │ │ +
369 refiner,
│ │ │ │ +
370 locationArrays,
│ │ │ │ +
371 static_cast<BaseTable const *>(cvStencils),
│ │ │ │ +
372 patchTable,
│ │ │ │ +
373 options));
│ │ │ │ +
374 }
│ │ │ │ +
│ │ │ │ +
375};
│ │ │ │ +
│ │ │ │ +
376
│ │ │ │ +
377} // end namespace Far
│ │ │ │ +
378
│ │ │ │ +
379} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
380using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
381
│ │ │ │ +
382} // end namespace OpenSubdiv
│ │ │ │ +
383
│ │ │ │ +
384#endif // OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H
│ │ │ │ + │ │ │ │ +
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ + │ │ │ │ +
static StencilTableReal< REAL > const * Create(TopologyRefiner const &refiner, Options options=Options())
Instantiates StencilTable from TopologyRefiner that have been refined uniformly or adaptively.
│ │ │ │ +
static StencilTableReal< REAL > const * AppendLocalPointStencilTableFaceVarying(TopologyRefiner const &refiner, StencilTableReal< REAL > const *baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, int channel=0, bool factorize=true)
Utility function for stencil splicing for local point face-varying stencils.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
static StencilTableReal< REAL > const * AppendLocalPointStencilTableVarying(TopologyRefiner const &refiner, StencilTableReal< REAL > const *baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, bool factorize=true)
Utility function for stencil splicing for local point varying stencils.
│ │ │ │ +
static StencilTableReal< REAL > const * AppendLocalPointStencilTable(TopologyRefiner const &refiner, StencilTableReal< REAL > const *baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, bool factorize=true)
Utility function for stencil splicing for local point stencils.
│ │ │ │ +
static StencilTableReal< REAL > const * Create(int numTables, StencilTableReal< REAL > const **tables)
Instantiates StencilTable by concatenating an array of existing stencil tables.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
static LimitStencilTableReal< REAL > const * Create(TopologyRefiner const &refiner, LocationArrayVec const &locationArrays, StencilTableReal< REAL > const *cvStencils=0, PatchTable const *patchTable=0, Options options=Options())
Instantiates LimitStencilTable from a TopologyRefiner that has been refined either uniformly or adapt...
│ │ │ │ + │ │ │ │ +
Vertex stencil class wrapping the template for compatibility.
│ │ │ │ + │ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ + │ │ │ │ +
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
unsigned int generateIntermediateLevels
vertices at all levels or highest only
│ │ │ │ +
unsigned int generateControlVerts
generate stencils for control-vertices
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
unsigned int generate2ndDerivatives
Generate weights for 2nd derivatives.
│ │ │ │ +
unsigned int generate1stDerivatives
Generate weights for 1st derivatives.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
Stencil table factory class wrapping the template for compatibility.
│ │ │ │ +
static StencilTable const * AppendLocalPointStencilTableVarying(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, StencilTable const *localPointStencilTable, bool factorize=true)
│ │ │ │ +
static StencilTable const * Create(TopologyRefiner const &refiner, Options options=Options())
│ │ │ │ +
static StencilTable const * AppendLocalPointStencilTableFaceVarying(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, StencilTable const *localPointStencilTable, int channel=0, bool factorize=true)
│ │ │ │ +
static StencilTable const * AppendLocalPointStencilTable(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, StencilTable const *localPointStencilTable, bool factorize=true)
│ │ │ │ +
static StencilTable const * Create(int numTables, StencilTable const **tables)
│ │ │ │ +
Stencil table factory class wrapping the template for compatibility.
│ │ │ │ +
static LimitStencilTable const * Create(TopologyRefiner const &refiner, LocationArrayVec const &locationArrays, StencilTable const *cvStencils=0, PatchTable const *patchTable=0, Options options=Options())
│ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -stencilTable.h │ │ │ │ │ +stencilTableFactory.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,990 +24,497 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_FAR_STENCILTABLE_H │ │ │ │ │ -26#define OPENSUBDIV3_FAR_STENCILTABLE_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H │ │ │ │ │ +26#define OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ 29 │ │ │ │ │ -30#include "../far/types.h" │ │ │ │ │ +30#include "../far/patchTable.h" │ │ │ │ │ 31 │ │ │ │ │ -32#include │ │ │ │ │ -33#include │ │ │ │ │ -34#include │ │ │ │ │ -35#include │ │ │ │ │ +32#include │ │ │ │ │ +33 │ │ │ │ │ +34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +35namespace OPENSUBDIV_VERSION { │ │ │ │ │ 36 │ │ │ │ │ -37namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -38namespace OPENSUBDIV_VERSION { │ │ │ │ │ -39 │ │ │ │ │ -40namespace Far { │ │ │ │ │ -41 │ │ │ │ │ -42// Forward declarations for friends: │ │ │ │ │ -43class PatchTableBuilder; │ │ │ │ │ -44 │ │ │ │ │ -45template class StencilTableFactoryReal; │ │ │ │ │ -46template class LimitStencilTableFactoryReal; │ │ │ │ │ +37namespace Far { │ │ │ │ │ +38 │ │ │ │ │ +39class TopologyRefiner; │ │ │ │ │ +40 │ │ │ │ │ +41template class StencilReal; │ │ │ │ │ +42template class StencilTableReal; │ │ │ │ │ +43 │ │ │ │ │ +44template class LimitStencilReal; │ │ │ │ │ +45template class LimitStencilTableReal; │ │ │ │ │ +46 │ │ │ │ │ 47 │ │ │ │ │ -52template │ │ │ │ │ -_5_3class _S_t_e_n_c_i_l_R_e_a_l { │ │ │ │ │ -54public: │ │ │ │ │ -55 │ │ │ │ │ -_5_7 _S_t_e_n_c_i_l_R_e_a_l() {} │ │ │ │ │ -58 │ │ │ │ │ -_6_7 _S_t_e_n_c_i_l_R_e_a_l(int * size, _I_n_d_e_x * indices, REAL * weights) │ │ │ │ │ -68 : ___s_i_z_e(size), ___i_n_d_i_c_e_s(indices), ___w_e_i_g_h_t_s(weights) { } │ │ │ │ │ -69 │ │ │ │ │ -_7_1 _S_t_e_n_c_i_l_R_e_a_l(_S_t_e_n_c_i_l_R_e_a_l const & other) { │ │ │ │ │ -72 ___s_i_z_e = other.___s_i_z_e; │ │ │ │ │ -73 ___i_n_d_i_c_e_s = other.___i_n_d_i_c_e_s; │ │ │ │ │ -74 ___w_e_i_g_h_t_s = other.___w_e_i_g_h_t_s; │ │ │ │ │ -75 } │ │ │ │ │ -76 │ │ │ │ │ -_7_8 int _G_e_t_S_i_z_e() const { │ │ │ │ │ -79 return *___s_i_z_e; │ │ │ │ │ -80 } │ │ │ │ │ -81 │ │ │ │ │ -_8_3 int * _G_e_t_S_i_z_e_P_t_r() const { │ │ │ │ │ -84 return ___s_i_z_e; │ │ │ │ │ -85 } │ │ │ │ │ -86 │ │ │ │ │ -_8_8 _I_n_d_e_x const * _G_e_t_V_e_r_t_e_x_I_n_d_i_c_e_s() const { │ │ │ │ │ -89 return ___i_n_d_i_c_e_s; │ │ │ │ │ -90 } │ │ │ │ │ -91 │ │ │ │ │ -_9_3 REAL const * _G_e_t_W_e_i_g_h_t_s() const { │ │ │ │ │ -94 return ___w_e_i_g_h_t_s; │ │ │ │ │ -95 } │ │ │ │ │ +50template │ │ │ │ │ +_5_1class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l { │ │ │ │ │ +52 │ │ │ │ │ +53public: │ │ │ │ │ +54 │ │ │ │ │ +_5_5 enum _M_o_d_e { │ │ │ │ │ +_5_6 _I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X=0, │ │ │ │ │ +_5_7 _I_N_T_E_R_P_O_L_A_T_E___V_A_R_Y_I_N_G, │ │ │ │ │ +58 _I_N_T_E_R_P_O_L_A_T_E___F_A_C_E___V_A_R_Y_I_N_G │ │ │ │ │ +_5_9 }; │ │ │ │ │ +60 │ │ │ │ │ +_6_1 struct _O_p_t_i_o_n_s { │ │ │ │ │ +62 │ │ │ │ │ +_6_3 _O_p_t_i_o_n_s() : _i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e(_I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X), │ │ │ │ │ +64 _g_e_n_e_r_a_t_e_O_f_f_s_e_t_s(false), │ │ │ │ │ +65 _g_e_n_e_r_a_t_e_C_o_n_t_r_o_l_V_e_r_t_s(false), │ │ │ │ │ +66 _g_e_n_e_r_a_t_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s(true), │ │ │ │ │ +67 _f_a_c_t_o_r_i_z_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s(true), │ │ │ │ │ +68 _m_a_x_L_e_v_e_l(10), │ │ │ │ │ +69 _f_v_a_r_C_h_a_n_n_e_l(0) { } │ │ │ │ │ +70 │ │ │ │ │ +_7_1 unsigned int _i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e : 2, │ │ │ │ │ +_7_2 _g_e_n_e_r_a_t_e_O_f_f_s_e_t_s : 1, │ │ │ │ │ +_7_3 _g_e_n_e_r_a_t_e_C_o_n_t_r_o_l_V_e_r_t_s : 1, │ │ │ │ │ +_7_4 _g_e_n_e_r_a_t_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s : 1, │ │ │ │ │ +_7_5 _f_a_c_t_o_r_i_z_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s : 1, │ │ │ │ │ +_7_8 _m_a_x_L_e_v_e_l : 4; │ │ │ │ │ +_7_9 unsigned int _f_v_a_r_C_h_a_n_n_e_l; │ │ │ │ │ +81 }; │ │ │ │ │ +82 │ │ │ │ │ +_9_4 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _C_r_e_a_t_e( │ │ │ │ │ +95 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, _O_p_t_i_o_n_s options = _O_p_t_i_o_n_s()); │ │ │ │ │ 96 │ │ │ │ │ -_9_8 void _N_e_x_t() { │ │ │ │ │ -99 int stride = *___s_i_z_e; │ │ │ │ │ -100 ++___s_i_z_e; │ │ │ │ │ -101 ___i_n_d_i_c_e_s += stride; │ │ │ │ │ -102 ___w_e_i_g_h_t_s += stride; │ │ │ │ │ -103 } │ │ │ │ │ -104 │ │ │ │ │ -105protected: │ │ │ │ │ -106 friend class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ -107 friend class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ -108 │ │ │ │ │ -_1_0_9 int * ___s_i_z_e; │ │ │ │ │ -_1_1_0 _I_n_d_e_x * ___i_n_d_i_c_e_s; │ │ │ │ │ -_1_1_1 REAL * ___w_e_i_g_h_t_s; │ │ │ │ │ -112}; │ │ │ │ │ +97 │ │ │ │ │ +_1_1_0 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _C_r_e_a_t_e( │ │ │ │ │ +111 int numTables, _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const ** tables); │ │ │ │ │ +112 │ │ │ │ │ 113 │ │ │ │ │ -_1_1_6class _S_t_e_n_c_i_l : public _S_t_e_n_c_i_l_R_e_a_l { │ │ │ │ │ -117protected: │ │ │ │ │ -_1_1_8 typedef _S_t_e_n_c_i_l_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_S_t_e_n_c_i_l; │ │ │ │ │ -119 │ │ │ │ │ -120public: │ │ │ │ │ -_1_2_1 _S_t_e_n_c_i_l() : _B_a_s_e_S_t_e_n_c_i_l() { } │ │ │ │ │ -_1_2_2 _S_t_e_n_c_i_l(_B_a_s_e_S_t_e_n_c_i_l const & other) : _B_a_s_e_S_t_e_n_c_i_l(other) { } │ │ │ │ │ -_1_2_3 _S_t_e_n_c_i_l(int * size, _I_n_d_e_x * indices, float * weights) │ │ │ │ │ -124 : _B_a_s_e_S_t_e_n_c_i_l(size, indices, weights) { } │ │ │ │ │ -125}; │ │ │ │ │ -126 │ │ │ │ │ -127 │ │ │ │ │ -140template │ │ │ │ │ -_1_4_1class _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l { │ │ │ │ │ -142protected: │ │ │ │ │ -_1_4_3 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l(int numControlVerts, │ │ │ │ │ -144 std::vector const& offsets, │ │ │ │ │ -145 std::vector const& sizes, │ │ │ │ │ -146 std::vector const& sources, │ │ │ │ │ -147 std::vector const& weights, │ │ │ │ │ -148 bool includeCoarseVerts, │ │ │ │ │ -149 size_t firstOffset); │ │ │ │ │ -150 │ │ │ │ │ -151public: │ │ │ │ │ -152 │ │ │ │ │ -_1_5_3 virtual _~_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l() {}; │ │ │ │ │ -154 │ │ │ │ │ -_1_5_6 int _G_e_t_N_u_m_S_t_e_n_c_i_l_s() const { │ │ │ │ │ -157 return (int)___s_i_z_e_s.size(); │ │ │ │ │ -158 } │ │ │ │ │ -159 │ │ │ │ │ -_1_6_1 int _G_e_t_N_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s() const { │ │ │ │ │ -162 return ___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s; │ │ │ │ │ -163 } │ │ │ │ │ -164 │ │ │ │ │ -_1_6_6 _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> _G_e_t_S_t_e_n_c_i_l(_I_n_d_e_x i) const; │ │ │ │ │ -167 │ │ │ │ │ -_1_6_9 std::vector const & _G_e_t_S_i_z_e_s() const { │ │ │ │ │ -170 return ___s_i_z_e_s; │ │ │ │ │ -171 } │ │ │ │ │ -172 │ │ │ │ │ -_1_7_4 std::vector const & _G_e_t_O_f_f_s_e_t_s() const { │ │ │ │ │ -175 return ___o_f_f_s_e_t_s; │ │ │ │ │ -176 } │ │ │ │ │ -177 │ │ │ │ │ -_1_7_9 std::vector const & _G_e_t_C_o_n_t_r_o_l_I_n_d_i_c_e_s() const { │ │ │ │ │ -180 return ___i_n_d_i_c_e_s; │ │ │ │ │ -181 } │ │ │ │ │ +_1_2_8 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e( │ │ │ │ │ +129 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ +130 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *baseStencilTable, │ │ │ │ │ +131 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *localPointStencilTable, │ │ │ │ │ +132 bool factorize = true); │ │ │ │ │ +133 │ │ │ │ │ +_1_4_8 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g( │ │ │ │ │ +149 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ +150 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *baseStencilTable, │ │ │ │ │ +151 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *localPointStencilTable, │ │ │ │ │ +152 bool factorize = true) { │ │ │ │ │ +153 return _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e( │ │ │ │ │ +154 refiner, baseStencilTable, localPointStencilTable, factorize); │ │ │ │ │ +155 } │ │ │ │ │ +156 │ │ │ │ │ +_1_7_4 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * │ │ │ │ │ +_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +175 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ +176 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *baseStencilTable, │ │ │ │ │ +177 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *localPointStencilTable, │ │ │ │ │ +178 int channel = 0, │ │ │ │ │ +179 bool factorize = true); │ │ │ │ │ +180 │ │ │ │ │ +181private: │ │ │ │ │ 182 │ │ │ │ │ -_1_8_4 std::vector const & _G_e_t_W_e_i_g_h_t_s() const { │ │ │ │ │ -185 return ___w_e_i_g_h_t_s; │ │ │ │ │ -186 } │ │ │ │ │ +183 // Generate stencils for the coarse control-vertices (single weight = 1.0f) │ │ │ │ │ +184 static void generateControlVertStencils( │ │ │ │ │ +185 int numControlVerts, │ │ │ │ │ +186 _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> & dst); │ │ │ │ │ 187 │ │ │ │ │ -_1_8_9 _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> _o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const; │ │ │ │ │ -190 │ │ │ │ │ -204 template │ │ │ │ │ -_2_0_5 void _U_p_d_a_t_e_V_a_l_u_e_s(T const &srcValues, U &dstValues, _I_n_d_e_x start=-1, _I_n_d_e_x │ │ │ │ │ -end=-1) const { │ │ │ │ │ -206 this->_u_p_d_a_t_e(srcValues, dstValues, ___w_e_i_g_h_t_s, start, end); │ │ │ │ │ -207 } │ │ │ │ │ -208 │ │ │ │ │ -209 template │ │ │ │ │ -_2_1_0 void _U_p_d_a_t_e_V_a_l_u_e_s(T1 const &srcBase, int numBase, T2 const &srcRef, │ │ │ │ │ -211 U &dstValues, _I_n_d_e_x start=-1, _I_n_d_e_x end=-1) const { │ │ │ │ │ -212 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, dstValues, ___w_e_i_g_h_t_s, start, end); │ │ │ │ │ -213 } │ │ │ │ │ -214 │ │ │ │ │ -215 // Pointer interface for backward compatibility │ │ │ │ │ -216 template │ │ │ │ │ -_2_1_7 void _U_p_d_a_t_e_V_a_l_u_e_s(T const *src, U *dst, _I_n_d_e_x start=-1, _I_n_d_e_x end=-1) const │ │ │ │ │ -{ │ │ │ │ │ -218 this->_u_p_d_a_t_e(src, dst, ___w_e_i_g_h_t_s, start, end); │ │ │ │ │ -219 } │ │ │ │ │ -220 template │ │ │ │ │ -_2_2_1 void _U_p_d_a_t_e_V_a_l_u_e_s(T1 const *srcBase, int numBase, T2 const *srcRef, │ │ │ │ │ -222 U *dst, _I_n_d_e_x start=-1, _I_n_d_e_x end=-1) const { │ │ │ │ │ -223 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, dst, ___w_e_i_g_h_t_s, start, end); │ │ │ │ │ -224 } │ │ │ │ │ +188 // Internal method to splice local point stencils │ │ │ │ │ +189 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * appendLocalPointStencilTable( │ │ │ │ │ +190 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ +191 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * baseStencilTable, │ │ │ │ │ +192 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * localPointStencilTable, │ │ │ │ │ +193 int channel, │ │ │ │ │ +194 bool factorize); │ │ │ │ │ +195}; │ │ │ │ │ +196 │ │ │ │ │ +208template │ │ │ │ │ +_2_0_9class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l { │ │ │ │ │ +210 │ │ │ │ │ +211public: │ │ │ │ │ +212 │ │ │ │ │ +_2_1_3 enum _M_o_d_e { │ │ │ │ │ +_2_1_4 _I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X=0, │ │ │ │ │ +_2_1_5 _I_N_T_E_R_P_O_L_A_T_E___V_A_R_Y_I_N_G, │ │ │ │ │ +216 _I_N_T_E_R_P_O_L_A_T_E___F_A_C_E___V_A_R_Y_I_N_G │ │ │ │ │ +_2_1_7 }; │ │ │ │ │ +218 │ │ │ │ │ +_2_1_9 struct _O_p_t_i_o_n_s { │ │ │ │ │ +220 │ │ │ │ │ +_2_2_1 _O_p_t_i_o_n_s() : _i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e(_I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X), │ │ │ │ │ +222 _g_e_n_e_r_a_t_e_1_s_t_D_e_r_i_v_a_t_i_v_e_s(true), │ │ │ │ │ +223 _g_e_n_e_r_a_t_e_2_n_d_D_e_r_i_v_a_t_i_v_e_s(false), │ │ │ │ │ +224 _f_v_a_r_C_h_a_n_n_e_l(0) { } │ │ │ │ │ 225 │ │ │ │ │ -_2_2_7 void _C_l_e_a_r(); │ │ │ │ │ -228 │ │ │ │ │ -229protected: │ │ │ │ │ -230 │ │ │ │ │ -231 // Update values by applying cached stencil weights to new control values │ │ │ │ │ -232 template │ │ │ │ │ -_2_3_3 void _u_p_d_a_t_e( T const &srcValues, U &dstValues, │ │ │ │ │ -234 std::vector const & valueWeights, _I_n_d_e_x start, _I_n_d_e_x end) const; │ │ │ │ │ -235 template │ │ │ │ │ -_2_3_6 void _u_p_d_a_t_e( T1 const &srcBase, int numBase, T2 const &srcRef, U │ │ │ │ │ -&dstValues, │ │ │ │ │ -237 std::vector const & valueWeights, _I_n_d_e_x start, _I_n_d_e_x end) const; │ │ │ │ │ -238 │ │ │ │ │ -239 // Populate the offsets table from the stencil sizes in _sizes (factory │ │ │ │ │ -helper) │ │ │ │ │ -_2_4_0 void _g_e_n_e_r_a_t_e_O_f_f_s_e_t_s(); │ │ │ │ │ -241 │ │ │ │ │ -242 // Resize the table arrays (factory helper) │ │ │ │ │ -_2_4_3 void _r_e_s_i_z_e(int nstencils, int nelems); │ │ │ │ │ -244 │ │ │ │ │ -245 // Reserves the table arrays (factory helper) │ │ │ │ │ -_2_4_6 void _r_e_s_e_r_v_e(int nstencils, int nelems); │ │ │ │ │ -247 │ │ │ │ │ -248 // Reallocates the table arrays to remove excess capacity (factory helper) │ │ │ │ │ -_2_4_9 void _s_h_r_i_n_k_T_o_F_i_t(); │ │ │ │ │ -250 │ │ │ │ │ -251 // Performs any final operations on internal tables (factory helper) │ │ │ │ │ -_2_5_2 void _f_i_n_a_l_i_z_e(); │ │ │ │ │ -253 │ │ │ │ │ -254protected: │ │ │ │ │ -_2_5_5 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l() : ___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s(0) {} │ │ │ │ │ -_2_5_6 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l(int numControlVerts) │ │ │ │ │ -257 : ___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s(numControlVerts) │ │ │ │ │ -258 { } │ │ │ │ │ -259 │ │ │ │ │ -260 friend class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ -_2_6_1 friend class _F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_B_u_i_l_d_e_r; │ │ │ │ │ -262 │ │ │ │ │ -_2_6_3 int ___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s; // number of control vertices │ │ │ │ │ -264 │ │ │ │ │ -_2_6_5 std::vector ___s_i_z_e_s; // number of coefficients for each stencil │ │ │ │ │ -_2_6_6 std::vector ___o_f_f_s_e_t_s, // offset to the start of each stencil │ │ │ │ │ -_2_6_7 ___i_n_d_i_c_e_s; // indices of contributing coarse vertices │ │ │ │ │ -_2_6_8 std::vector ___w_e_i_g_h_t_s; // stencil weight coefficients │ │ │ │ │ -269}; │ │ │ │ │ -270 │ │ │ │ │ -_2_7_3class _S_t_e_n_c_i_l_T_a_b_l_e : public _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l { │ │ │ │ │ -274protected: │ │ │ │ │ -_2_7_5 typedef _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_T_a_b_l_e; │ │ │ │ │ -276 │ │ │ │ │ -277public: │ │ │ │ │ -_2_7_8 _S_t_e_n_c_i_l _G_e_t_S_t_e_n_c_i_l(_I_n_d_e_x index) const { │ │ │ │ │ -279 return _S_t_e_n_c_i_l(_B_a_s_e_T_a_b_l_e_:_:_G_e_t_S_t_e_n_c_i_l(index)); │ │ │ │ │ -280 } │ │ │ │ │ -_2_8_1 _S_t_e_n_c_i_l _o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const { │ │ │ │ │ -282 return _S_t_e_n_c_i_l(_B_a_s_e_T_a_b_l_e_:_:_G_e_t_S_t_e_n_c_i_l(index)); │ │ │ │ │ -283 } │ │ │ │ │ +_2_2_6 unsigned int _i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e : 2, │ │ │ │ │ +_2_2_7 _g_e_n_e_r_a_t_e_1_s_t_D_e_r_i_v_a_t_i_v_e_s : 1, │ │ │ │ │ +_2_2_8 _g_e_n_e_r_a_t_e_2_n_d_D_e_r_i_v_a_t_i_v_e_s : 1; │ │ │ │ │ +_2_2_9 unsigned int _f_v_a_r_C_h_a_n_n_e_l; │ │ │ │ │ +230 }; │ │ │ │ │ +231 │ │ │ │ │ +_2_3_3 struct _L_o_c_a_t_i_o_n_A_r_r_a_y { │ │ │ │ │ +234 │ │ │ │ │ +_2_3_5 _L_o_c_a_t_i_o_n_A_r_r_a_y() : _p_t_e_x_I_d_x(-1), _n_u_m_L_o_c_a_t_i_o_n_s(0), _s(0), _t(0) { } │ │ │ │ │ +236 │ │ │ │ │ +_2_3_7 int _p_t_e_x_I_d_x, │ │ │ │ │ +_2_3_8 _n_u_m_L_o_c_a_t_i_o_n_s; │ │ │ │ │ +239 │ │ │ │ │ +_2_4_0 REAL const * _s, │ │ │ │ │ +_2_4_1 * _t; │ │ │ │ │ +242 }; │ │ │ │ │ +243 │ │ │ │ │ +_2_4_4 typedef std::vector _L_o_c_a_t_i_o_n_A_r_r_a_y_V_e_c; │ │ │ │ │ +245 │ │ │ │ │ +_2_6_9 static _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _C_r_e_a_t_e( │ │ │ │ │ +270 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, │ │ │ │ │ +271 _L_o_c_a_t_i_o_n_A_r_r_a_y_V_e_c const & locationArrays, │ │ │ │ │ +272 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * cvStencils = 0, │ │ │ │ │ +273 _P_a_t_c_h_T_a_b_l_e const * patchTable = 0, │ │ │ │ │ +274 _O_p_t_i_o_n_s options = _O_p_t_i_o_n_s()); │ │ │ │ │ +275 │ │ │ │ │ +276}; │ │ │ │ │ +277 │ │ │ │ │ +278 │ │ │ │ │ +279// │ │ │ │ │ +280// Public wrapper classes for the templates │ │ │ │ │ +281// │ │ │ │ │ +282class _S_t_e_n_c_i_l; │ │ │ │ │ +283class _S_t_e_n_c_i_l_T_a_b_l_e; │ │ │ │ │ 284 │ │ │ │ │ -285protected: │ │ │ │ │ -_2_8_6 _S_t_e_n_c_i_l_T_a_b_l_e() : _B_a_s_e_T_a_b_l_e() { } │ │ │ │ │ -_2_8_7 _S_t_e_n_c_i_l_T_a_b_l_e(int numControlVerts) : _B_a_s_e_T_a_b_l_e(numControlVerts) { } │ │ │ │ │ -_2_8_8 _S_t_e_n_c_i_l_T_a_b_l_e(int numControlVerts, │ │ │ │ │ -289 std::vector const& offsets, │ │ │ │ │ -290 std::vector const& sizes, │ │ │ │ │ -291 std::vector const& sources, │ │ │ │ │ -292 std::vector const& weights, │ │ │ │ │ -293 bool includeCoarseVerts, │ │ │ │ │ -294 size_t firstOffset) │ │ │ │ │ -295 : _B_a_s_e_T_a_b_l_e(numControlVerts, offsets, │ │ │ │ │ -296 sizes, sources, weights, includeCoarseVerts, firstOffset) { } │ │ │ │ │ -297}; │ │ │ │ │ -298 │ │ │ │ │ +_2_8_7class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y : public _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l { │ │ │ │ │ +288private: │ │ │ │ │ +289 typedef _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_F_a_c_t_o_r_y; │ │ │ │ │ +290 typedef _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_T_a_b_l_e; │ │ │ │ │ +291 │ │ │ │ │ +292public: │ │ │ │ │ +_2_9_3 static _S_t_e_n_c_i_l_T_a_b_l_e const * _C_r_e_a_t_e( │ │ │ │ │ +294 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, Options options = Options()) { │ │ │ │ │ +295 │ │ │ │ │ +296 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ +297 _B_a_s_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e(refiner, options)); │ │ │ │ │ +298 } │ │ │ │ │ 299 │ │ │ │ │ -302template │ │ │ │ │ -_3_0_3class _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l : public _S_t_e_n_c_i_l_R_e_a_l { │ │ │ │ │ -304public: │ │ │ │ │ -305 │ │ │ │ │ -_3_2_4 _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l( int* size, │ │ │ │ │ -325 _I_n_d_e_x * indices, │ │ │ │ │ -326 REAL * weights, │ │ │ │ │ -327 REAL * duWeights=0, │ │ │ │ │ -328 REAL * dvWeights=0, │ │ │ │ │ -329 REAL * duuWeights=0, │ │ │ │ │ -330 REAL * duvWeights=0, │ │ │ │ │ -331 REAL * dvvWeights=0) │ │ │ │ │ -332 : _S_t_e_n_c_i_l_R_e_a_l(size, indices, weights), │ │ │ │ │ -333 _duWeights(duWeights), │ │ │ │ │ -334 _dvWeights(dvWeights), │ │ │ │ │ -335 _duuWeights(duuWeights), │ │ │ │ │ -336 _duvWeights(duvWeights), │ │ │ │ │ -337 _dvvWeights(dvvWeights) { │ │ │ │ │ -338 } │ │ │ │ │ -339 │ │ │ │ │ -_3_4_1 REAL const * _G_e_t_D_u_W_e_i_g_h_t_s() const { │ │ │ │ │ -342 return _duWeights; │ │ │ │ │ -343 } │ │ │ │ │ -344 │ │ │ │ │ -_3_4_6 REAL const * _G_e_t_D_v_W_e_i_g_h_t_s() const { │ │ │ │ │ -347 return _dvWeights; │ │ │ │ │ -348 } │ │ │ │ │ -349 │ │ │ │ │ -_3_5_1 REAL const * _G_e_t_D_u_u_W_e_i_g_h_t_s() const { │ │ │ │ │ -352 return _duuWeights; │ │ │ │ │ -353 } │ │ │ │ │ -354 │ │ │ │ │ -_3_5_6 REAL const * _G_e_t_D_u_v_W_e_i_g_h_t_s() const { │ │ │ │ │ -357 return _duvWeights; │ │ │ │ │ -358 } │ │ │ │ │ -359 │ │ │ │ │ -_3_6_1 REAL const * _G_e_t_D_v_v_W_e_i_g_h_t_s() const { │ │ │ │ │ -362 return _dvvWeights; │ │ │ │ │ -363 } │ │ │ │ │ -364 │ │ │ │ │ -_3_6_6 void _N_e_x_t() { │ │ │ │ │ -367 int stride = *this->___s_i_z_e; │ │ │ │ │ -368 ++this->___s_i_z_e; │ │ │ │ │ -369 this->___i_n_d_i_c_e_s += stride; │ │ │ │ │ -370 this->___w_e_i_g_h_t_s += stride; │ │ │ │ │ -371 if (_duWeights) _duWeights += stride; │ │ │ │ │ -372 if (_dvWeights) _dvWeights += stride; │ │ │ │ │ -373 if (_duuWeights) _duuWeights += stride; │ │ │ │ │ -374 if (_duvWeights) _duvWeights += stride; │ │ │ │ │ -375 if (_dvvWeights) _dvvWeights += stride; │ │ │ │ │ -376 } │ │ │ │ │ -377 │ │ │ │ │ -378private: │ │ │ │ │ -379 │ │ │ │ │ -380 friend class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ -381 friend class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ -382 │ │ │ │ │ -383 REAL * _duWeights, // pointer to stencil u derivative limit weights │ │ │ │ │ -384 * _dvWeights, // pointer to stencil v derivative limit weights │ │ │ │ │ -385 * _duuWeights, // pointer to stencil uu derivative limit weights │ │ │ │ │ -386 * _duvWeights, // pointer to stencil uv derivative limit weights │ │ │ │ │ -387 * _dvvWeights; // pointer to stencil vv derivative limit weights │ │ │ │ │ -388}; │ │ │ │ │ -389 │ │ │ │ │ -_3_9_2class _L_i_m_i_t_S_t_e_n_c_i_l : public _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l { │ │ │ │ │ -393protected: │ │ │ │ │ -_3_9_4 typedef _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_S_t_e_n_c_i_l; │ │ │ │ │ -395 │ │ │ │ │ -396public: │ │ │ │ │ -_3_9_7 _L_i_m_i_t_S_t_e_n_c_i_l(_B_a_s_e_S_t_e_n_c_i_l const & other) : _B_a_s_e_S_t_e_n_c_i_l(other) { } │ │ │ │ │ -_3_9_8 _L_i_m_i_t_S_t_e_n_c_i_l(int* size, _I_n_d_e_x * indices, float * weights, │ │ │ │ │ -399 float * duWeights=0, float * dvWeights=0, │ │ │ │ │ -400 float * duuWeights=0, float * duvWeights=0, float * dvvWeights=0) │ │ │ │ │ -401 : _B_a_s_e_S_t_e_n_c_i_l(size, indices, weights, │ │ │ │ │ -402 duWeights, dvWeights, duuWeights, duvWeights, dvvWeights) { } │ │ │ │ │ -403}; │ │ │ │ │ -404 │ │ │ │ │ -405 │ │ │ │ │ -408template │ │ │ │ │ -_4_0_9class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l : public _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l { │ │ │ │ │ -410protected: │ │ │ │ │ -_4_1_1 _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l( │ │ │ │ │ -412 int numControlVerts, │ │ │ │ │ -413 std::vector const& offsets, │ │ │ │ │ -414 std::vector const& sizes, │ │ │ │ │ -415 std::vector const& sources, │ │ │ │ │ -416 std::vector const& weights, │ │ │ │ │ -417 std::vector const& duWeights, │ │ │ │ │ -418 std::vector const& dvWeights, │ │ │ │ │ -419 std::vector const& duuWeights, │ │ │ │ │ -420 std::vector const& duvWeights, │ │ │ │ │ -421 std::vector const& dvvWeights, │ │ │ │ │ -422 bool includeCoarseVerts, │ │ │ │ │ -423 size_t firstOffset); │ │ │ │ │ -424 │ │ │ │ │ -425public: │ │ │ │ │ -426 │ │ │ │ │ -_4_2_8 _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> _G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(_I_n_d_e_x i) const; │ │ │ │ │ -429 │ │ │ │ │ -_4_3_1 _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> _o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const; │ │ │ │ │ -432 │ │ │ │ │ -_4_3_4 std::vector const & _G_e_t_D_u_W_e_i_g_h_t_s() const { │ │ │ │ │ -435 return _duWeights; │ │ │ │ │ -436 } │ │ │ │ │ -437 │ │ │ │ │ -_4_3_9 std::vector const & _G_e_t_D_v_W_e_i_g_h_t_s() const { │ │ │ │ │ -440 return _dvWeights; │ │ │ │ │ -441 } │ │ │ │ │ -442 │ │ │ │ │ -_4_4_4 std::vector const & _G_e_t_D_u_u_W_e_i_g_h_t_s() const { │ │ │ │ │ -445 return _duuWeights; │ │ │ │ │ -446 } │ │ │ │ │ -447 │ │ │ │ │ -_4_4_9 std::vector const & _G_e_t_D_u_v_W_e_i_g_h_t_s() const { │ │ │ │ │ -450 return _duvWeights; │ │ │ │ │ -451 } │ │ │ │ │ -452 │ │ │ │ │ -_4_5_4 std::vector const & _G_e_t_D_v_v_W_e_i_g_h_t_s() const { │ │ │ │ │ -455 return _dvvWeights; │ │ │ │ │ -456 } │ │ │ │ │ -457 │ │ │ │ │ -475 template │ │ │ │ │ -_4_7_6 void _U_p_d_a_t_e_D_e_r_i_v_s(T const & srcValues, U & uderivs, U & vderivs, │ │ │ │ │ -477 int start=-1, int end=-1) const { │ │ │ │ │ -478 │ │ │ │ │ -479 this->_u_p_d_a_t_e(srcValues, uderivs, _duWeights, start, end); │ │ │ │ │ -480 this->_u_p_d_a_t_e(srcValues, vderivs, _dvWeights, start, end); │ │ │ │ │ -481 } │ │ │ │ │ -482 │ │ │ │ │ -483 template │ │ │ │ │ -_4_8_4 void _U_p_d_a_t_e_D_e_r_i_v_s(T1 const & srcBase, int numBase, T2 const & srcRef, │ │ │ │ │ -485 U & uderivs, U & vderivs, int start=-1, int end=-1) const { │ │ │ │ │ -486 │ │ │ │ │ -487 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uderivs, _duWeights, start, end); │ │ │ │ │ -488 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, vderivs, _dvWeights, start, end); │ │ │ │ │ -489 } │ │ │ │ │ -490 │ │ │ │ │ -491 // Pointer interface for backward compatibility │ │ │ │ │ -492 template │ │ │ │ │ -_4_9_3 void _U_p_d_a_t_e_D_e_r_i_v_s(T const *src, U *uderivs, U *vderivs, │ │ │ │ │ -494 int start=-1, int end=-1) const { │ │ │ │ │ -495 │ │ │ │ │ -496 this->_u_p_d_a_t_e(src, uderivs, _duWeights, start, end); │ │ │ │ │ -497 this->_u_p_d_a_t_e(src, vderivs, _dvWeights, start, end); │ │ │ │ │ -498 } │ │ │ │ │ -499 template │ │ │ │ │ -_5_0_0 void _U_p_d_a_t_e_D_e_r_i_v_s(T1 const *srcBase, int numBase, T2 const *srcRef, │ │ │ │ │ -501 U *uderivs, U *vderivs, int start=-1, int end=-1) const { │ │ │ │ │ -502 │ │ │ │ │ -503 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uderivs, _duWeights, start, end); │ │ │ │ │ -504 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, vderivs, _dvWeights, start, end); │ │ │ │ │ -505 } │ │ │ │ │ -506 │ │ │ │ │ -527 template │ │ │ │ │ -_5_2_8 void _U_p_d_a_t_e_2_n_d_D_e_r_i_v_s(T const & srcValues, │ │ │ │ │ -529 U & uuderivs, U & uvderivs, U & vvderivs, │ │ │ │ │ -530 int start=-1, int end=-1) const { │ │ │ │ │ -531 │ │ │ │ │ -532 this->_u_p_d_a_t_e(srcValues, uuderivs, _duuWeights, start, end); │ │ │ │ │ -533 this->_u_p_d_a_t_e(srcValues, uvderivs, _duvWeights, start, end); │ │ │ │ │ -534 this->_u_p_d_a_t_e(srcValues, vvderivs, _dvvWeights, start, end); │ │ │ │ │ -535 } │ │ │ │ │ -536 │ │ │ │ │ -537 template │ │ │ │ │ -_5_3_8 void _U_p_d_a_t_e_2_n_d_D_e_r_i_v_s(T1 const & srcBase, int numBase, T2 const & srcRef, │ │ │ │ │ -539 U & uuderivs, U & uvderivs, U & vvderivs, int start=-1, int end=-1) const { │ │ │ │ │ -540 │ │ │ │ │ -541 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uuderivs, _duuWeights, start, end); │ │ │ │ │ -542 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uvderivs, _duvWeights, start, end); │ │ │ │ │ -543 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, vvderivs, _dvvWeights, start, end); │ │ │ │ │ -544 } │ │ │ │ │ -545 │ │ │ │ │ -546 // Pointer interface for backward compatibility │ │ │ │ │ -547 template │ │ │ │ │ -_5_4_8 void _U_p_d_a_t_e_2_n_d_D_e_r_i_v_s(T const *src, T *uuderivs, U *uvderivs, U *vvderivs, │ │ │ │ │ -549 int start=-1, int end=-1) const { │ │ │ │ │ -550 │ │ │ │ │ -551 this->_u_p_d_a_t_e(src, uuderivs, _duuWeights, start, end); │ │ │ │ │ -552 this->_u_p_d_a_t_e(src, uvderivs, _duvWeights, start, end); │ │ │ │ │ -553 this->_u_p_d_a_t_e(src, vvderivs, _dvvWeights, start, end); │ │ │ │ │ -554 } │ │ │ │ │ -555 template │ │ │ │ │ -_5_5_6 void _U_p_d_a_t_e_2_n_d_D_e_r_i_v_s(T1 const *srcBase, int numBase, T2 const *srcRef, │ │ │ │ │ -557 U *uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const { │ │ │ │ │ -558 │ │ │ │ │ -559 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uuderivs, _duuWeights, start, end); │ │ │ │ │ -560 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uvderivs, _duvWeights, start, end); │ │ │ │ │ -561 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, vvderivs, _dvvWeights, start, end); │ │ │ │ │ -562 } │ │ │ │ │ -563 │ │ │ │ │ -_5_6_5 void _C_l_e_a_r(); │ │ │ │ │ -566 │ │ │ │ │ -567private: │ │ │ │ │ -568 friend class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ -569 │ │ │ │ │ -570 // Resize the table arrays (factory helper) │ │ │ │ │ -571 void resize(int nstencils, int nelems); │ │ │ │ │ -572 │ │ │ │ │ -573private: │ │ │ │ │ -574 std::vector _duWeights, // u derivative limit stencil weights │ │ │ │ │ -575 _dvWeights, // v derivative limit stencil weights │ │ │ │ │ -576 _duuWeights, // uu derivative limit stencil weights │ │ │ │ │ -577 _duvWeights, // uv derivative limit stencil weights │ │ │ │ │ -578 _dvvWeights; // vv derivative limit stencil weights │ │ │ │ │ -579}; │ │ │ │ │ -580 │ │ │ │ │ -_5_8_3class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e : public _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l { │ │ │ │ │ -584protected: │ │ │ │ │ -_5_8_5 typedef _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_T_a_b_l_e; │ │ │ │ │ -586 │ │ │ │ │ -587public: │ │ │ │ │ -_5_8_8 _L_i_m_i_t_S_t_e_n_c_i_l _G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(_I_n_d_e_x index) const { │ │ │ │ │ -589 return _L_i_m_i_t_S_t_e_n_c_i_l(_B_a_s_e_T_a_b_l_e_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(index)); │ │ │ │ │ -590 } │ │ │ │ │ -_5_9_1 _L_i_m_i_t_S_t_e_n_c_i_l _o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const { │ │ │ │ │ -592 return _L_i_m_i_t_S_t_e_n_c_i_l(_B_a_s_e_T_a_b_l_e_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(index)); │ │ │ │ │ -593 } │ │ │ │ │ -594 │ │ │ │ │ -595protected: │ │ │ │ │ -_5_9_6 _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e(int numControlVerts, │ │ │ │ │ -597 std::vector const& offsets, │ │ │ │ │ -598 std::vector const& sizes, │ │ │ │ │ -599 std::vector const& sources, │ │ │ │ │ -600 std::vector const& weights, │ │ │ │ │ -601 std::vector const& duWeights, │ │ │ │ │ -602 std::vector const& dvWeights, │ │ │ │ │ -603 std::vector const& duuWeights, │ │ │ │ │ -604 std::vector const& duvWeights, │ │ │ │ │ -605 std::vector const& dvvWeights, │ │ │ │ │ -606 bool includeCoarseVerts, │ │ │ │ │ -607 size_t firstOffset) │ │ │ │ │ -608 : _B_a_s_e_T_a_b_l_e(numControlVerts, │ │ │ │ │ -609 offsets, sizes, sources, weights, │ │ │ │ │ -610 duWeights, dvWeights, duuWeights, duvWeights, dvvWeights, │ │ │ │ │ -611 includeCoarseVerts, firstOffset) { } │ │ │ │ │ -612}; │ │ │ │ │ -613 │ │ │ │ │ -614 │ │ │ │ │ -615// Update values by applying cached stencil weights to new control values │ │ │ │ │ -616template │ │ │ │ │ -617template void │ │ │ │ │ -_6_1_8_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_u_p_d_a_t_e(T1 const &srcBase, int numBase, │ │ │ │ │ -619 T2 const &srcRef, U &dstValues, │ │ │ │ │ -620 std::vector const &valueWeights, _I_n_d_e_x start, _I_n_d_e_x end) const { │ │ │ │ │ -621 │ │ │ │ │ -622 int const * sizes = &_sizes.at(0); │ │ │ │ │ -623 _I_n_d_e_x const * indices = &_indices.at(0); │ │ │ │ │ -624 REAL const * weights = &valueWeights.at(0); │ │ │ │ │ -625 │ │ │ │ │ -626 if (start > 0) { │ │ │ │ │ -627 assert(start < (_I_n_d_e_x)_offsets.size()); │ │ │ │ │ -628 sizes += start; │ │ │ │ │ -629 indices += _offsets[start]; │ │ │ │ │ -630 weights += _offsets[start]; │ │ │ │ │ -631 } else { │ │ │ │ │ -632 start = 0; │ │ │ │ │ -633 } │ │ │ │ │ -634 │ │ │ │ │ -635 int nstencils = ((end < start) ? GetNumStencils() : end) - start; │ │ │ │ │ -636 │ │ │ │ │ -637 for (int i = 0; i < nstencils; ++i, ++sizes) { │ │ │ │ │ -638 dstValues[start + i].Clear(); │ │ │ │ │ -639 for (int j = 0; j < *sizes; ++j, ++indices, ++weights) { │ │ │ │ │ -640 if (*indices < numBase) { │ │ │ │ │ -641 dstValues[start + i].AddWithWeight(srcBase[*indices], *weights); │ │ │ │ │ -642 } else { │ │ │ │ │ -643 dstValues[start + i].AddWithWeight(srcRef[*indices - numBase], *weights); │ │ │ │ │ -644 } │ │ │ │ │ -645 } │ │ │ │ │ -646 } │ │ │ │ │ -647} │ │ │ │ │ -648template │ │ │ │ │ -649template void │ │ │ │ │ -_6_5_0_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_u_p_d_a_t_e(T const &srcValues, U &dstValues, │ │ │ │ │ -651 std::vector const &valueWeights, _I_n_d_e_x start, _I_n_d_e_x end) const { │ │ │ │ │ -652 │ │ │ │ │ -653 int const * sizes = &_sizes.at(0); │ │ │ │ │ -654 _I_n_d_e_x const * indices = &_indices.at(0); │ │ │ │ │ -655 REAL const * weights = &valueWeights.at(0); │ │ │ │ │ -656 │ │ │ │ │ -657 if (start > 0) { │ │ │ │ │ -658 assert(start < (_I_n_d_e_x)_offsets.size()); │ │ │ │ │ -659 sizes += start; │ │ │ │ │ -660 indices += _offsets[start]; │ │ │ │ │ -661 weights += _offsets[start]; │ │ │ │ │ -662 } else { │ │ │ │ │ -663 start = 0; │ │ │ │ │ -664 } │ │ │ │ │ -665 │ │ │ │ │ -666 int nstencils = ((end < start) ? GetNumStencils() : end) - start; │ │ │ │ │ -667 │ │ │ │ │ -668 for (int i = 0; i < nstencils; ++i, ++sizes) { │ │ │ │ │ -669 dstValues[start + i].Clear(); │ │ │ │ │ -670 for (int j = 0; j < *sizes; ++j, ++indices, ++weights) { │ │ │ │ │ -671 dstValues[start + i].AddWithWeight(srcValues[*indices], *weights); │ │ │ │ │ -672 } │ │ │ │ │ -673 } │ │ │ │ │ -674} │ │ │ │ │ -675 │ │ │ │ │ -676template │ │ │ │ │ -677inline void │ │ │ │ │ -_6_7_8_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_g_e_n_e_r_a_t_e_O_f_f_s_e_t_s() { │ │ │ │ │ -679 _I_n_d_e_x offset=0; │ │ │ │ │ -680 int noffsets = (int)_sizes.size(); │ │ │ │ │ -681 _offsets.resize(noffsets); │ │ │ │ │ -682 for (int i=0; i<(int)_sizes.size(); ++i ) { │ │ │ │ │ -683 _offsets[i]=offset; │ │ │ │ │ -684 offset+=_sizes[i]; │ │ │ │ │ -685 } │ │ │ │ │ -686} │ │ │ │ │ -687 │ │ │ │ │ -688template │ │ │ │ │ -689inline void │ │ │ │ │ -_6_9_0_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_r_e_s_i_z_e(int nstencils, int nelems) { │ │ │ │ │ -691 _sizes.resize(nstencils); │ │ │ │ │ -692 _indices.resize(nelems); │ │ │ │ │ -693 _weights.resize(nelems); │ │ │ │ │ -694} │ │ │ │ │ -695 │ │ │ │ │ -696template │ │ │ │ │ -697inline void │ │ │ │ │ -_6_9_8_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_r_e_s_e_r_v_e(int nstencils, int nelems) { │ │ │ │ │ -699 _sizes.reserve(nstencils); │ │ │ │ │ -700 _indices.reserve(nelems); │ │ │ │ │ -701 _weights.reserve(nelems); │ │ │ │ │ -702} │ │ │ │ │ -703 │ │ │ │ │ -704template │ │ │ │ │ -705inline void │ │ │ │ │ -_7_0_6_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_s_h_r_i_n_k_T_o_F_i_t() { │ │ │ │ │ -707 std::vector(_sizes).swap(_sizes); │ │ │ │ │ -708 std::vector(_indices).swap(_indices); │ │ │ │ │ -709 std::vector(_weights).swap(_weights); │ │ │ │ │ -710} │ │ │ │ │ -711 │ │ │ │ │ -712template │ │ │ │ │ -713inline void │ │ │ │ │ -_7_1_4_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_f_i_n_a_l_i_z_e() { │ │ │ │ │ -715 shrinkToFit(); │ │ │ │ │ -716 generateOffsets(); │ │ │ │ │ -717} │ │ │ │ │ -718 │ │ │ │ │ -719// Returns a Stencil at index i in the table │ │ │ │ │ -720template │ │ │ │ │ -721inline _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> │ │ │ │ │ -_7_2_2_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_G_e_t_S_t_e_n_c_i_l(_I_n_d_e_x i) const { │ │ │ │ │ -723 assert((! _offsets.empty()) && i<(int)_offsets.size()); │ │ │ │ │ -724 │ │ │ │ │ -725 _I_n_d_e_x ofs = _offsets[i]; │ │ │ │ │ -726 │ │ │ │ │ -727 return _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_>(const_cast(&_sizes[i]), │ │ │ │ │ -728 const_cast<_I_n_d_e_x*>(&_indices[ofs]), │ │ │ │ │ -729 const_cast(&_weights[ofs])); │ │ │ │ │ -730} │ │ │ │ │ -731 │ │ │ │ │ -732template │ │ │ │ │ -733inline _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> │ │ │ │ │ -_7_3_4_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const { │ │ │ │ │ -735 return GetStencil(index); │ │ │ │ │ -736} │ │ │ │ │ -737 │ │ │ │ │ -738template │ │ │ │ │ -739inline void │ │ │ │ │ -740_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_r_e_s_i_z_e(int nstencils, int nelems) { │ │ │ │ │ -741 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_r_e_s_i_z_e(nstencils, nelems); │ │ │ │ │ -742 _duWeights.resize(nelems); │ │ │ │ │ -743 _dvWeights.resize(nelems); │ │ │ │ │ -744} │ │ │ │ │ -745 │ │ │ │ │ -746// Returns a LimitStencil at index i in the table │ │ │ │ │ -747template │ │ │ │ │ -748inline LimitStencilReal │ │ │ │ │ -_7_4_9_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(_I_n_d_e_x i) const { │ │ │ │ │ -750 assert((! this->GetOffsets().empty()) && i<(int)this->GetOffsets().size()); │ │ │ │ │ -751 │ │ │ │ │ -752 _I_n_d_e_x ofs = this->GetOffsets()[i]; │ │ │ │ │ -753 │ │ │ │ │ -754 if (!_duWeights.empty() && !_dvWeights.empty() && │ │ │ │ │ -755 !_duuWeights.empty() && !_duvWeights.empty() && !_dvvWeights.empty()) { │ │ │ │ │ -756 return _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_>( │ │ │ │ │ -757 const_cast(&this->GetSizes()[i]), │ │ │ │ │ -758 const_cast<_I_n_d_e_x *>(&this->GetControlIndices()[ofs]), │ │ │ │ │ -759 const_cast(&this->GetWeights()[ofs]), │ │ │ │ │ -760 const_cast(&GetDuWeights()[ofs]), │ │ │ │ │ -761 const_cast(&GetDvWeights()[ofs]), │ │ │ │ │ -762 const_cast(&GetDuuWeights()[ofs]), │ │ │ │ │ -763 const_cast(&GetDuvWeights()[ofs]), │ │ │ │ │ -764 const_cast(&GetDvvWeights()[ofs]) ); │ │ │ │ │ -765 } else if (!_duWeights.empty() && !_dvWeights.empty()) { │ │ │ │ │ -766 return _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_>( │ │ │ │ │ -767 const_cast(&this->GetSizes()[i]), │ │ │ │ │ -768 const_cast<_I_n_d_e_x *>(&this->GetControlIndices()[ofs]), │ │ │ │ │ -769 const_cast(&this->GetWeights()[ofs]), │ │ │ │ │ -770 const_cast(&GetDuWeights()[ofs]), │ │ │ │ │ -771 const_cast(&GetDvWeights()[ofs]) ); │ │ │ │ │ -772 } else { │ │ │ │ │ -773 return _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_>( │ │ │ │ │ -774 const_cast(&this->GetSizes()[i]), │ │ │ │ │ -775 const_cast<_I_n_d_e_x *>(&this->GetControlIndices()[ofs]), │ │ │ │ │ -776 const_cast(&this->GetWeights()[ofs]) ); │ │ │ │ │ -777 } │ │ │ │ │ -778} │ │ │ │ │ -779 │ │ │ │ │ -780template │ │ │ │ │ -781inline _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> │ │ │ │ │ -_7_8_2_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const { │ │ │ │ │ -783 return GetLimitStencil(index); │ │ │ │ │ -784} │ │ │ │ │ -785 │ │ │ │ │ -786} // end namespace Far │ │ │ │ │ -787 │ │ │ │ │ -788} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -789using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -790 │ │ │ │ │ -791} // end namespace OpenSubdiv │ │ │ │ │ -792 │ │ │ │ │ -793#endif // OPENSUBDIV3_FAR_STENCILTABLE_H │ │ │ │ │ +_3_0_0 static _S_t_e_n_c_i_l_T_a_b_l_e const * _C_r_e_a_t_e( │ │ │ │ │ +301 int numTables, _S_t_e_n_c_i_l_T_a_b_l_e const ** tables) { │ │ │ │ │ +302 │ │ │ │ │ +303 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ +304 _B_a_s_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e(numTables, │ │ │ │ │ +305 reinterpret_cast<_B_a_s_e_T_a_b_l_e const **>(tables))); │ │ │ │ │ +306 } │ │ │ │ │ +307 │ │ │ │ │ +_3_0_8 static _S_t_e_n_c_i_l_T_a_b_l_e const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e( │ │ │ │ │ +309 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ +310 _S_t_e_n_c_i_l_T_a_b_l_e const *baseStencilTable, │ │ │ │ │ +311 _S_t_e_n_c_i_l_T_a_b_l_e const *localPointStencilTable, │ │ │ │ │ +312 bool factorize = true) { │ │ │ │ │ +313 │ │ │ │ │ +314 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ +315 _B_a_s_e_F_a_c_t_o_r_y_:_:_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e(refiner, │ │ │ │ │ +316 static_cast<_B_a_s_e_T_a_b_l_e const *>(baseStencilTable), │ │ │ │ │ +317 static_cast<_B_a_s_e_T_a_b_l_e const *>(localPointStencilTable), │ │ │ │ │ +318 factorize)); │ │ │ │ │ +319 } │ │ │ │ │ +320 │ │ │ │ │ +_3_2_1 static _S_t_e_n_c_i_l_T_a_b_l_e const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g( │ │ │ │ │ +322 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ +323 _S_t_e_n_c_i_l_T_a_b_l_e const *baseStencilTable, │ │ │ │ │ +324 _S_t_e_n_c_i_l_T_a_b_l_e const *localPointStencilTable, │ │ │ │ │ +325 bool factorize = true) { │ │ │ │ │ +326 │ │ │ │ │ +327 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ +328 _B_a_s_e_F_a_c_t_o_r_y_:_:_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g(refiner, │ │ │ │ │ +329 static_cast<_B_a_s_e_T_a_b_l_e const *>(baseStencilTable), │ │ │ │ │ +330 static_cast<_B_a_s_e_T_a_b_l_e const *>(localPointStencilTable), │ │ │ │ │ +331 factorize)); │ │ │ │ │ +332 } │ │ │ │ │ +333 │ │ │ │ │ +_3_3_4 static _S_t_e_n_c_i_l_T_a_b_l_e const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +335 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ +336 _S_t_e_n_c_i_l_T_a_b_l_e const *baseStencilTable, │ │ │ │ │ +337 _S_t_e_n_c_i_l_T_a_b_l_e const *localPointStencilTable, │ │ │ │ │ +338 int channel = 0, │ │ │ │ │ +339 bool factorize = true) { │ │ │ │ │ +340 │ │ │ │ │ +341 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ +342 _B_a_s_e_F_a_c_t_o_r_y_:_:_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g(refiner, │ │ │ │ │ +343 static_cast<_B_a_s_e_T_a_b_l_e const *>(baseStencilTable), │ │ │ │ │ +344 static_cast<_B_a_s_e_T_a_b_l_e const *>(localPointStencilTable), │ │ │ │ │ +345 channel, factorize)); │ │ │ │ │ +346 } │ │ │ │ │ +347}; │ │ │ │ │ +348 │ │ │ │ │ +349class LimitStencil; │ │ │ │ │ +350class LimitStencilTable; │ │ │ │ │ +351 │ │ │ │ │ +_3_5_4class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y : public _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l │ │ │ │ │ +{ │ │ │ │ │ +355private: │ │ │ │ │ +356 typedef _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_F_a_c_t_o_r_y; │ │ │ │ │ +357 typedef _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_T_a_b_l_e; │ │ │ │ │ +358 │ │ │ │ │ +359public: │ │ │ │ │ +_3_6_0 static _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e const * _C_r_e_a_t_e( │ │ │ │ │ +361 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, │ │ │ │ │ +362 _L_o_c_a_t_i_o_n_A_r_r_a_y_V_e_c const & locationArrays, │ │ │ │ │ +363 _S_t_e_n_c_i_l_T_a_b_l_e const * cvStencils = 0, │ │ │ │ │ +364 _P_a_t_c_h_T_a_b_l_e const * patchTable = 0, │ │ │ │ │ +365 Options options = Options()) { │ │ │ │ │ +366 │ │ │ │ │ +367 return static_cast<_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ +368 _B_a_s_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e( │ │ │ │ │ +369 refiner, │ │ │ │ │ +370 locationArrays, │ │ │ │ │ +371 static_cast<_B_a_s_e_T_a_b_l_e const *>(cvStencils), │ │ │ │ │ +372 patchTable, │ │ │ │ │ +373 options)); │ │ │ │ │ +374 } │ │ │ │ │ +375}; │ │ │ │ │ +376 │ │ │ │ │ +377} // end namespace Far │ │ │ │ │ +378 │ │ │ │ │ +379} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +380using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +381 │ │ │ │ │ +382} // end namespace OpenSubdiv │ │ │ │ │ +383 │ │ │ │ │ +384#endif // OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_I_n_d_e_x │ │ │ │ │ -Vtr::Index Index │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +Container for arrays of parametric patches. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_._h_:_5_5 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l │ │ │ │ │ A specialized factory for StencilTable. │ │ │ │ │ DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_C_r_e_a_t_e │ │ │ │ │ +static StencilTableReal< REAL > const * Create(TopologyRefiner const &refiner, │ │ │ │ │ +Options options=Options()) │ │ │ │ │ +Instantiates StencilTable from TopologyRefiner that have been refined uniformly │ │ │ │ │ +or adaptively. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static StencilTableReal< REAL > const * AppendLocalPointStencilTableFaceVarying │ │ │ │ │ +(TopologyRefiner const &refiner, StencilTableReal< REAL > const │ │ │ │ │ +*baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, int │ │ │ │ │ +channel=0, bool factorize=true) │ │ │ │ │ +Utility function for stencil splicing for local point face-varying stencils. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_M_o_d_e │ │ │ │ │ +Mode │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_I_N_T_E_R_P_O_L_A_T_E___F_A_C_E___V_A_R_Y_I_N_G │ │ │ │ │ +@ INTERPOLATE_FACE_VARYING │ │ │ │ │ +face-varying primvar stencils │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_I_N_T_E_R_P_O_L_A_T_E___V_A_R_Y_I_N_G │ │ │ │ │ +@ INTERPOLATE_VARYING │ │ │ │ │ +varying primvar stencils │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X │ │ │ │ │ +@ INTERPOLATE_VERTEX │ │ │ │ │ +vertex primvar stencils │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g │ │ │ │ │ +static StencilTableReal< REAL > const * AppendLocalPointStencilTableVarying │ │ │ │ │ +(TopologyRefiner const &refiner, StencilTableReal< REAL > const │ │ │ │ │ +*baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, bool │ │ │ │ │ +factorize=true) │ │ │ │ │ +Utility function for stencil splicing for local point varying stencils. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_4_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +static StencilTableReal< REAL > const * AppendLocalPointStencilTable │ │ │ │ │ +(TopologyRefiner const &refiner, StencilTableReal< REAL > const │ │ │ │ │ +*baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, bool │ │ │ │ │ +factorize=true) │ │ │ │ │ +Utility function for stencil splicing for local point stencils. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_C_r_e_a_t_e │ │ │ │ │ +static StencilTableReal< REAL > const * Create(int numTables, StencilTableReal< │ │ │ │ │ +REAL > const **tables) │ │ │ │ │ +Instantiates StencilTable by concatenating an array of existing stencil tables. │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l │ │ │ │ │ A specialized factory for LimitStencilTable. │ │ │ │ │ DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_M_o_d_e │ │ │ │ │ +Mode │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_I_N_T_E_R_P_O_L_A_T_E___F_A_C_E___V_A_R_Y_I_N_G │ │ │ │ │ +@ INTERPOLATE_FACE_VARYING │ │ │ │ │ +face-varying primvar stencils │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_I_N_T_E_R_P_O_L_A_T_E___V_A_R_Y_I_N_G │ │ │ │ │ +@ INTERPOLATE_VARYING │ │ │ │ │ +varying primvar stencils │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X │ │ │ │ │ +@ INTERPOLATE_VERTEX │ │ │ │ │ +vertex primvar stencils │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_L_o_c_a_t_i_o_n_A_r_r_a_y_V_e_c │ │ │ │ │ +std::vector< LocationArray > LocationArrayVec │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_4_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_C_r_e_a_t_e │ │ │ │ │ +static LimitStencilTableReal< REAL > const * Create(TopologyRefiner const │ │ │ │ │ +&refiner, LocationArrayVec const &locationArrays, StencilTableReal< REAL > │ │ │ │ │ +const *cvStencils=0, PatchTable const *patchTable=0, Options options=Options()) │ │ │ │ │ +Instantiates LimitStencilTable from a TopologyRefiner that has been refined │ │ │ │ │ +either uniformly or adapt... │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ Vertex stencil descriptor. │ │ │ │ │ DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ -StencilReal() │ │ │ │ │ -Default constructor. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:___s_i_z_e │ │ │ │ │ -int * _size │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_0_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ -StencilReal(int *size, Index *indices, REAL *weights) │ │ │ │ │ -Constructor. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_N_e_x_t │ │ │ │ │ -void Next() │ │ │ │ │ -Advance to the next stencil in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_9_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ -StencilReal(StencilReal const &other) │ │ │ │ │ -Copy constructor. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:___i_n_d_i_c_e_s │ │ │ │ │ -Index * _indices │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ -Index const * GetVertexIndices() const │ │ │ │ │ -Returns the control vertices' indices. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_8_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_S_i_z_e │ │ │ │ │ -int GetSize() const │ │ │ │ │ -Returns the size of the stencil. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:___w_e_i_g_h_t_s │ │ │ │ │ -REAL * _weights │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_S_i_z_e_P_t_r │ │ │ │ │ -int * GetSizePtr() const │ │ │ │ │ -Returns the size of the stencil as a pointer. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_8_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_W_e_i_g_h_t_s │ │ │ │ │ -REAL const * GetWeights() const │ │ │ │ │ -Returns the interpolation weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_9_3 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l │ │ │ │ │ Vertex stencil class wrapping the template for compatibility. │ │ │ │ │ DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_:_:_S_t_e_n_c_i_l │ │ │ │ │ -Stencil(BaseStencil const &other) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_2_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_:_:_S_t_e_n_c_i_l │ │ │ │ │ -Stencil(int *size, Index *indices, float *weights) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_2_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_:_:_B_a_s_e_S_t_e_n_c_i_l │ │ │ │ │ -StencilReal< float > BaseStencil │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_:_:_S_t_e_n_c_i_l │ │ │ │ │ -Stencil() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_2_1 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ Table of subdivision stencils. │ │ │ │ │ DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_4_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_N_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s │ │ │ │ │ -int GetNumControlVertices() const │ │ │ │ │ -Returns the number of control vertices indexed in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___s_i_z_e_s │ │ │ │ │ -std::vector< int > _sizes │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_P_a_t_c_h_T_a_b_l_e_B_u_i_l_d_e_r │ │ │ │ │ -friend class Far::PatchTableBuilder │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_u_p_d_a_t_e │ │ │ │ │ -void update(T1 const &srcBase, int numBase, T2 const &srcRef, U &dstValues, │ │ │ │ │ -std::vector< REAL > const &valueWeights, Index start, Index end) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_1_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_V_a_l_u_e_s │ │ │ │ │ -void UpdateValues(T1 const &srcBase, int numBase, T2 const &srcRef, U │ │ │ │ │ -&dstValues, Index start=-1, Index end=-1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_1_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_C_o_n_t_r_o_l_I_n_d_i_c_e_s │ │ │ │ │ -std::vector< Index > const & GetControlIndices() const │ │ │ │ │ -Returns the indices of the control vertices. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_7_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_f_i_n_a_l_i_z_e │ │ │ │ │ -void finalize() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_1_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_o_p_e_r_a_t_o_r_[_] │ │ │ │ │ -StencilReal< REAL > operator[](Index index) const │ │ │ │ │ -Returns the stencil at index i in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_3_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s │ │ │ │ │ -int _numControlVertices │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_u_p_d_a_t_e │ │ │ │ │ -void update(T const &srcValues, U &dstValues, std::vector< REAL > const │ │ │ │ │ -&valueWeights, Index start, Index end) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_5_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_S_i_z_e_s │ │ │ │ │ -std::vector< int > const & GetSizes() const │ │ │ │ │ -Returns the number of control vertices of each stencil in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_6_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_N_u_m_S_t_e_n_c_i_l_s │ │ │ │ │ -int GetNumStencils() const │ │ │ │ │ -Returns the number of stencils in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_~_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ -virtual ~StencilTableReal() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_5_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_O_f_f_s_e_t_s │ │ │ │ │ -std::vector< Index > const & GetOffsets() const │ │ │ │ │ -Returns the offset to a given stencil (factory may leave empty) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_7_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_S_t_e_n_c_i_l │ │ │ │ │ -StencilReal< REAL > GetStencil(Index i) const │ │ │ │ │ -Returns a Stencil at index i in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_2_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_s_h_r_i_n_k_T_o_F_i_t │ │ │ │ │ -void shrinkToFit() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_0_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_g_e_n_e_r_a_t_e_O_f_f_s_e_t_s │ │ │ │ │ -void generateOffsets() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_7_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_C_l_e_a_r │ │ │ │ │ -void Clear() │ │ │ │ │ -Clears the stencils from the table. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___o_f_f_s_e_t_s │ │ │ │ │ -std::vector< Index > _offsets │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___w_e_i_g_h_t_s │ │ │ │ │ -std::vector< REAL > _weights │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_r_e_s_i_z_e │ │ │ │ │ -void resize(int nstencils, int nelems) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_9_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_W_e_i_g_h_t_s │ │ │ │ │ -std::vector< REAL > const & GetWeights() const │ │ │ │ │ -Returns the stencil interpolation weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_8_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_V_a_l_u_e_s │ │ │ │ │ -void UpdateValues(T1 const *srcBase, int numBase, T2 const *srcRef, U *dst, │ │ │ │ │ -Index start=-1, Index end=-1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_2_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ -StencilTableReal(int numControlVerts, std::vector< int > const &offsets, std:: │ │ │ │ │ -vector< int > const &sizes, std::vector< int > const &sources, std::vector< │ │ │ │ │ -REAL > const &weights, bool includeCoarseVerts, size_t firstOffset) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___i_n_d_i_c_e_s │ │ │ │ │ -std::vector< Index > _indices │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ -StencilTableReal() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_5_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_r_e_s_e_r_v_e │ │ │ │ │ -void reserve(int nstencils, int nelems) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_9_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_V_a_l_u_e_s │ │ │ │ │ -void UpdateValues(T const *src, U *dst, Index start=-1, Index end=-1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_1_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_V_a_l_u_e_s │ │ │ │ │ -void UpdateValues(T const &srcValues, U &dstValues, Index start=-1, Index end=- │ │ │ │ │ -1) const │ │ │ │ │ -Updates point values based on the control values. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_0_5 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ Stencil table class wrapping the template for compatibility. │ │ │ │ │ DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -StencilTable(int numControlVerts, std::vector< int > const &offsets, std:: │ │ │ │ │ -vector< int > const &sizes, std::vector< int > const &sources, std::vector< │ │ │ │ │ -float > const &weights, bool includeCoarseVerts, size_t firstOffset) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_8_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -StencilTable(int numControlVerts) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_8_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_B_a_s_e_T_a_b_l_e │ │ │ │ │ -StencilTableReal< float > BaseTable │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_S_t_e_n_c_i_l │ │ │ │ │ -Stencil GetStencil(Index index) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_o_p_e_r_a_t_o_r_[_] │ │ │ │ │ -Stencil operator[](Index index) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_8_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -StencilTable() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ -Limit point stencil descriptor. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_0_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_u_v_W_e_i_g_h_t_s │ │ │ │ │ -REAL const * GetDuvWeights() const │ │ │ │ │ -Returns the uv derivative weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_v_W_e_i_g_h_t_s │ │ │ │ │ -REAL const * GetDvWeights() const │ │ │ │ │ -Returns the v derivative weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_4_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_N_e_x_t │ │ │ │ │ -void Next() │ │ │ │ │ -Advance to the next stencil in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_v_v_W_e_i_g_h_t_s │ │ │ │ │ -REAL const * GetDvvWeights() const │ │ │ │ │ -Returns the vv derivative weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ -LimitStencilReal(int *size, Index *indices, REAL *weights, REAL *duWeights=0, │ │ │ │ │ -REAL *dvWeights=0, REAL *duuWeights=0, REAL *duvWeights=0, REAL *dvvWeights=0) │ │ │ │ │ -Constructor. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_2_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_u_W_e_i_g_h_t_s │ │ │ │ │ -REAL const * GetDuWeights() const │ │ │ │ │ -Returns the u derivative weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_4_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_u_u_W_e_i_g_h_t_s │ │ │ │ │ -REAL const * GetDuuWeights() const │ │ │ │ │ -Returns the uu derivative weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ -Limit point stencil class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_9_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_:_:_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ -LimitStencil(BaseStencil const &other) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_9_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_:_:_B_a_s_e_S_t_e_n_c_i_l │ │ │ │ │ -LimitStencilReal< float > BaseStencil │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_9_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_:_:_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ -LimitStencil(int *size, Index *indices, float *weights, float *duWeights=0, │ │ │ │ │ -float *dvWeights=0, float *duuWeights=0, float *duvWeights=0, float │ │ │ │ │ -*dvvWeights=0) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_9_8 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ Table of limit subdivision stencils. │ │ │ │ │ DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_0_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_u_u_W_e_i_g_h_t_s │ │ │ │ │ -std::vector< REAL > const & GetDuuWeights() const │ │ │ │ │ -Returns the 'uu' derivative stencil interpolation weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_4_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_o_p_e_r_a_t_o_r_[_] │ │ │ │ │ -LimitStencilReal< REAL > operator[](Index index) const │ │ │ │ │ -Returns the limit stencil at index i in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_8_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_v_v_W_e_i_g_h_t_s │ │ │ │ │ -std::vector< REAL > const & GetDvvWeights() const │ │ │ │ │ -Returns the 'vv' derivative stencil interpolation weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_5_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_D_e_r_i_v_s │ │ │ │ │ -void UpdateDerivs(T const *src, U *uderivs, U *vderivs, int start=-1, int end=- │ │ │ │ │ -1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_9_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_2_n_d_D_e_r_i_v_s │ │ │ │ │ -void Update2ndDerivs(T const *src, T *uuderivs, U *uvderivs, U *vvderivs, int │ │ │ │ │ -start=-1, int end=-1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_v_W_e_i_g_h_t_s │ │ │ │ │ -std::vector< REAL > const & GetDvWeights() const │ │ │ │ │ -Returns the 'v' derivative stencil interpolation weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_3_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_2_n_d_D_e_r_i_v_s │ │ │ │ │ -void Update2ndDerivs(T1 const *srcBase, int numBase, T2 const *srcRef, U │ │ │ │ │ -*uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_D_e_r_i_v_s │ │ │ │ │ -void UpdateDerivs(T const &srcValues, U &uderivs, U &vderivs, int start=-1, int │ │ │ │ │ -end=-1) const │ │ │ │ │ -Updates derivative values based on the control values. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_7_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ -LimitStencilReal< REAL > GetLimitStencil(Index i) const │ │ │ │ │ -Returns a LimitStencil at index i in the table. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_4_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_: │ │ │ │ │ -_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ -LimitStencilTableReal(int numControlVerts, std::vector< int > const &offsets, │ │ │ │ │ -std::vector< int > const &sizes, std::vector< int > const &sources, std:: │ │ │ │ │ -vector< REAL > const &weights, std::vector< REAL > const &duWeights, std:: │ │ │ │ │ -vector< REAL > const &dvWeights, std::vector< REAL > const &duuWeights, std:: │ │ │ │ │ -vector< REAL > const &duvWeights, std::vector< REAL > const &dvvWeights, bool │ │ │ │ │ -includeCoarseVerts, size_t firstOffset) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_2_n_d_D_e_r_i_v_s │ │ │ │ │ -void Update2ndDerivs(T const &srcValues, U &uuderivs, U &uvderivs, U &vvderivs, │ │ │ │ │ -int start=-1, int end=-1) const │ │ │ │ │ -Updates 2nd derivative values based on the control values. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_2_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_u_W_e_i_g_h_t_s │ │ │ │ │ -std::vector< REAL > const & GetDuWeights() const │ │ │ │ │ -Returns the 'u' derivative stencil interpolation weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_3_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_C_l_e_a_r │ │ │ │ │ -void Clear() │ │ │ │ │ -Clears the stencils from the table. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_2_n_d_D_e_r_i_v_s │ │ │ │ │ -void Update2ndDerivs(T1 const &srcBase, int numBase, T2 const &srcRef, U │ │ │ │ │ -&uuderivs, U &uvderivs, U &vvderivs, int start=-1, int end=-1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_3_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_u_v_W_e_i_g_h_t_s │ │ │ │ │ -std::vector< REAL > const & GetDuvWeights() const │ │ │ │ │ -Returns the 'uv' derivative stencil interpolation weights. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_4_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_D_e_r_i_v_s │ │ │ │ │ -void UpdateDerivs(T1 const &srcBase, int numBase, T2 const &srcRef, U &uderivs, │ │ │ │ │ -U &vderivs, int start=-1, int end=-1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_8_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_D_e_r_i_v_s │ │ │ │ │ -void UpdateDerivs(T1 const *srcBase, int numBase, T2 const *srcRef, U *uderivs, │ │ │ │ │ -U *vderivs, int start=-1, int end=-1) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_0_0 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ Limit stencil table class wrapping the template for compatibility. │ │ │ │ │ DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_:_:_B_a_s_e_T_a_b_l_e │ │ │ │ │ -LimitStencilTableReal< float > BaseTable │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ -LimitStencil GetLimitStencil(Index index) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -LimitStencilTable(int numControlVerts, std::vector< int > const &offsets, std:: │ │ │ │ │ -vector< int > const &sizes, std::vector< int > const &sources, std::vector< │ │ │ │ │ -float > const &weights, std::vector< float > const &duWeights, std::vector< │ │ │ │ │ -float > const &dvWeights, std::vector< float > const &duuWeights, std::vector< │ │ │ │ │ -float > const &duvWeights, std::vector< float > const &dvvWeights, bool │ │ │ │ │ -includeCoarseVerts, size_t firstOffset) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_9_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_:_:_o_p_e_r_a_t_o_r_[_] │ │ │ │ │ -LimitStencil operator[](Index index) const │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_9_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_f_a_c_t_o_r_i_z_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s │ │ │ │ │ +unsigned int factorizeIntermediateLevels │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_:_m_a_x_L_e_v_e_l │ │ │ │ │ +unsigned int maxLevel │ │ │ │ │ +generate stencils up to 'maxLevel' │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_:_O_p_t_i_o_n_s │ │ │ │ │ +Options() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_6_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s │ │ │ │ │ +unsigned int generateIntermediateLevels │ │ │ │ │ +vertices at all levels or highest only │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_C_o_n_t_r_o_l_V_e_r_t_s │ │ │ │ │ +unsigned int generateControlVerts │ │ │ │ │ +generate stencils for control-vertices │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_O_f_f_s_e_t_s │ │ │ │ │ +unsigned int generateOffsets │ │ │ │ │ +populate optional "_offsets" field │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_f_v_a_r_C_h_a_n_n_e_l │ │ │ │ │ +unsigned int fvarChannel │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e │ │ │ │ │ +unsigned int interpolationMode │ │ │ │ │ +interpolation mode │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_O_p_t_i_o_n_s │ │ │ │ │ +Options() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_f_v_a_r_C_h_a_n_n_e_l │ │ │ │ │ +unsigned int fvarChannel │ │ │ │ │ +face-varying channel to use │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e │ │ │ │ │ +unsigned int interpolationMode │ │ │ │ │ +interpolation mode │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_2_n_d_D_e_r_i_v_a_t_i_v_e_s │ │ │ │ │ +unsigned int generate2ndDerivatives │ │ │ │ │ +Generate weights for 2nd derivatives. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_1_s_t_D_e_r_i_v_a_t_i_v_e_s │ │ │ │ │ +unsigned int generate1stDerivatives │ │ │ │ │ +Generate weights for 1st derivatives. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_L_o_c_a_t_i_o_n_A_r_r_a_y │ │ │ │ │ +Descriptor for limit surface locations. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_3_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_t │ │ │ │ │ +REAL const * t │ │ │ │ │ +array of v coordinates │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_4_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_s │ │ │ │ │ +REAL const * s │ │ │ │ │ +array of u coordinates │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_L_o_c_a_t_i_o_n_A_r_r_a_y │ │ │ │ │ +LocationArray() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_3_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_n_u_m_L_o_c_a_t_i_o_n_s │ │ │ │ │ +int numLocations │ │ │ │ │ +number of (u,v) coordinates in the array │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_3_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ +_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_p_t_e_x_I_d_x │ │ │ │ │ +int ptexIdx │ │ │ │ │ +ptex face index │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ +Stencil table factory class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_8_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ +_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g │ │ │ │ │ +static StencilTable const * AppendLocalPointStencilTableVarying(TopologyRefiner │ │ │ │ │ +const &refiner, StencilTable const *baseStencilTable, StencilTable const │ │ │ │ │ +*localPointStencilTable, bool factorize=true) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_2_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e │ │ │ │ │ +static StencilTable const * Create(TopologyRefiner const &refiner, Options │ │ │ │ │ +options=Options()) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_9_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ +_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static StencilTable const * AppendLocalPointStencilTableFaceVarying │ │ │ │ │ +(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, │ │ │ │ │ +StencilTable const *localPointStencilTable, int channel=0, bool factorize=true) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_3_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ +_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +static StencilTable const * AppendLocalPointStencilTable(TopologyRefiner const │ │ │ │ │ +&refiner, StencilTable const *baseStencilTable, StencilTable const │ │ │ │ │ +*localPointStencilTable, bool factorize=true) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_0_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e │ │ │ │ │ +static StencilTable const * Create(int numTables, StencilTable const **tables) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ +Stencil table factory class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e │ │ │ │ │ +static LimitStencilTable const * Create(TopologyRefiner const &refiner, │ │ │ │ │ +LocationArrayVec const &locationArrays, StencilTable const *cvStencils=0, │ │ │ │ │ +PatchTable const *patchTable=0, Options options=Options()) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_6_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ +Stores topology data for a specified set of refinement options. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_5_1 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _s_t_e_n_c_i_l_T_a_b_l_e_._h │ │ │ │ │ + * _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00719.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/stencilTableFactory.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/far/primvarRefiner.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,43 +90,43 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
stencilTableFactory.h File Reference
│ │ │ │ +
primvarRefiner.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/patchTable.h"
│ │ │ │ -#include <vector>
│ │ │ │ +#include "../sdc/types.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │ +#include "../sdc/bilinearScheme.h"
│ │ │ │ +#include "../sdc/catmarkScheme.h"
│ │ │ │ +#include "../sdc/loopScheme.h"
│ │ │ │ +#include "../vtr/level.h"
│ │ │ │ +#include "../vtr/fvarLevel.h"
│ │ │ │ +#include "../vtr/refinement.h"
│ │ │ │ +#include "../vtr/fvarRefinement.h"
│ │ │ │ +#include "../vtr/stackBuffer.h"
│ │ │ │ +#include "../vtr/componentInterfaces.h"
│ │ │ │ +#include "../far/types.h"
│ │ │ │ +#include "../far/error.h"
│ │ │ │ +#include "../far/topologyLevel.h"
│ │ │ │ +#include "../far/topologyRefiner.h"
│ │ │ │ +#include <cassert>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  StencilTableFactoryReal< REAL >
 A specialized factory for StencilTable. More...
class  PrimvarRefinerReal< REAL >
 Applies refinement operations to generic primvar data. More...
 
struct  StencilTableFactoryReal< REAL >::Options
 
class  LimitStencilTableFactoryReal< REAL >
 A specialized factory for LimitStencilTable. More...
 
struct  LimitStencilTableFactoryReal< REAL >::Options
 
struct  LimitStencilTableFactoryReal< REAL >::LocationArray
 Descriptor for limit surface locations. More...
 
class  StencilTableFactory
 Stencil table factory class wrapping the template for compatibility. More...
 
class  LimitStencilTableFactory
 Stencil table factory class wrapping the template for compatibility. More...
class  PrimvarRefiner
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -135,13 +135,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,43 +1,41 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -stencilTableFactory.h File Reference │ │ │ │ │ +primvarRefiner.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_f_a_r_/_p_a_t_c_h_T_a_b_l_e_._h" │ │ │ │ │ -#include │ │ │ │ │ +#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_b_i_l_i_n_e_a_r_S_c_h_e_m_e_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_c_a_t_m_a_r_k_S_c_h_e_m_e_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_l_o_o_p_S_c_h_e_m_e_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_l_e_v_e_l_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_f_v_a_r_L_e_v_e_l_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_r_e_f_i_n_e_m_e_n_t_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_f_v_a_r_R_e_f_i_n_e_m_e_n_t_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_s_t_a_c_k_B_u_f_f_e_r_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_c_o_m_p_o_n_e_n_t_I_n_t_e_r_f_a_c_e_s_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_e_r_r_o_r_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_t_o_p_o_l_o_g_y_L_e_v_e_l_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h" │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ - class   _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ -  A specialized factory for _S_t_e_n_c_i_l_T_a_b_l_e. _M_o_r_e_._._. │ │ │ │ │ +class   _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ +  Applies refinement operations to generic primvar data. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -struct   _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _>_:_:_O_p_t_i_o_n_s │ │ │ │ │ -  │ │ │ │ │ - class   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ -  A specialized factory for _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -struct   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _>_:_:_O_p_t_i_o_n_s │ │ │ │ │ -  │ │ │ │ │ -struct   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_ _R_E_A_L_ _>_:_:_L_o_c_a_t_i_o_n_A_r_r_a_y │ │ │ │ │ -  Descriptor for limit surface locations. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ - class   _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ -  _S_t_e_n_c_i_l table factory class wrapping the template for compatibility. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ - class   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ -  _S_t_e_n_c_i_l table factory class wrapping the template for compatibility. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ +class   _P_r_i_m_v_a_r_R_e_f_i_n_e_r │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h │ │ │ │ │ + * _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00719.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,9 +1,4 @@ │ │ │ │ │ var a00719 = [ │ │ │ │ │ - ["StencilTableFactoryReal< REAL >", "a01045.html", "a01045"], │ │ │ │ │ - ["Options", "a01085.html", "a01085"], │ │ │ │ │ - ["LimitStencilTableFactoryReal< REAL >", "a01049.html", "a01049"], │ │ │ │ │ - ["Options", "a01089.html", "a01089"], │ │ │ │ │ - ["LocationArray", "a01093.html", "a01093"], │ │ │ │ │ - ["StencilTableFactory", "a01097.html", null], │ │ │ │ │ - ["LimitStencilTableFactory", "a01101.html", null] │ │ │ │ │ + ["PrimvarRefinerReal< REAL >", "a01029.html", "a01029"], │ │ │ │ │ + ["PrimvarRefiner", "a01037.html", "a01037"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00719_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/stencilTableFactory.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/far/primvarRefiner.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
stencilTableFactory.h
│ │ │ │ +
primvarRefiner.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2013 Pixar
│ │ │ │ +
2// Copyright 2015 DreamWorks Animation LLC.
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -118,358 +118,1233 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H
│ │ │ │ -
26#define OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H
│ │ │ │ -
27
│ │ │ │ -
28#include "../version.h"
│ │ │ │ -
29
│ │ │ │ -
30#include "../far/patchTable.h"
│ │ │ │ -
31
│ │ │ │ -
32#include <vector>
│ │ │ │ -
33
│ │ │ │ -
34namespace OpenSubdiv {
│ │ │ │ -
35namespace OPENSUBDIV_VERSION {
│ │ │ │ -
36
│ │ │ │ -
37namespace Far {
│ │ │ │ -
38
│ │ │ │ -
39class TopologyRefiner;
│ │ │ │ -
40
│ │ │ │ -
41template <typename REAL> class StencilReal;
│ │ │ │ -
42template <typename REAL> class StencilTableReal;
│ │ │ │ -
43
│ │ │ │ -
44template <typename REAL> class LimitStencilReal;
│ │ │ │ -
45template <typename REAL> class LimitStencilTableReal;
│ │ │ │ +
24#ifndef OPENSUBDIV3_FAR_PRIMVAR_REFINER_H
│ │ │ │ +
25#define OPENSUBDIV3_FAR_PRIMVAR_REFINER_H
│ │ │ │ +
26
│ │ │ │ +
27#include "../version.h"
│ │ │ │ +
28
│ │ │ │ +
29#include "../sdc/types.h"
│ │ │ │ +
30#include "../sdc/options.h"
│ │ │ │ +
31#include "../sdc/bilinearScheme.h"
│ │ │ │ +
32#include "../sdc/catmarkScheme.h"
│ │ │ │ +
33#include "../sdc/loopScheme.h"
│ │ │ │ +
34#include "../vtr/level.h"
│ │ │ │ +
35#include "../vtr/fvarLevel.h"
│ │ │ │ +
36#include "../vtr/refinement.h"
│ │ │ │ +
37#include "../vtr/fvarRefinement.h"
│ │ │ │ +
38#include "../vtr/stackBuffer.h"
│ │ │ │ +
39#include "../vtr/componentInterfaces.h"
│ │ │ │ +
40#include "../far/types.h"
│ │ │ │ +
41#include "../far/error.h"
│ │ │ │ +
42#include "../far/topologyLevel.h"
│ │ │ │ +
43#include "../far/topologyRefiner.h"
│ │ │ │ +
44
│ │ │ │ +
45#include <cassert>
│ │ │ │
46
│ │ │ │ -
47
│ │ │ │ -
50template <typename REAL>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
52
│ │ │ │ -
53public:
│ │ │ │ -
54
│ │ │ │ -
│ │ │ │ -
55 enum Mode {
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
59 };
│ │ │ │ -
│ │ │ │ -
60
│ │ │ │ -
│ │ │ │ -
61 struct Options {
│ │ │ │ -
62
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
64 generateOffsets(false),
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
68 maxLevel(10),
│ │ │ │ -
69 fvarChannel(0) { }
│ │ │ │ -
│ │ │ │ -
70
│ │ │ │ -
71 unsigned int interpolationMode : 2,
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
79 unsigned int fvarChannel;
│ │ │ │ -
81 };
│ │ │ │ -
│ │ │ │ -
82
│ │ │ │ - │ │ │ │ -
95 TopologyRefiner const & refiner, Options options = Options());
│ │ │ │ -
96
│ │ │ │ -
97
│ │ │ │ - │ │ │ │ -
111 int numTables, StencilTableReal<REAL> const ** tables);
│ │ │ │ -
112
│ │ │ │ -
113
│ │ │ │ - │ │ │ │ -
129 TopologyRefiner const &refiner,
│ │ │ │ -
130 StencilTableReal<REAL> const *baseStencilTable,
│ │ │ │ -
131 StencilTableReal<REAL> const *localPointStencilTable,
│ │ │ │ -
132 bool factorize = true);
│ │ │ │ -
133
│ │ │ │ +
47namespace OpenSubdiv {
│ │ │ │ +
48namespace OPENSUBDIV_VERSION {
│ │ │ │ +
49
│ │ │ │ +
50namespace Far {
│ │ │ │ +
51
│ │ │ │ +
55template <typename REAL>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
57
│ │ │ │ +
58public:
│ │ │ │ +
59 PrimvarRefinerReal(TopologyRefiner const & refiner) : _refiner(refiner) { }
│ │ │ │ + │ │ │ │ +
61
│ │ │ │ +
62 TopologyRefiner const & GetTopologyRefiner() const { return _refiner; }
│ │ │ │ +
63
│ │ │ │ +
65
│ │ │ │ +
100
│ │ │ │ +
│ │ │ │ +
113 template <class T, class U> void Interpolate(int level, T const & src, U & dst) const;
│ │ │ │ +
114
│ │ │ │ +
│ │ │ │ +
130 template <class T, class U> void InterpolateVarying(int level, T const & src, U & dst) const;
│ │ │ │ +
131
│ │ │ │
│ │ │ │ - │ │ │ │ -
149 TopologyRefiner const &refiner,
│ │ │ │ -
150 StencilTableReal<REAL> const *baseStencilTable,
│ │ │ │ -
151 StencilTableReal<REAL> const *localPointStencilTable,
│ │ │ │ -
152 bool factorize = true) {
│ │ │ │ - │ │ │ │ -
154 refiner, baseStencilTable, localPointStencilTable, factorize);
│ │ │ │ -
155 }
│ │ │ │ -
│ │ │ │ -
156
│ │ │ │ - │ │ │ │ -
175 TopologyRefiner const &refiner,
│ │ │ │ -
176 StencilTableReal<REAL> const *baseStencilTable,
│ │ │ │ -
177 StencilTableReal<REAL> const *localPointStencilTable,
│ │ │ │ -
178 int channel = 0,
│ │ │ │ -
179 bool factorize = true);
│ │ │ │ -
180
│ │ │ │ -
181private:
│ │ │ │ -
182
│ │ │ │ -
183 // Generate stencils for the coarse control-vertices (single weight = 1.0f)
│ │ │ │ -
184 static void generateControlVertStencils(
│ │ │ │ -
185 int numControlVerts,
│ │ │ │ -
186 StencilReal<REAL> & dst);
│ │ │ │ -
187
│ │ │ │ -
188 // Internal method to splice local point stencils
│ │ │ │ -
189 static StencilTableReal<REAL> const * appendLocalPointStencilTable(
│ │ │ │ -
190 TopologyRefiner const &refiner,
│ │ │ │ -
191 StencilTableReal<REAL> const * baseStencilTable,
│ │ │ │ -
192 StencilTableReal<REAL> const * localPointStencilTable,
│ │ │ │ -
193 int channel,
│ │ │ │ -
194 bool factorize);
│ │ │ │ -
195};
│ │ │ │ -
│ │ │ │ -
196
│ │ │ │ -
208template <typename REAL>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
210
│ │ │ │ -
211public:
│ │ │ │ -
212
│ │ │ │ -
│ │ │ │ -
213 enum Mode {
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
217 };
│ │ │ │ -
│ │ │ │ -
218
│ │ │ │ -
│ │ │ │ -
219 struct Options {
│ │ │ │ -
220
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
224 fvarChannel(0) { }
│ │ │ │ -
│ │ │ │ -
225
│ │ │ │ -
226 unsigned int interpolationMode : 2,
│ │ │ │ - │ │ │ │ - │ │ │ │ -
229 unsigned int fvarChannel;
│ │ │ │ -
230 };
│ │ │ │ -
│ │ │ │ -
231
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
234
│ │ │ │ -
235 LocationArray() : ptexIdx(-1), numLocations(0), s(0), t(0) { }
│ │ │ │ -
236
│ │ │ │ - │ │ │ │ - │ │ │ │ -
239
│ │ │ │ -
240 REAL const * s,
│ │ │ │ -
241 * t;
│ │ │ │ -
242 };
│ │ │ │ -
│ │ │ │ -
243
│ │ │ │ -
244 typedef std::vector<LocationArray> LocationArrayVec;
│ │ │ │ -
245
│ │ │ │ - │ │ │ │ -
270 TopologyRefiner const & refiner,
│ │ │ │ -
271 LocationArrayVec const & locationArrays,
│ │ │ │ -
272 StencilTableReal<REAL> const * cvStencils = 0,
│ │ │ │ -
273 PatchTable const * patchTable = 0,
│ │ │ │ -
274 Options options = Options());
│ │ │ │ -
275
│ │ │ │ -
276};
│ │ │ │ -
│ │ │ │ -
277
│ │ │ │ -
278
│ │ │ │ -
279//
│ │ │ │ -
280// Public wrapper classes for the templates
│ │ │ │ -
281//
│ │ │ │ -
282class Stencil;
│ │ │ │ -
283class StencilTable;
│ │ │ │ -
284
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
288private:
│ │ │ │ - │ │ │ │ - │ │ │ │ -
291
│ │ │ │ -
292public:
│ │ │ │ +
148 template <class T, class U> void InterpolateFaceUniform(int level, T const & src, U & dst) const;
│ │ │ │ +
149
│ │ │ │ +
│ │ │ │ +
161 template <class T, class U> void InterpolateFaceVarying(int level, T const & src, U & dst, int channel = 0) const;
│ │ │ │ +
162
│ │ │ │ +
163
│ │ │ │ +
│ │ │ │ +
175 template <class T, class U> void Limit(T const & src, U & dstPos) const;
│ │ │ │ +
176
│ │ │ │ +
177 template <class T, class U, class U1, class U2>
│ │ │ │ +
│ │ │ │ +
178 void Limit(T const & src, U & dstPos, U1 & dstTan1, U2 & dstTan2) const;
│ │ │ │ +
179
│ │ │ │ +
│ │ │ │ +
180 template <class T, class U> void LimitFaceVarying(T const & src, U & dst, int channel = 0) const;
│ │ │ │ +
181
│ │ │ │ +
183
│ │ │ │ +
184private:
│ │ │ │ +
185 typedef REAL Weight;
│ │ │ │ +
186
│ │ │ │ +
187 // Non-copyable:
│ │ │ │ +
188 PrimvarRefinerReal(PrimvarRefinerReal const & src) : _refiner(src._refiner) { }
│ │ │ │ +
189 PrimvarRefinerReal & operator=(PrimvarRefinerReal const &) { return *this; }
│ │ │ │ +
190
│ │ │ │ +
191 template <Sdc::SchemeType SCHEME, class T, class U> void interpFromFaces(int, T const &, U &) const;
│ │ │ │ +
192 template <Sdc::SchemeType SCHEME, class T, class U> void interpFromEdges(int, T const &, U &) const;
│ │ │ │ +
193 template <Sdc::SchemeType SCHEME, class T, class U> void interpFromVerts(int, T const &, U &) const;
│ │ │ │ +
194
│ │ │ │ +
195 template <Sdc::SchemeType SCHEME, class T, class U> void interpFVarFromFaces(int, T const &, U &, int) const;
│ │ │ │ +
196 template <Sdc::SchemeType SCHEME, class T, class U> void interpFVarFromEdges(int, T const &, U &, int) const;
│ │ │ │ +
197 template <Sdc::SchemeType SCHEME, class T, class U> void interpFVarFromVerts(int, T const &, U &, int) const;
│ │ │ │ +
198
│ │ │ │ +
199 template <Sdc::SchemeType SCHEME, class T, class U, class U1, class U2>
│ │ │ │ +
200 void limit(T const & src, U & pos, U1 * tan1, U2 * tan2) const;
│ │ │ │ +
201
│ │ │ │ +
202 template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ +
203 void limitFVar(T const & src, U & dst, int channel) const;
│ │ │ │ +
204
│ │ │ │ +
205private:
│ │ │ │ +
206 TopologyRefiner const & _refiner;
│ │ │ │ +
207
│ │ │ │ +
208private:
│ │ │ │ +
209 //
│ │ │ │ +
210 // Local class to fulfill interface for <typename MASK> in the Scheme mask queries:
│ │ │ │ +
211 //
│ │ │ │ +
212 class Mask {
│ │ │ │ +
213 public:
│ │ │ │ +
214 typedef REAL Weight; // Also part of the expected interface
│ │ │ │ +
215
│ │ │ │ +
216 public:
│ │ │ │ +
217 Mask(Weight* v, Weight* e, Weight* f) :
│ │ │ │ +
218 _vertWeights(v), _edgeWeights(e), _faceWeights(f),
│ │ │ │ +
219 _vertCount(0), _edgeCount(0), _faceCount(0),
│ │ │ │ +
220 _faceWeightsForFaceCenters(false)
│ │ │ │ +
221 { }
│ │ │ │ +
222
│ │ │ │ +
223 ~Mask() { }
│ │ │ │ +
224
│ │ │ │ +
225 public: // Generic interface expected of <typename MASK>:
│ │ │ │ +
226 int GetNumVertexWeights() const { return _vertCount; }
│ │ │ │ +
227 int GetNumEdgeWeights() const { return _edgeCount; }
│ │ │ │ +
228 int GetNumFaceWeights() const { return _faceCount; }
│ │ │ │ +
229
│ │ │ │ +
230 void SetNumVertexWeights(int count) { _vertCount = count; }
│ │ │ │ +
231 void SetNumEdgeWeights( int count) { _edgeCount = count; }
│ │ │ │ +
232 void SetNumFaceWeights( int count) { _faceCount = count; }
│ │ │ │ +
233
│ │ │ │ +
234 Weight const& VertexWeight(int index) const { return _vertWeights[index]; }
│ │ │ │ +
235 Weight const& EdgeWeight( int index) const { return _edgeWeights[index]; }
│ │ │ │ +
236 Weight const& FaceWeight( int index) const { return _faceWeights[index]; }
│ │ │ │ +
237
│ │ │ │ +
238 Weight& VertexWeight(int index) { return _vertWeights[index]; }
│ │ │ │ +
239 Weight& EdgeWeight( int index) { return _edgeWeights[index]; }
│ │ │ │ +
240 Weight& FaceWeight( int index) { return _faceWeights[index]; }
│ │ │ │ +
241
│ │ │ │ +
242 bool AreFaceWeightsForFaceCenters() const { return _faceWeightsForFaceCenters; }
│ │ │ │ +
243 void SetFaceWeightsForFaceCenters(bool on) { _faceWeightsForFaceCenters = on; }
│ │ │ │ +
244
│ │ │ │ +
245 private:
│ │ │ │ +
246 Weight* _vertWeights;
│ │ │ │ +
247 Weight* _edgeWeights;
│ │ │ │ +
248 Weight* _faceWeights;
│ │ │ │ +
249
│ │ │ │ +
250 int _vertCount;
│ │ │ │ +
251 int _edgeCount;
│ │ │ │ +
252 int _faceCount;
│ │ │ │ +
253
│ │ │ │ +
254 bool _faceWeightsForFaceCenters;
│ │ │ │ +
255 };
│ │ │ │ +
256};
│ │ │ │ +
257
│ │ │ │ +
258
│ │ │ │ +
259//
│ │ │ │ +
260// Public entry points to the methods. Queries of the scheme type and its
│ │ │ │ +
261// use as a template parameter in subsequent implementation will be factored
│ │ │ │ +
262// out of a later release:
│ │ │ │ +
263//
│ │ │ │ +
264template <typename REAL>
│ │ │ │ +
265template <class T, class U>
│ │ │ │ +
266inline void
│ │ │ │ +
│ │ │ │ +
267PrimvarRefinerReal<REAL>::Interpolate(int level, T const & src, U & dst) const {
│ │ │ │ +
268
│ │ │ │ +
269 assert(level>0 && level<=(int)_refiner._refinements.size());
│ │ │ │ +
270
│ │ │ │ +
271 switch (_refiner._subdivType) {
│ │ │ │ + │ │ │ │ +
273 interpFromFaces<Sdc::SCHEME_CATMARK>(level, src, dst);
│ │ │ │ +
274 interpFromEdges<Sdc::SCHEME_CATMARK>(level, src, dst);
│ │ │ │ +
275 interpFromVerts<Sdc::SCHEME_CATMARK>(level, src, dst);
│ │ │ │ +
276 break;
│ │ │ │ +
277 case Sdc::SCHEME_LOOP:
│ │ │ │ +
278 interpFromFaces<Sdc::SCHEME_LOOP>(level, src, dst);
│ │ │ │ +
279 interpFromEdges<Sdc::SCHEME_LOOP>(level, src, dst);
│ │ │ │ +
280 interpFromVerts<Sdc::SCHEME_LOOP>(level, src, dst);
│ │ │ │ +
281 break;
│ │ │ │ + │ │ │ │ +
283 interpFromFaces<Sdc::SCHEME_BILINEAR>(level, src, dst);
│ │ │ │ +
284 interpFromEdges<Sdc::SCHEME_BILINEAR>(level, src, dst);
│ │ │ │ +
285 interpFromVerts<Sdc::SCHEME_BILINEAR>(level, src, dst);
│ │ │ │ +
286 break;
│ │ │ │ +
287 }
│ │ │ │ +
288}
│ │ │ │ +
│ │ │ │ +
289
│ │ │ │ +
290template <typename REAL>
│ │ │ │ +
291template <class T, class U>
│ │ │ │ +
292inline void
│ │ │ │
│ │ │ │ -
293 static StencilTable const * Create(
│ │ │ │ -
294 TopologyRefiner const & refiner, Options options = Options()) {
│ │ │ │ -
295
│ │ │ │ -
296 return static_cast<StencilTable const *>(
│ │ │ │ -
297 BaseFactory::Create(refiner, options));
│ │ │ │ -
298 }
│ │ │ │ -
│ │ │ │ -
299
│ │ │ │ -
│ │ │ │ -
300 static StencilTable const * Create(
│ │ │ │ -
301 int numTables, StencilTable const ** tables) {
│ │ │ │ -
302
│ │ │ │ -
303 return static_cast<StencilTable const *>(
│ │ │ │ -
304 BaseFactory::Create(numTables,
│ │ │ │ -
305 reinterpret_cast<BaseTable const **>(tables)));
│ │ │ │ -
306 }
│ │ │ │ -
│ │ │ │ -
307
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
309 TopologyRefiner const &refiner,
│ │ │ │ -
310 StencilTable const *baseStencilTable,
│ │ │ │ -
311 StencilTable const *localPointStencilTable,
│ │ │ │ -
312 bool factorize = true) {
│ │ │ │ -
313
│ │ │ │ -
314 return static_cast<StencilTable const *>(
│ │ │ │ - │ │ │ │ -
316 static_cast<BaseTable const *>(baseStencilTable),
│ │ │ │ -
317 static_cast<BaseTable const *>(localPointStencilTable),
│ │ │ │ -
318 factorize));
│ │ │ │ -
319 }
│ │ │ │ -
│ │ │ │ +
293PrimvarRefinerReal<REAL>::InterpolateFaceVarying(int level, T const & src, U & dst, int channel) const {
│ │ │ │ +
294
│ │ │ │ +
295 assert(level>0 && level<=(int)_refiner._refinements.size());
│ │ │ │ +
296
│ │ │ │ +
297 switch (_refiner._subdivType) {
│ │ │ │ + │ │ │ │ +
299 interpFVarFromFaces<Sdc::SCHEME_CATMARK>(level, src, dst, channel);
│ │ │ │ +
300 interpFVarFromEdges<Sdc::SCHEME_CATMARK>(level, src, dst, channel);
│ │ │ │ +
301 interpFVarFromVerts<Sdc::SCHEME_CATMARK>(level, src, dst, channel);
│ │ │ │ +
302 break;
│ │ │ │ +
303 case Sdc::SCHEME_LOOP:
│ │ │ │ +
304 interpFVarFromFaces<Sdc::SCHEME_LOOP>(level, src, dst, channel);
│ │ │ │ +
305 interpFVarFromEdges<Sdc::SCHEME_LOOP>(level, src, dst, channel);
│ │ │ │ +
306 interpFVarFromVerts<Sdc::SCHEME_LOOP>(level, src, dst, channel);
│ │ │ │ +
307 break;
│ │ │ │ + │ │ │ │ +
309 interpFVarFromFaces<Sdc::SCHEME_BILINEAR>(level, src, dst, channel);
│ │ │ │ +
310 interpFVarFromEdges<Sdc::SCHEME_BILINEAR>(level, src, dst, channel);
│ │ │ │ +
311 interpFVarFromVerts<Sdc::SCHEME_BILINEAR>(level, src, dst, channel);
│ │ │ │ +
312 break;
│ │ │ │ +
313 }
│ │ │ │ +
314}
│ │ │ │ +
│ │ │ │ +
315
│ │ │ │ +
316template <typename REAL>
│ │ │ │ +
317template <class T, class U>
│ │ │ │ +
318inline void
│ │ │ │ +
│ │ │ │ +
319PrimvarRefinerReal<REAL>::Limit(T const & src, U & dst) const {
│ │ │ │
320
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
322 TopologyRefiner const &refiner,
│ │ │ │ -
323 StencilTable const *baseStencilTable,
│ │ │ │ -
324 StencilTable const *localPointStencilTable,
│ │ │ │ -
325 bool factorize = true) {
│ │ │ │ -
326
│ │ │ │ -
327 return static_cast<StencilTable const *>(
│ │ │ │ - │ │ │ │ -
329 static_cast<BaseTable const *>(baseStencilTable),
│ │ │ │ -
330 static_cast<BaseTable const *>(localPointStencilTable),
│ │ │ │ -
331 factorize));
│ │ │ │ -
332 }
│ │ │ │ -
│ │ │ │ -
333
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
335 TopologyRefiner const &refiner,
│ │ │ │ -
336 StencilTable const *baseStencilTable,
│ │ │ │ -
337 StencilTable const *localPointStencilTable,
│ │ │ │ -
338 int channel = 0,
│ │ │ │ -
339 bool factorize = true) {
│ │ │ │ +
321 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == 0) {
│ │ │ │ + │ │ │ │ +
323 "Failure in PrimvarRefiner::Limit() -- "
│ │ │ │ +
324 "last level of refinement does not include full topology.");
│ │ │ │ +
325 return;
│ │ │ │ +
326 }
│ │ │ │ +
327
│ │ │ │ +
328 switch (_refiner._subdivType) {
│ │ │ │ + │ │ │ │ +
330 limit<Sdc::SCHEME_CATMARK>(src, dst, (U*)0, (U*)0);
│ │ │ │ +
331 break;
│ │ │ │ +
332 case Sdc::SCHEME_LOOP:
│ │ │ │ +
333 limit<Sdc::SCHEME_LOOP>(src, dst, (U*)0, (U*)0);
│ │ │ │ +
334 break;
│ │ │ │ + │ │ │ │ +
336 limit<Sdc::SCHEME_BILINEAR>(src, dst, (U*)0, (U*)0);
│ │ │ │ +
337 break;
│ │ │ │ +
338 }
│ │ │ │ +
339}
│ │ │ │ +
│ │ │ │
340
│ │ │ │ -
341 return static_cast<StencilTable const *>(
│ │ │ │ - │ │ │ │ -
343 static_cast<BaseTable const *>(baseStencilTable),
│ │ │ │ -
344 static_cast<BaseTable const *>(localPointStencilTable),
│ │ │ │ -
345 channel, factorize));
│ │ │ │ -
346 }
│ │ │ │ -
│ │ │ │ -
347};
│ │ │ │ -
│ │ │ │ -
348
│ │ │ │ -
349class LimitStencil;
│ │ │ │ -
350class LimitStencilTable;
│ │ │ │ -
351
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
355private:
│ │ │ │ - │ │ │ │ - │ │ │ │ -
358
│ │ │ │ -
359public:
│ │ │ │ -
│ │ │ │ -
360 static LimitStencilTable const * Create(
│ │ │ │ -
361 TopologyRefiner const & refiner,
│ │ │ │ -
362 LocationArrayVec const & locationArrays,
│ │ │ │ -
363 StencilTable const * cvStencils = 0,
│ │ │ │ -
364 PatchTable const * patchTable = 0,
│ │ │ │ -
365 Options options = Options()) {
│ │ │ │ -
366
│ │ │ │ -
367 return static_cast<LimitStencilTable const *>(
│ │ │ │ - │ │ │ │ -
369 refiner,
│ │ │ │ -
370 locationArrays,
│ │ │ │ -
371 static_cast<BaseTable const *>(cvStencils),
│ │ │ │ -
372 patchTable,
│ │ │ │ -
373 options));
│ │ │ │ -
374 }
│ │ │ │ -
│ │ │ │ -
375};
│ │ │ │ -
│ │ │ │ -
376
│ │ │ │ -
377} // end namespace Far
│ │ │ │ -
378
│ │ │ │ -
379} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
380using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
381
│ │ │ │ -
382} // end namespace OpenSubdiv
│ │ │ │ -
383
│ │ │ │ -
384#endif // OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H
│ │ │ │ - │ │ │ │ -
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ - │ │ │ │ -
static StencilTableReal< REAL > const * Create(TopologyRefiner const &refiner, Options options=Options())
Instantiates StencilTable from TopologyRefiner that have been refined uniformly or adaptively.
│ │ │ │ -
static StencilTableReal< REAL > const * AppendLocalPointStencilTableFaceVarying(TopologyRefiner const &refiner, StencilTableReal< REAL > const *baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, int channel=0, bool factorize=true)
Utility function for stencil splicing for local point face-varying stencils.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
static StencilTableReal< REAL > const * AppendLocalPointStencilTableVarying(TopologyRefiner const &refiner, StencilTableReal< REAL > const *baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, bool factorize=true)
Utility function for stencil splicing for local point varying stencils.
│ │ │ │ -
static StencilTableReal< REAL > const * AppendLocalPointStencilTable(TopologyRefiner const &refiner, StencilTableReal< REAL > const *baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, bool factorize=true)
Utility function for stencil splicing for local point stencils.
│ │ │ │ -
static StencilTableReal< REAL > const * Create(int numTables, StencilTableReal< REAL > const **tables)
Instantiates StencilTable by concatenating an array of existing stencil tables.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
static LimitStencilTableReal< REAL > const * Create(TopologyRefiner const &refiner, LocationArrayVec const &locationArrays, StencilTableReal< REAL > const *cvStencils=0, PatchTable const *patchTable=0, Options options=Options())
Instantiates LimitStencilTable from a TopologyRefiner that has been refined either uniformly or adapt...
│ │ │ │ - │ │ │ │ -
Vertex stencil class wrapping the template for compatibility.
│ │ │ │ - │ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ - │ │ │ │ -
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
unsigned int generateIntermediateLevels
vertices at all levels or highest only
│ │ │ │ -
unsigned int generateControlVerts
generate stencils for control-vertices
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
unsigned int generate2ndDerivatives
Generate weights for 2nd derivatives.
│ │ │ │ -
unsigned int generate1stDerivatives
Generate weights for 1st derivatives.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
Stencil table factory class wrapping the template for compatibility.
│ │ │ │ -
static StencilTable const * AppendLocalPointStencilTableVarying(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, StencilTable const *localPointStencilTable, bool factorize=true)
│ │ │ │ -
static StencilTable const * Create(TopologyRefiner const &refiner, Options options=Options())
│ │ │ │ -
static StencilTable const * AppendLocalPointStencilTableFaceVarying(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, StencilTable const *localPointStencilTable, int channel=0, bool factorize=true)
│ │ │ │ -
static StencilTable const * AppendLocalPointStencilTable(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, StencilTable const *localPointStencilTable, bool factorize=true)
│ │ │ │ -
static StencilTable const * Create(int numTables, StencilTable const **tables)
│ │ │ │ -
Stencil table factory class wrapping the template for compatibility.
│ │ │ │ -
static LimitStencilTable const * Create(TopologyRefiner const &refiner, LocationArrayVec const &locationArrays, StencilTable const *cvStencils=0, PatchTable const *patchTable=0, Options options=Options())
│ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ +
341template <typename REAL>
│ │ │ │ +
342template <class T, class U, class U1, class U2>
│ │ │ │ +
343inline void
│ │ │ │ +
│ │ │ │ +
344PrimvarRefinerReal<REAL>::Limit(T const & src, U & dstPos, U1 & dstTan1, U2 & dstTan2) const {
│ │ │ │ +
345
│ │ │ │ +
346 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == 0) {
│ │ │ │ + │ │ │ │ +
348 "Failure in PrimvarRefiner::Limit() -- "
│ │ │ │ +
349 "last level of refinement does not include full topology.");
│ │ │ │ +
350 return;
│ │ │ │ +
351 }
│ │ │ │ +
352
│ │ │ │ +
353 switch (_refiner._subdivType) {
│ │ │ │ + │ │ │ │ +
355 limit<Sdc::SCHEME_CATMARK>(src, dstPos, &dstTan1, &dstTan2);
│ │ │ │ +
356 break;
│ │ │ │ +
357 case Sdc::SCHEME_LOOP:
│ │ │ │ +
358 limit<Sdc::SCHEME_LOOP>(src, dstPos, &dstTan1, &dstTan2);
│ │ │ │ +
359 break;
│ │ │ │ + │ │ │ │ +
361 limit<Sdc::SCHEME_BILINEAR>(src, dstPos, &dstTan1, &dstTan2);
│ │ │ │ +
362 break;
│ │ │ │ +
363 }
│ │ │ │ +
364}
│ │ │ │ +
│ │ │ │ +
365
│ │ │ │ +
366template <typename REAL>
│ │ │ │ +
367template <class T, class U>
│ │ │ │ +
368inline void
│ │ │ │ +
│ │ │ │ +
369PrimvarRefinerReal<REAL>::LimitFaceVarying(T const & src, U & dst, int channel) const {
│ │ │ │ +
370
│ │ │ │ +
371 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == 0) {
│ │ │ │ + │ │ │ │ +
373 "Failure in PrimvarRefiner::LimitFaceVarying() -- "
│ │ │ │ +
374 "last level of refinement does not include full topology.");
│ │ │ │ +
375 return;
│ │ │ │ +
376 }
│ │ │ │ +
377
│ │ │ │ +
378 switch (_refiner._subdivType) {
│ │ │ │ + │ │ │ │ +
380 limitFVar<Sdc::SCHEME_CATMARK>(src, dst, channel);
│ │ │ │ +
381 break;
│ │ │ │ +
382 case Sdc::SCHEME_LOOP:
│ │ │ │ +
383 limitFVar<Sdc::SCHEME_LOOP>(src, dst, channel);
│ │ │ │ +
384 break;
│ │ │ │ + │ │ │ │ +
386 limitFVar<Sdc::SCHEME_BILINEAR>(src, dst, channel);
│ │ │ │ +
387 break;
│ │ │ │ +
388 }
│ │ │ │ +
389}
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
390
│ │ │ │ +
391template <typename REAL>
│ │ │ │ +
392template <class T, class U>
│ │ │ │ +
393inline void
│ │ │ │ +
│ │ │ │ +
394PrimvarRefinerReal<REAL>::InterpolateFaceUniform(int level, T const & src, U & dst) const {
│ │ │ │ +
395
│ │ │ │ +
396 assert(level>0 && level<=(int)_refiner._refinements.size());
│ │ │ │ +
397
│ │ │ │ +
398 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ +
399 Vtr::internal::Level const & child = refinement.child();
│ │ │ │ +
400
│ │ │ │ +
401 for (int cFace = 0; cFace < child.getNumFaces(); ++cFace) {
│ │ │ │ +
402
│ │ │ │ +
403 Vtr::Index pFace = refinement.getChildFaceParentFace(cFace);
│ │ │ │ +
404
│ │ │ │ +
405 dst[cFace] = src[pFace];
│ │ │ │ +
406 }
│ │ │ │ +
407}
│ │ │ │ +
│ │ │ │ +
408
│ │ │ │ +
409template <typename REAL>
│ │ │ │ +
410template <class T, class U>
│ │ │ │ +
411inline void
│ │ │ │ +
│ │ │ │ +
412PrimvarRefinerReal<REAL>::InterpolateVarying(int level, T const & src, U & dst) const {
│ │ │ │ +
413
│ │ │ │ +
414 assert(level>0 && level<=(int)_refiner._refinements.size());
│ │ │ │ +
415
│ │ │ │ +
416 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ +
417 Vtr::internal::Level const & parent = refinement.parent();
│ │ │ │ +
418
│ │ │ │ +
419 //
│ │ │ │ +
420 // Group values to interpolate based on origin -- note that there may
│ │ │ │ +
421 // be none originating from faces:
│ │ │ │ +
422 //
│ │ │ │ +
423 if (refinement.getNumChildVerticesFromFaces() > 0) {
│ │ │ │ +
424
│ │ │ │ +
425 for (int face = 0; face < parent.getNumFaces(); ++face) {
│ │ │ │ +
426
│ │ │ │ +
427 Vtr::Index cVert = refinement.getFaceChildVertex(face);
│ │ │ │ +
428 if (Vtr::IndexIsValid(cVert)) {
│ │ │ │ +
429
│ │ │ │ +
430 // Apply the weights to the parent face's vertices:
│ │ │ │ +
431 ConstIndexArray fVerts = parent.getFaceVertices(face);
│ │ │ │ +
432
│ │ │ │ +
433 Weight fVaryingWeight = 1.0f / (Weight) fVerts.size();
│ │ │ │ +
434
│ │ │ │ +
435 dst[cVert].Clear();
│ │ │ │ +
436 for (int i = 0; i < fVerts.size(); ++i) {
│ │ │ │ +
437 dst[cVert].AddWithWeight(src[fVerts[i]], fVaryingWeight);
│ │ │ │ +
438 }
│ │ │ │ +
439 }
│ │ │ │ +
440 }
│ │ │ │ +
441 }
│ │ │ │ +
442 for (int edge = 0; edge < parent.getNumEdges(); ++edge) {
│ │ │ │ +
443
│ │ │ │ +
444 Vtr::Index cVert = refinement.getEdgeChildVertex(edge);
│ │ │ │ +
445 if (Vtr::IndexIsValid(cVert)) {
│ │ │ │ +
446
│ │ │ │ +
447 // Apply the weights to the parent edges's vertices
│ │ │ │ +
448 ConstIndexArray eVerts = parent.getEdgeVertices(edge);
│ │ │ │ +
449
│ │ │ │ +
450 dst[cVert].Clear();
│ │ │ │ +
451 dst[cVert].AddWithWeight(src[eVerts[0]], 0.5f);
│ │ │ │ +
452 dst[cVert].AddWithWeight(src[eVerts[1]], 0.5f);
│ │ │ │ +
453 }
│ │ │ │ +
454 }
│ │ │ │ +
455 for (int vert = 0; vert < parent.getNumVertices(); ++vert) {
│ │ │ │ +
456
│ │ │ │ +
457 Vtr::Index cVert = refinement.getVertexChildVertex(vert);
│ │ │ │ +
458 if (Vtr::IndexIsValid(cVert)) {
│ │ │ │ +
459
│ │ │ │ +
460 // Essentially copy the parent vertex:
│ │ │ │ +
461 dst[cVert].Clear();
│ │ │ │ +
462 dst[cVert].AddWithWeight(src[vert], 1.0f);
│ │ │ │ +
463 }
│ │ │ │ +
464 }
│ │ │ │ +
465}
│ │ │ │ +
│ │ │ │ +
466
│ │ │ │ +
467
│ │ │ │ +
468//
│ │ │ │ +
469// Internal implementation methods -- grouping vertices to be interpolated
│ │ │ │ +
470// based on the type of parent component from which they originated:
│ │ │ │ +
471//
│ │ │ │ +
472template <typename REAL>
│ │ │ │ +
473template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ +
474inline void
│ │ │ │ +
475PrimvarRefinerReal<REAL>::interpFromFaces(int level, T const & src, U & dst) const {
│ │ │ │ +
476
│ │ │ │ +
477 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ +
478 Vtr::internal::Level const & parent = refinement.parent();
│ │ │ │ +
479
│ │ │ │ +
480 if (refinement.getNumChildVerticesFromFaces() == 0) return;
│ │ │ │ +
481
│ │ │ │ +
482 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ +
483
│ │ │ │ +
484 Vtr::internal::StackBuffer<Weight,16> fVertWeights(parent.getMaxValence());
│ │ │ │ +
485
│ │ │ │ +
486 for (int face = 0; face < parent.getNumFaces(); ++face) {
│ │ │ │ +
487
│ │ │ │ +
488 Vtr::Index cVert = refinement.getFaceChildVertex(face);
│ │ │ │ +
489 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ +
490 continue;
│ │ │ │ +
491
│ │ │ │ +
492 // Declare and compute mask weights for this vertex relative to its parent face:
│ │ │ │ +
493 ConstIndexArray fVerts = parent.getFaceVertices(face);
│ │ │ │ +
494
│ │ │ │ +
495 Mask fMask(fVertWeights, 0, 0);
│ │ │ │ +
496 Vtr::internal::FaceInterface fHood(fVerts.size());
│ │ │ │ +
497
│ │ │ │ +
498 scheme.ComputeFaceVertexMask(fHood, fMask);
│ │ │ │ +
499
│ │ │ │ +
500 // Apply the weights to the parent face's vertices:
│ │ │ │ +
501 dst[cVert].Clear();
│ │ │ │ +
502
│ │ │ │ +
503 for (int i = 0; i < fVerts.size(); ++i) {
│ │ │ │ +
504
│ │ │ │ +
505 dst[cVert].AddWithWeight(src[fVerts[i]], fVertWeights[i]);
│ │ │ │ +
506 }
│ │ │ │ +
507 }
│ │ │ │ +
508}
│ │ │ │ +
509
│ │ │ │ +
510template <typename REAL>
│ │ │ │ +
511template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ +
512inline void
│ │ │ │ +
513PrimvarRefinerReal<REAL>::interpFromEdges(int level, T const & src, U & dst) const {
│ │ │ │ +
514
│ │ │ │ +
515 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ +
516 Vtr::internal::Level const & parent = refinement.parent();
│ │ │ │ +
517 Vtr::internal::Level const & child = refinement.child();
│ │ │ │ +
518
│ │ │ │ +
519 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ +
520
│ │ │ │ +
521 Vtr::internal::EdgeInterface eHood(parent);
│ │ │ │ +
522
│ │ │ │ +
523 Weight eVertWeights[2];
│ │ │ │ +
524 Vtr::internal::StackBuffer<Weight,8> eFaceWeights(parent.getMaxEdgeFaces());
│ │ │ │ +
525
│ │ │ │ +
526 for (int edge = 0; edge < parent.getNumEdges(); ++edge) {
│ │ │ │ +
527
│ │ │ │ +
528 Vtr::Index cVert = refinement.getEdgeChildVertex(edge);
│ │ │ │ +
529 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ +
530 continue;
│ │ │ │ +
531
│ │ │ │ +
532 // Declare and compute mask weights for this vertex relative to its parent edge:
│ │ │ │ +
533 ConstIndexArray eVerts = parent.getEdgeVertices(edge),
│ │ │ │ +
534 eFaces = parent.getEdgeFaces(edge);
│ │ │ │ +
535
│ │ │ │ +
536 Mask eMask(eVertWeights, 0, eFaceWeights);
│ │ │ │ +
537
│ │ │ │ +
538 eHood.SetIndex(edge);
│ │ │ │ +
539
│ │ │ │ +
540 Sdc::Crease::Rule pRule = (parent.getEdgeSharpness(edge) > 0.0f) ? Sdc::Crease::RULE_CREASE : Sdc::Crease::RULE_SMOOTH;
│ │ │ │ +
541 Sdc::Crease::Rule cRule = child.getVertexRule(cVert);
│ │ │ │ +
542
│ │ │ │ +
543 scheme.ComputeEdgeVertexMask(eHood, eMask, pRule, cRule);
│ │ │ │ +
544
│ │ │ │ +
545 // Apply the weights to the parent edges's vertices and (if applicable) to
│ │ │ │ +
546 // the child vertices of its incident faces:
│ │ │ │ +
547 dst[cVert].Clear();
│ │ │ │ +
548 dst[cVert].AddWithWeight(src[eVerts[0]], eVertWeights[0]);
│ │ │ │ +
549 dst[cVert].AddWithWeight(src[eVerts[1]], eVertWeights[1]);
│ │ │ │ +
550
│ │ │ │ +
551 if (eMask.GetNumFaceWeights() > 0) {
│ │ │ │ +
552
│ │ │ │ +
553 for (int i = 0; i < eFaces.size(); ++i) {
│ │ │ │ +
554
│ │ │ │ +
555 if (eMask.AreFaceWeightsForFaceCenters()) {
│ │ │ │ +
556 assert(refinement.getNumChildVerticesFromFaces() > 0);
│ │ │ │ +
557 Vtr::Index cVertOfFace = refinement.getFaceChildVertex(eFaces[i]);
│ │ │ │ +
558
│ │ │ │ +
559 assert(Vtr::IndexIsValid(cVertOfFace));
│ │ │ │ +
560 dst[cVert].AddWithWeight(dst[cVertOfFace], eFaceWeights[i]);
│ │ │ │ +
561 } else {
│ │ │ │ +
562 Vtr::Index pFace = eFaces[i];
│ │ │ │ +
563 ConstIndexArray pFaceEdges = parent.getFaceEdges(pFace),
│ │ │ │ +
564 pFaceVerts = parent.getFaceVertices(pFace);
│ │ │ │ +
565
│ │ │ │ +
566 int eInFace = 0;
│ │ │ │ +
567 for ( ; pFaceEdges[eInFace] != edge; ++eInFace ) ;
│ │ │ │ +
568
│ │ │ │ +
569 int vInFace = eInFace + 2;
│ │ │ │ +
570 if (vInFace >= pFaceVerts.size()) vInFace -= pFaceVerts.size();
│ │ │ │ +
571
│ │ │ │ +
572 Vtr::Index pVertNext = pFaceVerts[vInFace];
│ │ │ │ +
573 dst[cVert].AddWithWeight(src[pVertNext], eFaceWeights[i]);
│ │ │ │ +
574 }
│ │ │ │ +
575 }
│ │ │ │ +
576 }
│ │ │ │ +
577 }
│ │ │ │ +
578}
│ │ │ │ +
579
│ │ │ │ +
580template <typename REAL>
│ │ │ │ +
581template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ +
582inline void
│ │ │ │ +
583PrimvarRefinerReal<REAL>::interpFromVerts(int level, T const & src, U & dst) const {
│ │ │ │ +
584
│ │ │ │ +
585 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ +
586 Vtr::internal::Level const & parent = refinement.parent();
│ │ │ │ +
587 Vtr::internal::Level const & child = refinement.child();
│ │ │ │ +
588
│ │ │ │ +
589 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ +
590
│ │ │ │ +
591 Vtr::internal::VertexInterface vHood(parent, child);
│ │ │ │ +
592
│ │ │ │ +
593 Vtr::internal::StackBuffer<Weight,32> weightBuffer(2*parent.getMaxValence());
│ │ │ │ +
594
│ │ │ │ +
595 for (int vert = 0; vert < parent.getNumVertices(); ++vert) {
│ │ │ │ +
596
│ │ │ │ +
597 Vtr::Index cVert = refinement.getVertexChildVertex(vert);
│ │ │ │ +
598 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ +
599 continue;
│ │ │ │ +
600
│ │ │ │ +
601 // Declare and compute mask weights for this vertex relative to its parent edge:
│ │ │ │ +
602 ConstIndexArray vEdges = parent.getVertexEdges(vert),
│ │ │ │ +
603 vFaces = parent.getVertexFaces(vert);
│ │ │ │ +
604
│ │ │ │ +
605 Weight vVertWeight,
│ │ │ │ +
606 * vEdgeWeights = weightBuffer,
│ │ │ │ +
607 * vFaceWeights = vEdgeWeights + vEdges.size();
│ │ │ │ +
608
│ │ │ │ +
609 Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights);
│ │ │ │ +
610
│ │ │ │ +
611 vHood.SetIndex(vert, cVert);
│ │ │ │ +
612
│ │ │ │ +
613 Sdc::Crease::Rule pRule = parent.getVertexRule(vert);
│ │ │ │ +
614 Sdc::Crease::Rule cRule = child.getVertexRule(cVert);
│ │ │ │ +
615
│ │ │ │ +
616 scheme.ComputeVertexVertexMask(vHood, vMask, pRule, cRule);
│ │ │ │ +
617
│ │ │ │ +
618 // Apply the weights to the parent vertex, the vertices opposite its incident
│ │ │ │ +
619 // edges, and the child vertices of its incident faces:
│ │ │ │ +
620 //
│ │ │ │ +
621 // In order to improve numerical precision, it's better to apply smaller weights
│ │ │ │ +
622 // first, so begin with the face-weights followed by the edge-weights and the
│ │ │ │ +
623 // vertex weight last.
│ │ │ │ +
624 dst[cVert].Clear();
│ │ │ │ +
625
│ │ │ │ +
626 if (vMask.GetNumFaceWeights() > 0) {
│ │ │ │ +
627 assert(vMask.AreFaceWeightsForFaceCenters());
│ │ │ │ +
628
│ │ │ │ +
629 for (int i = 0; i < vFaces.size(); ++i) {
│ │ │ │ +
630
│ │ │ │ +
631 Vtr::Index cVertOfFace = refinement.getFaceChildVertex(vFaces[i]);
│ │ │ │ +
632 assert(Vtr::IndexIsValid(cVertOfFace));
│ │ │ │ +
633 dst[cVert].AddWithWeight(dst[cVertOfFace], vFaceWeights[i]);
│ │ │ │ +
634 }
│ │ │ │ +
635 }
│ │ │ │ +
636 if (vMask.GetNumEdgeWeights() > 0) {
│ │ │ │ +
637
│ │ │ │ +
638 for (int i = 0; i < vEdges.size(); ++i) {
│ │ │ │ +
639
│ │ │ │ +
640 ConstIndexArray eVerts = parent.getEdgeVertices(vEdges[i]);
│ │ │ │ +
641 Vtr::Index pVertOppositeEdge = (eVerts[0] == vert) ? eVerts[1] : eVerts[0];
│ │ │ │ +
642
│ │ │ │ +
643 dst[cVert].AddWithWeight(src[pVertOppositeEdge], vEdgeWeights[i]);
│ │ │ │ +
644 }
│ │ │ │ +
645 }
│ │ │ │ +
646 dst[cVert].AddWithWeight(src[vert], vVertWeight);
│ │ │ │ +
647 }
│ │ │ │ +
648}
│ │ │ │ +
649
│ │ │ │ +
650
│ │ │ │ +
651//
│ │ │ │ +
652// Internal face-varying implementation details:
│ │ │ │ +
653//
│ │ │ │ +
654template <typename REAL>
│ │ │ │ +
655template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ +
656inline void
│ │ │ │ +
657PrimvarRefinerReal<REAL>::interpFVarFromFaces(int level, T const & src, U & dst, int channel) const {
│ │ │ │ +
658
│ │ │ │ +
659 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ +
660
│ │ │ │ +
661 if (refinement.getNumChildVerticesFromFaces() == 0) return;
│ │ │ │ +
662
│ │ │ │ +
663 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ +
664
│ │ │ │ +
665 Vtr::internal::Level const & parentLevel = refinement.parent();
│ │ │ │ +
666 Vtr::internal::Level const & childLevel = refinement.child();
│ │ │ │ +
667
│ │ │ │ +
668 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel(channel);
│ │ │ │ +
669 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel(channel);
│ │ │ │ +
670
│ │ │ │ +
671 Vtr::internal::StackBuffer<Weight,16> fValueWeights(parentLevel.getMaxValence());
│ │ │ │ +
672
│ │ │ │ +
673 for (int face = 0; face < parentLevel.getNumFaces(); ++face) {
│ │ │ │ +
674
│ │ │ │ +
675 Vtr::Index cVert = refinement.getFaceChildVertex(face);
│ │ │ │ +
676 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ +
677 continue;
│ │ │ │ +
678
│ │ │ │ +
679 Vtr::Index cVertValue = childFVar.getVertexValueOffset(cVert);
│ │ │ │ +
680
│ │ │ │ +
681 // The only difference for face-varying here is that we get the values associated
│ │ │ │ +
682 // with each face-vertex directly from the FVarLevel, rather than using the parent
│ │ │ │ +
683 // face-vertices directly. If any face-vertex has any sibling values, then we may
│ │ │ │ +
684 // get the wrong one using the face-vertex index directly.
│ │ │ │ +
685
│ │ │ │ +
686 // Declare and compute mask weights for this vertex relative to its parent face:
│ │ │ │ +
687 ConstIndexArray fValues = parentFVar.getFaceValues(face);
│ │ │ │ +
688
│ │ │ │ +
689 Mask fMask(fValueWeights, 0, 0);
│ │ │ │ +
690 Vtr::internal::FaceInterface fHood(fValues.size());
│ │ │ │ +
691
│ │ │ │ +
692 scheme.ComputeFaceVertexMask(fHood, fMask);
│ │ │ │ +
693
│ │ │ │ +
694 // Apply the weights to the parent face's vertices:
│ │ │ │ +
695 dst[cVertValue].Clear();
│ │ │ │ +
696
│ │ │ │ +
697 for (int i = 0; i < fValues.size(); ++i) {
│ │ │ │ +
698 dst[cVertValue].AddWithWeight(src[fValues[i]], fValueWeights[i]);
│ │ │ │ +
699 }
│ │ │ │ +
700 }
│ │ │ │ +
701}
│ │ │ │ +
702
│ │ │ │ +
703template <typename REAL>
│ │ │ │ +
704template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ +
705inline void
│ │ │ │ +
706PrimvarRefinerReal<REAL>::interpFVarFromEdges(int level, T const & src, U & dst, int channel) const {
│ │ │ │ +
707
│ │ │ │ +
708 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ +
709
│ │ │ │ +
710 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ +
711
│ │ │ │ +
712 Vtr::internal::Level const & parentLevel = refinement.parent();
│ │ │ │ +
713 Vtr::internal::Level const & childLevel = refinement.child();
│ │ │ │ +
714
│ │ │ │ +
715 Vtr::internal::FVarRefinement const & refineFVar = refinement.getFVarRefinement(channel);
│ │ │ │ +
716 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel(channel);
│ │ │ │ +
717 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel(channel);
│ │ │ │ +
718
│ │ │ │ +
719 //
│ │ │ │ +
720 // Allocate and initialize (if linearly interpolated) interpolation weights for
│ │ │ │ +
721 // the edge mask:
│ │ │ │ +
722 //
│ │ │ │ +
723 Weight eVertWeights[2];
│ │ │ │ +
724 Vtr::internal::StackBuffer<Weight,8> eFaceWeights(parentLevel.getMaxEdgeFaces());
│ │ │ │ +
725
│ │ │ │ +
726 Mask eMask(eVertWeights, 0, eFaceWeights);
│ │ │ │ +
727
│ │ │ │ +
728 bool isLinearFVar = parentFVar.isLinear() || (_refiner._subdivType == Sdc::SCHEME_BILINEAR);
│ │ │ │ +
729 if (isLinearFVar) {
│ │ │ │ +
730 eMask.SetNumVertexWeights(2);
│ │ │ │ +
731 eMask.SetNumEdgeWeights(0);
│ │ │ │ +
732 eMask.SetNumFaceWeights(0);
│ │ │ │ +
733
│ │ │ │ +
734 eVertWeights[0] = 0.5f;
│ │ │ │ +
735 eVertWeights[1] = 0.5f;
│ │ │ │ +
736 }
│ │ │ │ +
737
│ │ │ │ +
738 Vtr::internal::EdgeInterface eHood(parentLevel);
│ │ │ │ +
739
│ │ │ │ +
740 for (int edge = 0; edge < parentLevel.getNumEdges(); ++edge) {
│ │ │ │ +
741
│ │ │ │ +
742 Vtr::Index cVert = refinement.getEdgeChildVertex(edge);
│ │ │ │ +
743 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ +
744 continue;
│ │ │ │ +
745
│ │ │ │ +
746 ConstIndexArray cVertValues = childFVar.getVertexValues(cVert);
│ │ │ │ +
747
│ │ │ │ +
748 bool fvarEdgeVertMatchesVertex = childFVar.valueTopologyMatches(cVertValues[0]);
│ │ │ │ +
749 if (fvarEdgeVertMatchesVertex) {
│ │ │ │ +
750 //
│ │ │ │ +
751 // If smoothly interpolated, compute new weights for the edge mask:
│ │ │ │ +
752 //
│ │ │ │ +
753 if (!isLinearFVar) {
│ │ │ │ +
754 eHood.SetIndex(edge);
│ │ │ │ +
755
│ │ │ │ +
756 Sdc::Crease::Rule pRule = (parentLevel.getEdgeSharpness(edge) > 0.0f)
│ │ │ │ +
757 ? Sdc::Crease::RULE_CREASE : Sdc::Crease::RULE_SMOOTH;
│ │ │ │ +
758 Sdc::Crease::Rule cRule = childLevel.getVertexRule(cVert);
│ │ │ │ +
759
│ │ │ │ +
760 scheme.ComputeEdgeVertexMask(eHood, eMask, pRule, cRule);
│ │ │ │ +
761 }
│ │ │ │ +
762
│ │ │ │ +
763 // Apply the weights to the parent edge's vertices and (if applicable) to
│ │ │ │ +
764 // the child vertices of its incident faces:
│ │ │ │ +
765 //
│ │ │ │ +
766 // Even though the face-varying topology matches the vertex topology, we need
│ │ │ │ +
767 // to be careful here when getting values corresponding to the two end-vertices.
│ │ │ │ +
768 // While the edge may be continuous, the vertices at their ends may have
│ │ │ │ +
769 // discontinuities elsewhere in their neighborhood (i.e. on the "other side"
│ │ │ │ +
770 // of the end-vertex) and so have sibling values associated with them. In most
│ │ │ │ +
771 // cases the topology for an end-vertex will match and we can use it directly,
│ │ │ │ +
772 // but we must still check and retrieve as needed.
│ │ │ │ +
773 //
│ │ │ │ +
774 // Indices for values corresponding to face-vertices are guaranteed to match,
│ │ │ │ +
775 // so we can use the child-vertex indices directly.
│ │ │ │ +
776 //
│ │ │ │ +
777 // And by "directly", we always use getVertexValue(vertexIndex) to reference
│ │ │ │ +
778 // values in the "src" to account for the possible indirection that may exist at
│ │ │ │ +
779 // level 0 -- where there may be fewer values than vertices and an additional
│ │ │ │ +
780 // indirection is necessary. We can use a vertex index directly for "dst" when
│ │ │ │ +
781 // it matches.
│ │ │ │ +
782 //
│ │ │ │ +
783 Vtr::Index eVertValues[2];
│ │ │ │ +
784
│ │ │ │ +
785 parentFVar.getEdgeFaceValues(edge, 0, eVertValues);
│ │ │ │ +
786
│ │ │ │ +
787 Index cVertValue = cVertValues[0];
│ │ │ │ +
788
│ │ │ │ +
789 dst[cVertValue].Clear();
│ │ │ │ +
790 dst[cVertValue].AddWithWeight(src[eVertValues[0]], eVertWeights[0]);
│ │ │ │ +
791 dst[cVertValue].AddWithWeight(src[eVertValues[1]], eVertWeights[1]);
│ │ │ │ +
792
│ │ │ │ +
793 if (eMask.GetNumFaceWeights() > 0) {
│ │ │ │ +
794
│ │ │ │ +
795 ConstIndexArray eFaces = parentLevel.getEdgeFaces(edge);
│ │ │ │ +
796
│ │ │ │ +
797 for (int i = 0; i < eFaces.size(); ++i) {
│ │ │ │ +
798 if (eMask.AreFaceWeightsForFaceCenters()) {
│ │ │ │ +
799
│ │ │ │ +
800 Vtr::Index cVertOfFace = refinement.getFaceChildVertex(eFaces[i]);
│ │ │ │ +
801 assert(Vtr::IndexIsValid(cVertOfFace));
│ │ │ │ +
802
│ │ │ │ +
803 Vtr::Index cValueOfFace = childFVar.getVertexValueOffset(cVertOfFace);
│ │ │ │ +
804 dst[cVertValue].AddWithWeight(dst[cValueOfFace], eFaceWeights[i]);
│ │ │ │ +
805 } else {
│ │ │ │ +
806 Vtr::Index pFace = eFaces[i];
│ │ │ │ +
807 ConstIndexArray pFaceEdges = parentLevel.getFaceEdges(pFace),
│ │ │ │ +
808 pFaceVerts = parentLevel.getFaceVertices(pFace);
│ │ │ │ +
809
│ │ │ │ +
810 int eInFace = 0;
│ │ │ │ +
811 for ( ; pFaceEdges[eInFace] != edge; ++eInFace ) ;
│ │ │ │ +
812
│ │ │ │ +
813 // Edge "i" spans vertices [i,i+1] so we want i+2...
│ │ │ │ +
814 int vInFace = eInFace + 2;
│ │ │ │ +
815 if (vInFace >= pFaceVerts.size()) vInFace -= pFaceVerts.size();
│ │ │ │ +
816
│ │ │ │ +
817 Vtr::Index pValueNext = parentFVar.getFaceValues(pFace)[vInFace];
│ │ │ │ +
818 dst[cVertValue].AddWithWeight(src[pValueNext], eFaceWeights[i]);
│ │ │ │ +
819 }
│ │ │ │ +
820 }
│ │ │ │ +
821 }
│ │ │ │ +
822 } else {
│ │ │ │ +
823 //
│ │ │ │ +
824 // Mismatched edge-verts should just be linearly interpolated between the pairs of
│ │ │ │ +
825 // values for each sibling of the child edge-vertex -- the question is: which face
│ │ │ │ +
826 // holds that pair of values for a given sibling?
│ │ │ │ +
827 //
│ │ │ │ +
828 // In the manifold case, the sibling and edge-face indices will correspond. We
│ │ │ │ +
829 // will eventually need to update this to account for > 3 incident faces.
│ │ │ │ +
830 //
│ │ │ │ +
831 for (int i = 0; i < cVertValues.size(); ++i) {
│ │ │ │ +
832 Vtr::Index eVertValues[2];
│ │ │ │ +
833 int eFaceIndex = refineFVar.getChildValueParentSource(cVert, i);
│ │ │ │ +
834 assert(eFaceIndex == i);
│ │ │ │ +
835
│ │ │ │ +
836 parentFVar.getEdgeFaceValues(edge, eFaceIndex, eVertValues);
│ │ │ │ +
837
│ │ │ │ +
838 Index cVertValue = cVertValues[i];
│ │ │ │ +
839
│ │ │ │ +
840 dst[cVertValue].Clear();
│ │ │ │ +
841 dst[cVertValue].AddWithWeight(src[eVertValues[0]], 0.5);
│ │ │ │ +
842 dst[cVertValue].AddWithWeight(src[eVertValues[1]], 0.5);
│ │ │ │ +
843 }
│ │ │ │ +
844 }
│ │ │ │ +
845 }
│ │ │ │ +
846}
│ │ │ │ +
847
│ │ │ │ +
848template <typename REAL>
│ │ │ │ +
849template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ +
850inline void
│ │ │ │ +
851PrimvarRefinerReal<REAL>::interpFVarFromVerts(int level, T const & src, U & dst, int channel) const {
│ │ │ │ +
852
│ │ │ │ +
853 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ +
854
│ │ │ │ +
855 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ +
856
│ │ │ │ +
857 Vtr::internal::Level const & parentLevel = refinement.parent();
│ │ │ │ +
858 Vtr::internal::Level const & childLevel = refinement.child();
│ │ │ │ +
859
│ │ │ │ +
860 Vtr::internal::FVarRefinement const & refineFVar = refinement.getFVarRefinement(channel);
│ │ │ │ +
861 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel(channel);
│ │ │ │ +
862 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel(channel);
│ │ │ │ +
863
│ │ │ │ +
864 bool isLinearFVar = parentFVar.isLinear() || (_refiner._subdivType == Sdc::SCHEME_BILINEAR);
│ │ │ │ +
865
│ │ │ │ +
866 Vtr::internal::StackBuffer<Weight,32> weightBuffer(2*parentLevel.getMaxValence());
│ │ │ │ +
867
│ │ │ │ +
868 Vtr::internal::StackBuffer<Vtr::Index,16> vEdgeValues(parentLevel.getMaxValence());
│ │ │ │ +
869
│ │ │ │ +
870 Vtr::internal::VertexInterface vHood(parentLevel, childLevel);
│ │ │ │ +
871
│ │ │ │ +
872 for (int vert = 0; vert < parentLevel.getNumVertices(); ++vert) {
│ │ │ │ +
873
│ │ │ │ +
874 Vtr::Index cVert = refinement.getVertexChildVertex(vert);
│ │ │ │ +
875 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ +
876 continue;
│ │ │ │ +
877
│ │ │ │ +
878 ConstIndexArray pVertValues = parentFVar.getVertexValues(vert),
│ │ │ │ +
879 cVertValues = childFVar.getVertexValues(cVert);
│ │ │ │ +
880
│ │ │ │ +
881 bool fvarVertVertMatchesVertex = childFVar.valueTopologyMatches(cVertValues[0]);
│ │ │ │ +
882 if (isLinearFVar && fvarVertVertMatchesVertex) {
│ │ │ │ +
883 dst[cVertValues[0]].Clear();
│ │ │ │ +
884 dst[cVertValues[0]].AddWithWeight(src[pVertValues[0]], 1.0f);
│ │ │ │ +
885 continue;
│ │ │ │ +
886 }
│ │ │ │ +
887
│ │ │ │ +
888 if (fvarVertVertMatchesVertex) {
│ │ │ │ +
889 //
│ │ │ │ +
890 // Declare and compute mask weights for this vertex relative to its parent edge:
│ │ │ │ +
891 //
│ │ │ │ +
892 // (We really need to encapsulate this somewhere else for use here and in the
│ │ │ │ +
893 // general case)
│ │ │ │ +
894 //
│ │ │ │ +
895 ConstIndexArray vEdges = parentLevel.getVertexEdges(vert);
│ │ │ │ +
896
│ │ │ │ +
897 Weight vVertWeight;
│ │ │ │ +
898 Weight * vEdgeWeights = weightBuffer;
│ │ │ │ +
899 Weight * vFaceWeights = vEdgeWeights + vEdges.size();
│ │ │ │ +
900
│ │ │ │ +
901 Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights);
│ │ │ │ +
902
│ │ │ │ +
903 vHood.SetIndex(vert, cVert);
│ │ │ │ +
904
│ │ │ │ +
905 Sdc::Crease::Rule pRule = parentLevel.getVertexRule(vert);
│ │ │ │ +
906 Sdc::Crease::Rule cRule = childLevel.getVertexRule(cVert);
│ │ │ │ +
907
│ │ │ │ +
908 scheme.ComputeVertexVertexMask(vHood, vMask, pRule, cRule);
│ │ │ │ +
909
│ │ │ │ +
910 // Apply the weights to the parent vertex, the vertices opposite its incident
│ │ │ │ +
911 // edges, and the child vertices of its incident faces:
│ │ │ │ +
912 //
│ │ │ │ +
913 // Even though the face-varying topology matches the vertex topology, we need
│ │ │ │ +
914 // to be careful here when getting values corresponding to vertices at the
│ │ │ │ +
915 // ends of edges. While the edge may be continuous, the end vertex may have
│ │ │ │ +
916 // discontinuities elsewhere in their neighborhood (i.e. on the "other side"
│ │ │ │ +
917 // of the end-vertex) and so have sibling values associated with them. In most
│ │ │ │ +
918 // cases the topology for an end-vertex will match and we can use it directly,
│ │ │ │ +
919 // but we must still check and retrieve as needed.
│ │ │ │ +
920 //
│ │ │ │ +
921 // Indices for values corresponding to face-vertices are guaranteed to match,
│ │ │ │ +
922 // so we can use the child-vertex indices directly.
│ │ │ │ +
923 //
│ │ │ │ +
924 // And by "directly", we always use getVertexValue(vertexIndex) to reference
│ │ │ │ +
925 // values in the "src" to account for the possible indirection that may exist at
│ │ │ │ +
926 // level 0 -- where there may be fewer values than vertices and an additional
│ │ │ │ +
927 // indirection is necessary. We can use a vertex index directly for "dst" when
│ │ │ │ +
928 // it matches.
│ │ │ │ +
929 //
│ │ │ │ +
930 // As with applying the mask to vertex data, in order to improve numerical
│ │ │ │ +
931 // precision, it's better to apply smaller weights first, so begin with the
│ │ │ │ +
932 // face-weights followed by the edge-weights and the vertex weight last.
│ │ │ │ +
933 //
│ │ │ │ +
934 Vtr::Index pVertValue = pVertValues[0];
│ │ │ │ +
935 Vtr::Index cVertValue = cVertValues[0];
│ │ │ │ +
936
│ │ │ │ +
937 dst[cVertValue].Clear();
│ │ │ │ +
938 if (vMask.GetNumFaceWeights() > 0) {
│ │ │ │ +
939 assert(vMask.AreFaceWeightsForFaceCenters());
│ │ │ │ +
940
│ │ │ │ +
941 ConstIndexArray vFaces = parentLevel.getVertexFaces(vert);
│ │ │ │ +
942
│ │ │ │ +
943 for (int i = 0; i < vFaces.size(); ++i) {
│ │ │ │ +
944
│ │ │ │ +
945 Vtr::Index cVertOfFace = refinement.getFaceChildVertex(vFaces[i]);
│ │ │ │ +
946 assert(Vtr::IndexIsValid(cVertOfFace));
│ │ │ │ +
947
│ │ │ │ +
948 Vtr::Index cValueOfFace = childFVar.getVertexValueOffset(cVertOfFace);
│ │ │ │ +
949 dst[cVertValue].AddWithWeight(dst[cValueOfFace], vFaceWeights[i]);
│ │ │ │ +
950 }
│ │ │ │ +
951 }
│ │ │ │ +
952 if (vMask.GetNumEdgeWeights() > 0) {
│ │ │ │ +
953
│ │ │ │ +
954 parentFVar.getVertexEdgeValues(vert, vEdgeValues);
│ │ │ │ +
955
│ │ │ │ +
956 for (int i = 0; i < vEdges.size(); ++i) {
│ │ │ │ +
957 dst[cVertValue].AddWithWeight(src[vEdgeValues[i]], vEdgeWeights[i]);
│ │ │ │ +
958 }
│ │ │ │ +
959 }
│ │ │ │ +
960 dst[cVertValue].AddWithWeight(src[pVertValue], vVertWeight);
│ │ │ │ +
961 } else {
│ │ │ │ +
962 //
│ │ │ │ +
963 // Each FVar value associated with a vertex will be either a corner or a crease,
│ │ │ │ +
964 // or potentially in transition from corner to crease:
│ │ │ │ +
965 // - if the CHILD is a corner, there can be no transition so we have a corner
│ │ │ │ +
966 // - otherwise if the PARENT is a crease, both will be creases (no transition)
│ │ │ │ +
967 // - otherwise the parent must be a corner and the child a crease (transition)
│ │ │ │ +
968 //
│ │ │ │ +
969 Vtr::internal::FVarLevel::ConstValueTagArray pValueTags = parentFVar.getVertexValueTags(vert);
│ │ │ │ +
970 Vtr::internal::FVarLevel::ConstValueTagArray cValueTags = childFVar.getVertexValueTags(cVert);
│ │ │ │ +
971
│ │ │ │ +
972 for (int cSiblingIndex = 0; cSiblingIndex < cVertValues.size(); ++cSiblingIndex) {
│ │ │ │ +
973 int pSiblingIndex = refineFVar.getChildValueParentSource(cVert, cSiblingIndex);
│ │ │ │ +
974 assert(pSiblingIndex == cSiblingIndex);
│ │ │ │ +
975
│ │ │ │ +
976 typedef Vtr::internal::FVarLevel::Sibling SiblingIntType;
│ │ │ │ +
977
│ │ │ │ +
978 SiblingIntType cSibling = (SiblingIntType) cSiblingIndex;
│ │ │ │ +
979 SiblingIntType pSibling = (SiblingIntType) pSiblingIndex;
│ │ │ │ +
980
│ │ │ │ +
981 Vtr::Index pVertValue = pVertValues[pSibling];
│ │ │ │ +
982 Vtr::Index cVertValue = cVertValues[cSibling];
│ │ │ │ +
983
│ │ │ │ +
984 dst[cVertValue].Clear();
│ │ │ │ +
985 if (isLinearFVar || cValueTags[cSibling].isCorner()) {
│ │ │ │ +
986 dst[cVertValue].AddWithWeight(src[pVertValue], 1.0f);
│ │ │ │ +
987 } else {
│ │ │ │ +
988 //
│ │ │ │ +
989 // We have either a crease or a transition from corner to crease -- in
│ │ │ │ +
990 // either case, we need the end values for the full/fractional crease:
│ │ │ │ +
991 //
│ │ │ │ +
992 Index pEndValues[2];
│ │ │ │ +
993 parentFVar.getVertexCreaseEndValues(vert, pSibling, pEndValues);
│ │ │ │ +
994
│ │ │ │ +
995 Weight vWeight = 0.75f;
│ │ │ │ +
996 Weight eWeight = 0.125f;
│ │ │ │ +
997
│ │ │ │ +
998 //
│ │ │ │ +
999 // If semi-sharp we need to apply fractional weighting -- if made sharp because
│ │ │ │ +
1000 // of the other sibling (dependent-sharp) use the fractional weight from that
│ │ │ │ +
1001 // other sibling (should only occur when there are 2):
│ │ │ │ +
1002 //
│ │ │ │ +
1003 if (pValueTags[pSibling].isSemiSharp()) {
│ │ │ │ +
1004 Weight wCorner = pValueTags[pSibling].isDepSharp()
│ │ │ │ +
1005 ? refineFVar.getFractionalWeight(vert, !pSibling, cVert, !cSibling)
│ │ │ │ +
1006 : refineFVar.getFractionalWeight(vert, pSibling, cVert, cSibling);
│ │ │ │ +
1007 Weight wCrease = 1.0f - wCorner;
│ │ │ │ +
1008
│ │ │ │ +
1009 vWeight = wCrease * 0.75f + wCorner;
│ │ │ │ +
1010 eWeight = wCrease * 0.125f;
│ │ │ │ +
1011 }
│ │ │ │ +
1012 dst[cVertValue].AddWithWeight(src[pEndValues[0]], eWeight);
│ │ │ │ +
1013 dst[cVertValue].AddWithWeight(src[pEndValues[1]], eWeight);
│ │ │ │ +
1014 dst[cVertValue].AddWithWeight(src[pVertValue], vWeight);
│ │ │ │ +
1015 }
│ │ │ │ +
1016 }
│ │ │ │ +
1017 }
│ │ │ │ +
1018 }
│ │ │ │ +
1019}
│ │ │ │ +
1020
│ │ │ │ +
1021template <typename REAL>
│ │ │ │ +
1022template <Sdc::SchemeType SCHEME, class T, class U, class U1, class U2>
│ │ │ │ +
1023inline void
│ │ │ │ +
1024PrimvarRefinerReal<REAL>::limit(T const & src, U & dstPos, U1 * dstTan1Ptr, U2 * dstTan2Ptr) const {
│ │ │ │ +
1025
│ │ │ │ +
1026 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ +
1027
│ │ │ │ +
1028 Vtr::internal::Level const & level = _refiner.getLevel(_refiner.GetMaxLevel());
│ │ │ │ +
1029
│ │ │ │ +
1030 int maxWeightsPerMask = 1 + 2 * level.getMaxValence();
│ │ │ │ +
1031 bool hasTangents = (dstTan1Ptr && dstTan2Ptr);
│ │ │ │ +
1032 int numMasks = 1 + (hasTangents ? 2 : 0);
│ │ │ │ +
1033
│ │ │ │ +
1034 Vtr::internal::StackBuffer<Index,33> indexBuffer(maxWeightsPerMask);
│ │ │ │ +
1035 Vtr::internal::StackBuffer<Weight,99> weightBuffer(numMasks * maxWeightsPerMask);
│ │ │ │ +
1036
│ │ │ │ +
1037 Weight * vPosWeights = weightBuffer,
│ │ │ │ +
1038 * ePosWeights = vPosWeights + 1,
│ │ │ │ +
1039 * fPosWeights = ePosWeights + level.getMaxValence();
│ │ │ │ +
1040 Weight * vTan1Weights = vPosWeights + maxWeightsPerMask,
│ │ │ │ +
1041 * eTan1Weights = ePosWeights + maxWeightsPerMask,
│ │ │ │ +
1042 * fTan1Weights = fPosWeights + maxWeightsPerMask;
│ │ │ │ +
1043 Weight * vTan2Weights = vTan1Weights + maxWeightsPerMask,
│ │ │ │ +
1044 * eTan2Weights = eTan1Weights + maxWeightsPerMask,
│ │ │ │ +
1045 * fTan2Weights = fTan1Weights + maxWeightsPerMask;
│ │ │ │ +
1046
│ │ │ │ +
1047 Mask posMask( vPosWeights, ePosWeights, fPosWeights);
│ │ │ │ +
1048 Mask tan1Mask(vTan1Weights, eTan1Weights, fTan1Weights);
│ │ │ │ +
1049 Mask tan2Mask(vTan2Weights, eTan2Weights, fTan2Weights);
│ │ │ │ +
1050
│ │ │ │ +
1051 // This is a bit obscure -- assigning both parent and child as last level -- but
│ │ │ │ +
1052 // this mask type was intended for another purpose. Consider one for the limit:
│ │ │ │ +
1053 Vtr::internal::VertexInterface vHood(level, level);
│ │ │ │ +
1054
│ │ │ │ +
1055 for (int vert = 0; vert < level.getNumVertices(); ++vert) {
│ │ │ │ +
1056 ConstIndexArray vEdges = level.getVertexEdges(vert);
│ │ │ │ +
1057
│ │ │ │ +
1058 // Incomplete vertices (present in sparse refinement) do not have their full
│ │ │ │ +
1059 // topological neighborhood to determine a proper limit -- just leave the
│ │ │ │ +
1060 // vertex at the refined location and continue to the next:
│ │ │ │ +
1061 if (level.getVertexTag(vert)._incomplete || (vEdges.size() == 0)) {
│ │ │ │ +
1062 dstPos[vert].Clear();
│ │ │ │ +
1063 dstPos[vert].AddWithWeight(src[vert], 1.0);
│ │ │ │ +
1064 if (hasTangents) {
│ │ │ │ +
1065 (*dstTan1Ptr)[vert].Clear();
│ │ │ │ +
1066 (*dstTan2Ptr)[vert].Clear();
│ │ │ │ +
1067 }
│ │ │ │ +
1068 continue;
│ │ │ │ +
1069 }
│ │ │ │ +
1070
│ │ │ │ +
1071 //
│ │ │ │ +
1072 // Limit masks require the subdivision Rule for the vertex in order to deal
│ │ │ │ +
1073 // with infinitely sharp features correctly -- including boundaries and corners.
│ │ │ │ +
1074 // The vertex neighborhood is minimally defined with vertex and edge counts.
│ │ │ │ +
1075 //
│ │ │ │ +
1076 Sdc::Crease::Rule vRule = level.getVertexRule(vert);
│ │ │ │ +
1077
│ │ │ │ +
1078 // This is a bit obscure -- child vertex index will be ignored here
│ │ │ │ +
1079 vHood.SetIndex(vert, vert);
│ │ │ │ +
1080
│ │ │ │ +
1081 if (hasTangents) {
│ │ │ │ +
1082 scheme.ComputeVertexLimitMask(vHood, posMask, tan1Mask, tan2Mask, vRule);
│ │ │ │ +
1083 } else {
│ │ │ │ +
1084 scheme.ComputeVertexLimitMask(vHood, posMask, vRule);
│ │ │ │ +
1085 }
│ │ │ │ +
1086
│ │ │ │ +
1087 //
│ │ │ │ +
1088 // Gather the neighboring vertices of this vertex -- the vertices opposite its
│ │ │ │ +
1089 // incident edges, and the opposite vertices of its incident faces:
│ │ │ │ +
1090 //
│ │ │ │ +
1091 Index * eIndices = indexBuffer;
│ │ │ │ +
1092 Index * fIndices = indexBuffer + vEdges.size();
│ │ │ │ +
1093
│ │ │ │ +
1094 for (int i = 0; i < vEdges.size(); ++i) {
│ │ │ │ +
1095 ConstIndexArray eVerts = level.getEdgeVertices(vEdges[i]);
│ │ │ │ +
1096
│ │ │ │ +
1097 eIndices[i] = (eVerts[0] == vert) ? eVerts[1] : eVerts[0];
│ │ │ │ +
1098 }
│ │ │ │ +
1099 if (posMask.GetNumFaceWeights() || (hasTangents && tan1Mask.GetNumFaceWeights())) {
│ │ │ │ +
1100 ConstIndexArray vFaces = level.getVertexFaces(vert);
│ │ │ │ +
1101 ConstLocalIndexArray vInFace = level.getVertexFaceLocalIndices(vert);
│ │ │ │ +
1102
│ │ │ │ +
1103 for (int i = 0; i < vFaces.size(); ++i) {
│ │ │ │ +
1104 ConstIndexArray fVerts = level.getFaceVertices(vFaces[i]);
│ │ │ │ +
1105
│ │ │ │ +
1106 LocalIndex vOppInFace = (vInFace[i] + 2);
│ │ │ │ +
1107 if (vOppInFace >= fVerts.size()) vOppInFace -= (LocalIndex)fVerts.size();
│ │ │ │ +
1108
│ │ │ │ +
1109 fIndices[i] = level.getFaceVertices(vFaces[i])[vOppInFace];
│ │ │ │ +
1110 }
│ │ │ │ +
1111 }
│ │ │ │ +
1112
│ │ │ │ +
1113 //
│ │ │ │ +
1114 // Combine the weights and indices for position and tangents. As with applying
│ │ │ │ +
1115 // refinement masks to vertex data, in order to improve numerical precision, it's
│ │ │ │ +
1116 // better to apply smaller weights first, so begin with the face-weights followed
│ │ │ │ +
1117 // by the edge-weights and the vertex weight last.
│ │ │ │ +
1118 //
│ │ │ │ +
1119 dstPos[vert].Clear();
│ │ │ │ +
1120 for (int i = 0; i < posMask.GetNumFaceWeights(); ++i) {
│ │ │ │ +
1121 dstPos[vert].AddWithWeight(src[fIndices[i]], fPosWeights[i]);
│ │ │ │ +
1122 }
│ │ │ │ +
1123 for (int i = 0; i < posMask.GetNumEdgeWeights(); ++i) {
│ │ │ │ +
1124 dstPos[vert].AddWithWeight(src[eIndices[i]], ePosWeights[i]);
│ │ │ │ +
1125 }
│ │ │ │ +
1126 dstPos[vert].AddWithWeight(src[vert], vPosWeights[0]);
│ │ │ │ +
1127
│ │ │ │ +
1128 //
│ │ │ │ +
1129 // Apply the tangent masks -- both will have the same number of weights and
│ │ │ │ +
1130 // indices (one tangent may be "padded" to accommodate the other), but these
│ │ │ │ +
1131 // may differ from those of the position:
│ │ │ │ +
1132 //
│ │ │ │ +
1133 if (hasTangents) {
│ │ │ │ +
1134 assert(tan1Mask.GetNumFaceWeights() == tan2Mask.GetNumFaceWeights());
│ │ │ │ +
1135 assert(tan1Mask.GetNumEdgeWeights() == tan2Mask.GetNumEdgeWeights());
│ │ │ │ +
1136
│ │ │ │ +
1137 U1 & dstTan1 = *dstTan1Ptr;
│ │ │ │ +
1138 U2 & dstTan2 = *dstTan2Ptr;
│ │ │ │ +
1139
│ │ │ │ +
1140 dstTan1[vert].Clear();
│ │ │ │ +
1141 dstTan2[vert].Clear();
│ │ │ │ +
1142 for (int i = 0; i < tan1Mask.GetNumFaceWeights(); ++i) {
│ │ │ │ +
1143 dstTan1[vert].AddWithWeight(src[fIndices[i]], fTan1Weights[i]);
│ │ │ │ +
1144 dstTan2[vert].AddWithWeight(src[fIndices[i]], fTan2Weights[i]);
│ │ │ │ +
1145 }
│ │ │ │ +
1146 for (int i = 0; i < tan1Mask.GetNumEdgeWeights(); ++i) {
│ │ │ │ +
1147 dstTan1[vert].AddWithWeight(src[eIndices[i]], eTan1Weights[i]);
│ │ │ │ +
1148 dstTan2[vert].AddWithWeight(src[eIndices[i]], eTan2Weights[i]);
│ │ │ │ +
1149 }
│ │ │ │ +
1150 dstTan1[vert].AddWithWeight(src[vert], vTan1Weights[0]);
│ │ │ │ +
1151 dstTan2[vert].AddWithWeight(src[vert], vTan2Weights[0]);
│ │ │ │ +
1152 }
│ │ │ │ +
1153 }
│ │ │ │ +
1154}
│ │ │ │ +
1155
│ │ │ │ +
1156template <typename REAL>
│ │ │ │ +
1157template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ +
1158inline void
│ │ │ │ +
1159PrimvarRefinerReal<REAL>::limitFVar(T const & src, U & dst, int channel) const {
│ │ │ │ +
1160
│ │ │ │ +
1161 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ +
1162
│ │ │ │ +
1163 Vtr::internal::Level const & level = _refiner.getLevel(_refiner.GetMaxLevel());
│ │ │ │ +
1164 Vtr::internal::FVarLevel const & fvarChannel = level.getFVarLevel(channel);
│ │ │ │ +
1165
│ │ │ │ +
1166 int maxWeightsPerMask = 1 + 2 * level.getMaxValence();
│ │ │ │ +
1167
│ │ │ │ +
1168 Vtr::internal::StackBuffer<Weight,33> weightBuffer(maxWeightsPerMask);
│ │ │ │ +
1169 Vtr::internal::StackBuffer<Index,16> vEdgeBuffer(level.getMaxValence());
│ │ │ │ +
1170
│ │ │ │ +
1171 // This is a bit obscure -- assign both parent and child as last level
│ │ │ │ +
1172 Vtr::internal::VertexInterface vHood(level, level);
│ │ │ │ +
1173
│ │ │ │ +
1174 for (int vert = 0; vert < level.getNumVertices(); ++vert) {
│ │ │ │ +
1175
│ │ │ │ +
1176 ConstIndexArray vEdges = level.getVertexEdges(vert);
│ │ │ │ +
1177 ConstIndexArray vValues = fvarChannel.getVertexValues(vert);
│ │ │ │ +
1178
│ │ │ │ +
1179 // Incomplete vertices (present in sparse refinement) do not have their full
│ │ │ │ +
1180 // topological neighborhood to determine a proper limit -- just leave the
│ │ │ │ +
1181 // values (perhaps more than one per vertex) at the refined location.
│ │ │ │ +
1182 //
│ │ │ │ +
1183 // The same can be done if the face-varying channel is purely linear.
│ │ │ │ +
1184 //
│ │ │ │ +
1185 bool isIncomplete = (level.getVertexTag(vert)._incomplete || (vEdges.size() == 0));
│ │ │ │ +
1186 if (isIncomplete || fvarChannel.isLinear()) {
│ │ │ │ +
1187 for (int i = 0; i < vValues.size(); ++i) {
│ │ │ │ +
1188 Vtr::Index vValue = vValues[i];
│ │ │ │ +
1189
│ │ │ │ +
1190 dst[vValue].Clear();
│ │ │ │ +
1191 dst[vValue].AddWithWeight(src[vValue], 1.0f);
│ │ │ │ +
1192 }
│ │ │ │ +
1193 continue;
│ │ │ │ +
1194 }
│ │ │ │ +
1195
│ │ │ │ +
1196 bool fvarVertMatchesVertex = fvarChannel.valueTopologyMatches(vValues[0]);
│ │ │ │ +
1197 if (fvarVertMatchesVertex) {
│ │ │ │ +
1198
│ │ │ │ +
1199 // Assign the mask weights to the common buffer and compute the mask:
│ │ │ │ +
1200 //
│ │ │ │ +
1201 Weight * vWeights = weightBuffer,
│ │ │ │ +
1202 * eWeights = vWeights + 1,
│ │ │ │ +
1203 * fWeights = eWeights + vEdges.size();
│ │ │ │ +
1204
│ │ │ │ +
1205 Mask vMask(vWeights, eWeights, fWeights);
│ │ │ │ +
1206
│ │ │ │ +
1207 vHood.SetIndex(vert, vert);
│ │ │ │ +
1208
│ │ │ │ +
1209 scheme.ComputeVertexLimitMask(vHood, vMask, level.getVertexRule(vert));
│ │ │ │ +
1210
│ │ │ │ +
1211 //
│ │ │ │ +
1212 // Apply mask to corresponding FVar values for neighboring vertices:
│ │ │ │ +
1213 //
│ │ │ │ +
1214 Vtr::Index vValue = vValues[0];
│ │ │ │ +
1215
│ │ │ │ +
1216 dst[vValue].Clear();
│ │ │ │ +
1217 if (vMask.GetNumFaceWeights() > 0) {
│ │ │ │ +
1218 assert(!vMask.AreFaceWeightsForFaceCenters());
│ │ │ │ +
1219
│ │ │ │ +
1220 ConstIndexArray vFaces = level.getVertexFaces(vert);
│ │ │ │ +
1221 ConstLocalIndexArray vInFace = level.getVertexFaceLocalIndices(vert);
│ │ │ │ +
1222
│ │ │ │ +
1223 for (int i = 0; i < vFaces.size(); ++i) {
│ │ │ │ +
1224 ConstIndexArray faceValues = fvarChannel.getFaceValues(vFaces[i]);
│ │ │ │ +
1225 LocalIndex vOppInFace = vInFace[i] + 2;
│ │ │ │ +
1226 if (vOppInFace >= faceValues.size()) vOppInFace -= faceValues.size();
│ │ │ │ +
1227
│ │ │ │ +
1228 Index vValueOppositeFace = faceValues[vOppInFace];
│ │ │ │ +
1229
│ │ │ │ +
1230 dst[vValue].AddWithWeight(src[vValueOppositeFace], fWeights[i]);
│ │ │ │ +
1231 }
│ │ │ │ +
1232 }
│ │ │ │ +
1233 if (vMask.GetNumEdgeWeights() > 0) {
│ │ │ │ +
1234 Index * vEdgeValues = vEdgeBuffer;
│ │ │ │ +
1235 fvarChannel.getVertexEdgeValues(vert, vEdgeValues);
│ │ │ │ +
1236
│ │ │ │ +
1237 for (int i = 0; i < vEdges.size(); ++i) {
│ │ │ │ +
1238 dst[vValue].AddWithWeight(src[vEdgeValues[i]], eWeights[i]);
│ │ │ │ +
1239 }
│ │ │ │ +
1240 }
│ │ │ │ +
1241 dst[vValue].AddWithWeight(src[vValue], vWeights[0]);
│ │ │ │ +
1242 } else {
│ │ │ │ +
1243 //
│ │ │ │ +
1244 // Sibling FVar values associated with a vertex will be either a corner or a crease:
│ │ │ │ +
1245 //
│ │ │ │ +
1246 for (int i = 0; i < vValues.size(); ++i) {
│ │ │ │ +
1247 Vtr::Index vValue = vValues[i];
│ │ │ │ +
1248
│ │ │ │ +
1249 dst[vValue].Clear();
│ │ │ │ +
1250 if (fvarChannel.getValueTag(vValue).isCorner()) {
│ │ │ │ +
1251 dst[vValue].AddWithWeight(src[vValue], 1.0f);
│ │ │ │ +
1252 } else {
│ │ │ │ +
1253 Index vEndValues[2];
│ │ │ │ +
1254 fvarChannel.getVertexCreaseEndValues(vert, i, vEndValues);
│ │ │ │ +
1255
│ │ │ │ +
1256 dst[vValue].AddWithWeight(src[vEndValues[0]], 1.0f/6.0f);
│ │ │ │ +
1257 dst[vValue].AddWithWeight(src[vEndValues[1]], 1.0f/6.0f);
│ │ │ │ +
1258 dst[vValue].AddWithWeight(src[vValue], 2.0f/3.0f);
│ │ │ │ +
1259 }
│ │ │ │ +
1260 }
│ │ │ │ +
1261 }
│ │ │ │ +
1262 }
│ │ │ │ +
1263}
│ │ │ │ +
1264
│ │ │ │ +
│ │ │ │ +
1265class PrimvarRefiner : public PrimvarRefinerReal<float> {
│ │ │ │ +
1266public:
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1268 : PrimvarRefinerReal<float>(refiner) { }
│ │ │ │ +
│ │ │ │ +
1269};
│ │ │ │ +
│ │ │ │ +
1270
│ │ │ │ +
1271} // end namespace Far
│ │ │ │ +
1272
│ │ │ │ +
1273} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
1274using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
1275} // end namespace OpenSubdiv
│ │ │ │ +
1276
│ │ │ │ +
1277#endif /* OPENSUBDIV3_FAR_PRIMVAR_REFINER_H */
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ +
void Error(ErrorType err, const char *format,...)
Sends an OSD error with a message (internal use only)
│ │ │ │ +
Vtr::ConstIndexArray ConstIndexArray
Definition types.h:47
│ │ │ │ +
Vtr::ConstLocalIndexArray ConstLocalIndexArray
Definition types.h:48
│ │ │ │ +
@ FAR_RUNTIME_ERROR
Issue a generic runtime error, but continue execution.
Definition error.h:40
│ │ │ │ + │ │ │ │ + │ │ │ │ +
bool IndexIsValid(Index index)
Definition types.h:58
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
Applies refinement operations to generic primvar data.
│ │ │ │ +
void Limit(T const &src, U &dstPos) const
Apply limit weights to a primvar buffer.
│ │ │ │ + │ │ │ │ +
void Limit(T const &src, U &dstPos, U1 &dstTan1, U2 &dstTan2) const
│ │ │ │ +
void InterpolateFaceUniform(int level, T const &src, U &dst) const
Refine uniform (per-face) primvar data between levels.
│ │ │ │ + │ │ │ │ +
void InterpolateVarying(int level, T const &src, U &dst) const
Apply only varying interpolation weights to a primvar buffer for a single level of refinement.
│ │ │ │ +
void Interpolate(int level, T const &src, U &dst) const
Apply vertex interpolation weights to a primvar buffer for a single level of refinement.
│ │ │ │ +
void InterpolateFaceVarying(int level, T const &src, U &dst, int channel=0) const
Apply face-varying interpolation weights to a primvar buffer associated with a particular face-varyin...
│ │ │ │ + │ │ │ │ +
void LimitFaceVarying(T const &src, U &dst, int channel=0) const
│ │ │ │ + │ │ │ │ + │ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
Scheme is a class template which provides all implementation for the subdivision schemes supported by...
Definition scheme.h:66
│ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -stencilTableFactory.h │ │ │ │ │ +primvarRefiner.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2013 Pixar │ │ │ │ │ +2// Copyright 2015 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -23,498 +23,1388 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H │ │ │ │ │ -26#define OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H │ │ │ │ │ -27 │ │ │ │ │ -28#include "../version.h" │ │ │ │ │ -29 │ │ │ │ │ -30#include "../far/patchTable.h" │ │ │ │ │ -31 │ │ │ │ │ -32#include │ │ │ │ │ -33 │ │ │ │ │ -34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -35namespace OPENSUBDIV_VERSION { │ │ │ │ │ -36 │ │ │ │ │ -37namespace Far { │ │ │ │ │ -38 │ │ │ │ │ -39class TopologyRefiner; │ │ │ │ │ -40 │ │ │ │ │ -41template class StencilReal; │ │ │ │ │ -42template class StencilTableReal; │ │ │ │ │ -43 │ │ │ │ │ -44template class LimitStencilReal; │ │ │ │ │ -45template class LimitStencilTableReal; │ │ │ │ │ +24#ifndef OPENSUBDIV3_FAR_PRIMVAR_REFINER_H │ │ │ │ │ +25#define OPENSUBDIV3_FAR_PRIMVAR_REFINER_H │ │ │ │ │ +26 │ │ │ │ │ +27#include "../version.h" │ │ │ │ │ +28 │ │ │ │ │ +29#include "../sdc/types.h" │ │ │ │ │ +30#include "../sdc/options.h" │ │ │ │ │ +31#include "../sdc/bilinearScheme.h" │ │ │ │ │ +32#include "../sdc/catmarkScheme.h" │ │ │ │ │ +33#include "../sdc/loopScheme.h" │ │ │ │ │ +34#include "../vtr/level.h" │ │ │ │ │ +35#include "../vtr/fvarLevel.h" │ │ │ │ │ +36#include "../vtr/refinement.h" │ │ │ │ │ +37#include "../vtr/fvarRefinement.h" │ │ │ │ │ +38#include "../vtr/stackBuffer.h" │ │ │ │ │ +39#include "../vtr/componentInterfaces.h" │ │ │ │ │ +40#include "../far/types.h" │ │ │ │ │ +41#include "../far/error.h" │ │ │ │ │ +42#include "../far/topologyLevel.h" │ │ │ │ │ +43#include "../far/topologyRefiner.h" │ │ │ │ │ +44 │ │ │ │ │ +45#include │ │ │ │ │ 46 │ │ │ │ │ -47 │ │ │ │ │ -50template │ │ │ │ │ -_5_1class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l { │ │ │ │ │ -52 │ │ │ │ │ -53public: │ │ │ │ │ -54 │ │ │ │ │ -_5_5 enum _M_o_d_e { │ │ │ │ │ -_5_6 _I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X=0, │ │ │ │ │ -_5_7 _I_N_T_E_R_P_O_L_A_T_E___V_A_R_Y_I_N_G, │ │ │ │ │ -58 _I_N_T_E_R_P_O_L_A_T_E___F_A_C_E___V_A_R_Y_I_N_G │ │ │ │ │ -_5_9 }; │ │ │ │ │ -60 │ │ │ │ │ -_6_1 struct _O_p_t_i_o_n_s { │ │ │ │ │ -62 │ │ │ │ │ -_6_3 _O_p_t_i_o_n_s() : _i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e(_I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X), │ │ │ │ │ -64 _g_e_n_e_r_a_t_e_O_f_f_s_e_t_s(false), │ │ │ │ │ -65 _g_e_n_e_r_a_t_e_C_o_n_t_r_o_l_V_e_r_t_s(false), │ │ │ │ │ -66 _g_e_n_e_r_a_t_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s(true), │ │ │ │ │ -67 _f_a_c_t_o_r_i_z_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s(true), │ │ │ │ │ -68 _m_a_x_L_e_v_e_l(10), │ │ │ │ │ -69 _f_v_a_r_C_h_a_n_n_e_l(0) { } │ │ │ │ │ -70 │ │ │ │ │ -_7_1 unsigned int _i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e : 2, │ │ │ │ │ -_7_2 _g_e_n_e_r_a_t_e_O_f_f_s_e_t_s : 1, │ │ │ │ │ -_7_3 _g_e_n_e_r_a_t_e_C_o_n_t_r_o_l_V_e_r_t_s : 1, │ │ │ │ │ -_7_4 _g_e_n_e_r_a_t_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s : 1, │ │ │ │ │ -_7_5 _f_a_c_t_o_r_i_z_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s : 1, │ │ │ │ │ -_7_8 _m_a_x_L_e_v_e_l : 4; │ │ │ │ │ -_7_9 unsigned int _f_v_a_r_C_h_a_n_n_e_l; │ │ │ │ │ -81 }; │ │ │ │ │ -82 │ │ │ │ │ -_9_4 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _C_r_e_a_t_e( │ │ │ │ │ -95 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, _O_p_t_i_o_n_s options = _O_p_t_i_o_n_s()); │ │ │ │ │ -96 │ │ │ │ │ -97 │ │ │ │ │ -_1_1_0 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _C_r_e_a_t_e( │ │ │ │ │ -111 int numTables, _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const ** tables); │ │ │ │ │ -112 │ │ │ │ │ -113 │ │ │ │ │ -_1_2_8 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e( │ │ │ │ │ -129 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ -130 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *baseStencilTable, │ │ │ │ │ -131 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *localPointStencilTable, │ │ │ │ │ -132 bool factorize = true); │ │ │ │ │ -133 │ │ │ │ │ -_1_4_8 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g( │ │ │ │ │ -149 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ -150 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *baseStencilTable, │ │ │ │ │ -151 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *localPointStencilTable, │ │ │ │ │ -152 bool factorize = true) { │ │ │ │ │ -153 return _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e( │ │ │ │ │ -154 refiner, baseStencilTable, localPointStencilTable, factorize); │ │ │ │ │ -155 } │ │ │ │ │ -156 │ │ │ │ │ -_1_7_4 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * │ │ │ │ │ -_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -175 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ -176 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *baseStencilTable, │ │ │ │ │ -177 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const *localPointStencilTable, │ │ │ │ │ -178 int channel = 0, │ │ │ │ │ -179 bool factorize = true); │ │ │ │ │ -180 │ │ │ │ │ -181private: │ │ │ │ │ -182 │ │ │ │ │ -183 // Generate stencils for the coarse control-vertices (single weight = 1.0f) │ │ │ │ │ -184 static void generateControlVertStencils( │ │ │ │ │ -185 int numControlVerts, │ │ │ │ │ -186 _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> & dst); │ │ │ │ │ -187 │ │ │ │ │ -188 // Internal method to splice local point stencils │ │ │ │ │ -189 static _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * appendLocalPointStencilTable( │ │ │ │ │ -190 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ -191 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * baseStencilTable, │ │ │ │ │ -192 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * localPointStencilTable, │ │ │ │ │ -193 int channel, │ │ │ │ │ -194 bool factorize); │ │ │ │ │ -195}; │ │ │ │ │ -196 │ │ │ │ │ -208template │ │ │ │ │ -_2_0_9class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l { │ │ │ │ │ -210 │ │ │ │ │ -211public: │ │ │ │ │ -212 │ │ │ │ │ -_2_1_3 enum _M_o_d_e { │ │ │ │ │ -_2_1_4 _I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X=0, │ │ │ │ │ -_2_1_5 _I_N_T_E_R_P_O_L_A_T_E___V_A_R_Y_I_N_G, │ │ │ │ │ -216 _I_N_T_E_R_P_O_L_A_T_E___F_A_C_E___V_A_R_Y_I_N_G │ │ │ │ │ -_2_1_7 }; │ │ │ │ │ -218 │ │ │ │ │ -_2_1_9 struct _O_p_t_i_o_n_s { │ │ │ │ │ -220 │ │ │ │ │ -_2_2_1 _O_p_t_i_o_n_s() : _i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e(_I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X), │ │ │ │ │ -222 _g_e_n_e_r_a_t_e_1_s_t_D_e_r_i_v_a_t_i_v_e_s(true), │ │ │ │ │ -223 _g_e_n_e_r_a_t_e_2_n_d_D_e_r_i_v_a_t_i_v_e_s(false), │ │ │ │ │ -224 _f_v_a_r_C_h_a_n_n_e_l(0) { } │ │ │ │ │ -225 │ │ │ │ │ -_2_2_6 unsigned int _i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e : 2, │ │ │ │ │ -_2_2_7 _g_e_n_e_r_a_t_e_1_s_t_D_e_r_i_v_a_t_i_v_e_s : 1, │ │ │ │ │ -_2_2_8 _g_e_n_e_r_a_t_e_2_n_d_D_e_r_i_v_a_t_i_v_e_s : 1; │ │ │ │ │ -_2_2_9 unsigned int _f_v_a_r_C_h_a_n_n_e_l; │ │ │ │ │ -230 }; │ │ │ │ │ -231 │ │ │ │ │ -_2_3_3 struct _L_o_c_a_t_i_o_n_A_r_r_a_y { │ │ │ │ │ -234 │ │ │ │ │ -_2_3_5 _L_o_c_a_t_i_o_n_A_r_r_a_y() : _p_t_e_x_I_d_x(-1), _n_u_m_L_o_c_a_t_i_o_n_s(0), _s(0), _t(0) { } │ │ │ │ │ -236 │ │ │ │ │ -_2_3_7 int _p_t_e_x_I_d_x, │ │ │ │ │ -_2_3_8 _n_u_m_L_o_c_a_t_i_o_n_s; │ │ │ │ │ -239 │ │ │ │ │ -_2_4_0 REAL const * _s, │ │ │ │ │ -_2_4_1 * _t; │ │ │ │ │ -242 }; │ │ │ │ │ -243 │ │ │ │ │ -_2_4_4 typedef std::vector _L_o_c_a_t_i_o_n_A_r_r_a_y_V_e_c; │ │ │ │ │ -245 │ │ │ │ │ -_2_6_9 static _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * _C_r_e_a_t_e( │ │ │ │ │ -270 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, │ │ │ │ │ -271 _L_o_c_a_t_i_o_n_A_r_r_a_y_V_e_c const & locationArrays, │ │ │ │ │ -272 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_> const * cvStencils = 0, │ │ │ │ │ -273 _P_a_t_c_h_T_a_b_l_e const * patchTable = 0, │ │ │ │ │ -274 _O_p_t_i_o_n_s options = _O_p_t_i_o_n_s()); │ │ │ │ │ -275 │ │ │ │ │ -276}; │ │ │ │ │ -277 │ │ │ │ │ -278 │ │ │ │ │ -279// │ │ │ │ │ -280// Public wrapper classes for the templates │ │ │ │ │ -281// │ │ │ │ │ -282class _S_t_e_n_c_i_l; │ │ │ │ │ -283class _S_t_e_n_c_i_l_T_a_b_l_e; │ │ │ │ │ -284 │ │ │ │ │ -_2_8_7class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y : public _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l { │ │ │ │ │ -288private: │ │ │ │ │ -289 typedef _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_F_a_c_t_o_r_y; │ │ │ │ │ -290 typedef _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_T_a_b_l_e; │ │ │ │ │ -291 │ │ │ │ │ -292public: │ │ │ │ │ -_2_9_3 static _S_t_e_n_c_i_l_T_a_b_l_e const * _C_r_e_a_t_e( │ │ │ │ │ -294 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, Options options = Options()) { │ │ │ │ │ -295 │ │ │ │ │ -296 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ -297 _B_a_s_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e(refiner, options)); │ │ │ │ │ -298 } │ │ │ │ │ -299 │ │ │ │ │ -_3_0_0 static _S_t_e_n_c_i_l_T_a_b_l_e const * _C_r_e_a_t_e( │ │ │ │ │ -301 int numTables, _S_t_e_n_c_i_l_T_a_b_l_e const ** tables) { │ │ │ │ │ -302 │ │ │ │ │ -303 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ -304 _B_a_s_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e(numTables, │ │ │ │ │ -305 reinterpret_cast<_B_a_s_e_T_a_b_l_e const **>(tables))); │ │ │ │ │ -306 } │ │ │ │ │ -307 │ │ │ │ │ -_3_0_8 static _S_t_e_n_c_i_l_T_a_b_l_e const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e( │ │ │ │ │ -309 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ -310 _S_t_e_n_c_i_l_T_a_b_l_e const *baseStencilTable, │ │ │ │ │ -311 _S_t_e_n_c_i_l_T_a_b_l_e const *localPointStencilTable, │ │ │ │ │ -312 bool factorize = true) { │ │ │ │ │ -313 │ │ │ │ │ -314 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ -315 _B_a_s_e_F_a_c_t_o_r_y_:_:_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e(refiner, │ │ │ │ │ -316 static_cast<_B_a_s_e_T_a_b_l_e const *>(baseStencilTable), │ │ │ │ │ -317 static_cast<_B_a_s_e_T_a_b_l_e const *>(localPointStencilTable), │ │ │ │ │ -318 factorize)); │ │ │ │ │ -319 } │ │ │ │ │ +47namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +48namespace OPENSUBDIV_VERSION { │ │ │ │ │ +49 │ │ │ │ │ +50namespace Far { │ │ │ │ │ +51 │ │ │ │ │ +55template │ │ │ │ │ +_5_6class _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l { │ │ │ │ │ +57 │ │ │ │ │ +58public: │ │ │ │ │ +_5_9 _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l(_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner) : _refiner(refiner) { } │ │ │ │ │ +_6_0 _~_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l() { } │ │ │ │ │ +61 │ │ │ │ │ +_6_2 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & _G_e_t_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r() const { return _refiner; } │ │ │ │ │ +63 │ │ │ │ │ +65 │ │ │ │ │ +100 │ │ │ │ │ +_1_1_3 template void _I_n_t_e_r_p_o_l_a_t_e(int level, T const & src, U & │ │ │ │ │ +dst) const; │ │ │ │ │ +114 │ │ │ │ │ +_1_3_0 template void _I_n_t_e_r_p_o_l_a_t_e_V_a_r_y_i_n_g(int level, T const & │ │ │ │ │ +src, U & dst) const; │ │ │ │ │ +131 │ │ │ │ │ +_1_4_8 template void _I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_U_n_i_f_o_r_m(int level, T const │ │ │ │ │ +& src, U & dst) const; │ │ │ │ │ +149 │ │ │ │ │ +_1_6_1 template void _I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_V_a_r_y_i_n_g(int level, T const │ │ │ │ │ +& src, U & dst, int channel = 0) const; │ │ │ │ │ +162 │ │ │ │ │ +163 │ │ │ │ │ +_1_7_5 template void _L_i_m_i_t(T const & src, U & dstPos) const; │ │ │ │ │ +176 │ │ │ │ │ +177 template │ │ │ │ │ +_1_7_8 void _L_i_m_i_t(T const & src, U & dstPos, U1 & dstTan1, U2 & dstTan2) const; │ │ │ │ │ +179 │ │ │ │ │ +_1_8_0 template void _L_i_m_i_t_F_a_c_e_V_a_r_y_i_n_g(T const & src, U & dst, │ │ │ │ │ +int channel = 0) const; │ │ │ │ │ +181 │ │ │ │ │ +183 │ │ │ │ │ +184private: │ │ │ │ │ +185 typedef REAL Weight; │ │ │ │ │ +186 │ │ │ │ │ +187 // Non-copyable: │ │ │ │ │ +188 _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l(_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l const & src) : _refiner(src._refiner) │ │ │ │ │ +{ } │ │ │ │ │ +189 _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l & operator=(_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l const &) { return *this; │ │ │ │ │ +} │ │ │ │ │ +190 │ │ │ │ │ +191 template void interpFromFaces │ │ │ │ │ +(int, T const &, U &) const; │ │ │ │ │ +192 template void interpFromEdges │ │ │ │ │ +(int, T const &, U &) const; │ │ │ │ │ +193 template void interpFromVerts │ │ │ │ │ +(int, T const &, U &) const; │ │ │ │ │ +194 │ │ │ │ │ +195 template void │ │ │ │ │ +interpFVarFromFaces(int, T const &, U &, int) const; │ │ │ │ │ +196 template void │ │ │ │ │ +interpFVarFromEdges(int, T const &, U &, int) const; │ │ │ │ │ +197 template void │ │ │ │ │ +interpFVarFromVerts(int, T const &, U &, int) const; │ │ │ │ │ +198 │ │ │ │ │ +199 template │ │ │ │ │ +200 void limit(T const & src, U & pos, U1 * tan1, U2 * tan2) const; │ │ │ │ │ +201 │ │ │ │ │ +202 template │ │ │ │ │ +203 void limitFVar(T const & src, U & dst, int channel) const; │ │ │ │ │ +204 │ │ │ │ │ +205private: │ │ │ │ │ +206 TopologyRefiner const & _refiner; │ │ │ │ │ +207 │ │ │ │ │ +208private: │ │ │ │ │ +209 // │ │ │ │ │ +210 // Local class to fulfill interface for in the Scheme mask │ │ │ │ │ +queries: │ │ │ │ │ +211 // │ │ │ │ │ +212 class Mask { │ │ │ │ │ +213 public: │ │ │ │ │ +214 typedef REAL Weight; // Also part of the expected interface │ │ │ │ │ +215 │ │ │ │ │ +216 public: │ │ │ │ │ +217 Mask(Weight* v, Weight* e, Weight* f) : │ │ │ │ │ +218 _vertWeights(v), _edgeWeights(e), _faceWeights(f), │ │ │ │ │ +219 _vertCount(0), _edgeCount(0), _faceCount(0), │ │ │ │ │ +220 _faceWeightsForFaceCenters(false) │ │ │ │ │ +221 { } │ │ │ │ │ +222 │ │ │ │ │ +223 ~Mask() { } │ │ │ │ │ +224 │ │ │ │ │ +225 public: // Generic interface expected of : │ │ │ │ │ +226 int GetNumVertexWeights() const { return _vertCount; } │ │ │ │ │ +227 int GetNumEdgeWeights() const { return _edgeCount; } │ │ │ │ │ +228 int GetNumFaceWeights() const { return _faceCount; } │ │ │ │ │ +229 │ │ │ │ │ +230 void SetNumVertexWeights(int count) { _vertCount = count; } │ │ │ │ │ +231 void SetNumEdgeWeights( int count) { _edgeCount = count; } │ │ │ │ │ +232 void SetNumFaceWeights( int count) { _faceCount = count; } │ │ │ │ │ +233 │ │ │ │ │ +234 Weight const& VertexWeight(int index) const { return _vertWeights[index]; } │ │ │ │ │ +235 Weight const& EdgeWeight( int index) const { return _edgeWeights[index]; } │ │ │ │ │ +236 Weight const& FaceWeight( int index) const { return _faceWeights[index]; } │ │ │ │ │ +237 │ │ │ │ │ +238 Weight& VertexWeight(int index) { return _vertWeights[index]; } │ │ │ │ │ +239 Weight& EdgeWeight( int index) { return _edgeWeights[index]; } │ │ │ │ │ +240 Weight& FaceWeight( int index) { return _faceWeights[index]; } │ │ │ │ │ +241 │ │ │ │ │ +242 bool AreFaceWeightsForFaceCenters() const { return │ │ │ │ │ +_faceWeightsForFaceCenters; } │ │ │ │ │ +243 void SetFaceWeightsForFaceCenters(bool on) { _faceWeightsForFaceCenters = │ │ │ │ │ +on; } │ │ │ │ │ +244 │ │ │ │ │ +245 private: │ │ │ │ │ +246 Weight* _vertWeights; │ │ │ │ │ +247 Weight* _edgeWeights; │ │ │ │ │ +248 Weight* _faceWeights; │ │ │ │ │ +249 │ │ │ │ │ +250 int _vertCount; │ │ │ │ │ +251 int _edgeCount; │ │ │ │ │ +252 int _faceCount; │ │ │ │ │ +253 │ │ │ │ │ +254 bool _faceWeightsForFaceCenters; │ │ │ │ │ +255 }; │ │ │ │ │ +256}; │ │ │ │ │ +257 │ │ │ │ │ +258 │ │ │ │ │ +259// │ │ │ │ │ +260// Public entry points to the methods. Queries of the scheme type and its │ │ │ │ │ +261// use as a template parameter in subsequent implementation will be factored │ │ │ │ │ +262// out of a later release: │ │ │ │ │ +263// │ │ │ │ │ +264template │ │ │ │ │ +265template │ │ │ │ │ +266inline void │ │ │ │ │ +_2_6_7_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_I_n_t_e_r_p_o_l_a_t_e(int level, T const & src, U & dst) │ │ │ │ │ +const { │ │ │ │ │ +268 │ │ │ │ │ +269 assert(level>0 && level<=(int)_refiner._refinements.size()); │ │ │ │ │ +270 │ │ │ │ │ +271 switch (_refiner._subdivType) { │ │ │ │ │ +272 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ +273 interpFromFaces(level, src, dst); │ │ │ │ │ +274 interpFromEdges(level, src, dst); │ │ │ │ │ +275 interpFromVerts(level, src, dst); │ │ │ │ │ +276 break; │ │ │ │ │ +277 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ +278 interpFromFaces(level, src, dst); │ │ │ │ │ +279 interpFromEdges(level, src, dst); │ │ │ │ │ +280 interpFromVerts(level, src, dst); │ │ │ │ │ +281 break; │ │ │ │ │ +282 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ +283 interpFromFaces(level, src, dst); │ │ │ │ │ +284 interpFromEdges(level, src, dst); │ │ │ │ │ +285 interpFromVerts(level, src, dst); │ │ │ │ │ +286 break; │ │ │ │ │ +287 } │ │ │ │ │ +288} │ │ │ │ │ +289 │ │ │ │ │ +290template │ │ │ │ │ +291template │ │ │ │ │ +292inline void │ │ │ │ │ +_2_9_3_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_V_a_r_y_i_n_g(int level, T const & src, U │ │ │ │ │ +& dst, int channel) const { │ │ │ │ │ +294 │ │ │ │ │ +295 assert(level>0 && level<=(int)_refiner._refinements.size()); │ │ │ │ │ +296 │ │ │ │ │ +297 switch (_refiner._subdivType) { │ │ │ │ │ +298 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ +299 interpFVarFromFaces(level, src, dst, channel); │ │ │ │ │ +300 interpFVarFromEdges(level, src, dst, channel); │ │ │ │ │ +301 interpFVarFromVerts(level, src, dst, channel); │ │ │ │ │ +302 break; │ │ │ │ │ +303 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ +304 interpFVarFromFaces(level, src, dst, channel); │ │ │ │ │ +305 interpFVarFromEdges(level, src, dst, channel); │ │ │ │ │ +306 interpFVarFromVerts(level, src, dst, channel); │ │ │ │ │ +307 break; │ │ │ │ │ +308 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ +309 interpFVarFromFaces(level, src, dst, channel); │ │ │ │ │ +310 interpFVarFromEdges(level, src, dst, channel); │ │ │ │ │ +311 interpFVarFromVerts(level, src, dst, channel); │ │ │ │ │ +312 break; │ │ │ │ │ +313 } │ │ │ │ │ +314} │ │ │ │ │ +315 │ │ │ │ │ +316template │ │ │ │ │ +317template │ │ │ │ │ +318inline void │ │ │ │ │ +_3_1_9_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_L_i_m_i_t(T const & src, U & dst) const { │ │ │ │ │ 320 │ │ │ │ │ -_3_2_1 static _S_t_e_n_c_i_l_T_a_b_l_e const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g( │ │ │ │ │ -322 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ -323 _S_t_e_n_c_i_l_T_a_b_l_e const *baseStencilTable, │ │ │ │ │ -324 _S_t_e_n_c_i_l_T_a_b_l_e const *localPointStencilTable, │ │ │ │ │ -325 bool factorize = true) { │ │ │ │ │ -326 │ │ │ │ │ -327 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ -328 _B_a_s_e_F_a_c_t_o_r_y_:_:_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g(refiner, │ │ │ │ │ -329 static_cast<_B_a_s_e_T_a_b_l_e const *>(baseStencilTable), │ │ │ │ │ -330 static_cast<_B_a_s_e_T_a_b_l_e const *>(localPointStencilTable), │ │ │ │ │ -331 factorize)); │ │ │ │ │ -332 } │ │ │ │ │ -333 │ │ │ │ │ -_3_3_4 static _S_t_e_n_c_i_l_T_a_b_l_e const * _A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -335 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const &refiner, │ │ │ │ │ -336 _S_t_e_n_c_i_l_T_a_b_l_e const *baseStencilTable, │ │ │ │ │ -337 _S_t_e_n_c_i_l_T_a_b_l_e const *localPointStencilTable, │ │ │ │ │ -338 int channel = 0, │ │ │ │ │ -339 bool factorize = true) { │ │ │ │ │ +321 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == │ │ │ │ │ +0) { │ │ │ │ │ +322 _E_r_r_o_r(_F_A_R___R_U_N_T_I_M_E___E_R_R_O_R, │ │ │ │ │ +323 "Failure in PrimvarRefiner::Limit() -- " │ │ │ │ │ +324 "last level of refinement does not include full topology."); │ │ │ │ │ +325 return; │ │ │ │ │ +326 } │ │ │ │ │ +327 │ │ │ │ │ +328 switch (_refiner._subdivType) { │ │ │ │ │ +329 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ +330 limit(src, dst, (U*)0, (U*)0); │ │ │ │ │ +331 break; │ │ │ │ │ +332 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ +333 limit(src, dst, (U*)0, (U*)0); │ │ │ │ │ +334 break; │ │ │ │ │ +335 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ +336 limit(src, dst, (U*)0, (U*)0); │ │ │ │ │ +337 break; │ │ │ │ │ +338 } │ │ │ │ │ +339} │ │ │ │ │ 340 │ │ │ │ │ -341 return static_cast<_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ -342 _B_a_s_e_F_a_c_t_o_r_y_:_:_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g(refiner, │ │ │ │ │ -343 static_cast<_B_a_s_e_T_a_b_l_e const *>(baseStencilTable), │ │ │ │ │ -344 static_cast<_B_a_s_e_T_a_b_l_e const *>(localPointStencilTable), │ │ │ │ │ -345 channel, factorize)); │ │ │ │ │ -346 } │ │ │ │ │ -347}; │ │ │ │ │ -348 │ │ │ │ │ -349class LimitStencil; │ │ │ │ │ -350class LimitStencilTable; │ │ │ │ │ -351 │ │ │ │ │ -_3_5_4class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y : public _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l │ │ │ │ │ -{ │ │ │ │ │ -355private: │ │ │ │ │ -356 typedef _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_F_a_c_t_o_r_y; │ │ │ │ │ -357 typedef _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_T_a_b_l_e; │ │ │ │ │ -358 │ │ │ │ │ -359public: │ │ │ │ │ -_3_6_0 static _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e const * _C_r_e_a_t_e( │ │ │ │ │ -361 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, │ │ │ │ │ -362 _L_o_c_a_t_i_o_n_A_r_r_a_y_V_e_c const & locationArrays, │ │ │ │ │ -363 _S_t_e_n_c_i_l_T_a_b_l_e const * cvStencils = 0, │ │ │ │ │ -364 _P_a_t_c_h_T_a_b_l_e const * patchTable = 0, │ │ │ │ │ -365 Options options = Options()) { │ │ │ │ │ -366 │ │ │ │ │ -367 return static_cast<_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e const *>( │ │ │ │ │ -368 _B_a_s_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e( │ │ │ │ │ -369 refiner, │ │ │ │ │ -370 locationArrays, │ │ │ │ │ -371 static_cast<_B_a_s_e_T_a_b_l_e const *>(cvStencils), │ │ │ │ │ -372 patchTable, │ │ │ │ │ -373 options)); │ │ │ │ │ -374 } │ │ │ │ │ -375}; │ │ │ │ │ -376 │ │ │ │ │ -377} // end namespace Far │ │ │ │ │ -378 │ │ │ │ │ -379} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -380using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -381 │ │ │ │ │ -382} // end namespace OpenSubdiv │ │ │ │ │ -383 │ │ │ │ │ -384#endif // OPENSUBDIV3_FAR_STENCILTABLE_FACTORY_H │ │ │ │ │ +341template │ │ │ │ │ +342template │ │ │ │ │ +343inline void │ │ │ │ │ +_3_4_4_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_L_i_m_i_t(T const & src, U & dstPos, U1 & dstTan1, U2 │ │ │ │ │ +& dstTan2) const { │ │ │ │ │ +345 │ │ │ │ │ +346 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == │ │ │ │ │ +0) { │ │ │ │ │ +347 _E_r_r_o_r(_F_A_R___R_U_N_T_I_M_E___E_R_R_O_R, │ │ │ │ │ +348 "Failure in PrimvarRefiner::Limit() -- " │ │ │ │ │ +349 "last level of refinement does not include full topology."); │ │ │ │ │ +350 return; │ │ │ │ │ +351 } │ │ │ │ │ +352 │ │ │ │ │ +353 switch (_refiner._subdivType) { │ │ │ │ │ +354 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ +355 limit(src, dstPos, &dstTan1, &dstTan2); │ │ │ │ │ +356 break; │ │ │ │ │ +357 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ +358 limit(src, dstPos, &dstTan1, &dstTan2); │ │ │ │ │ +359 break; │ │ │ │ │ +360 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ +361 limit(src, dstPos, &dstTan1, &dstTan2); │ │ │ │ │ +362 break; │ │ │ │ │ +363 } │ │ │ │ │ +364} │ │ │ │ │ +365 │ │ │ │ │ +366template │ │ │ │ │ +367template │ │ │ │ │ +368inline void │ │ │ │ │ +_3_6_9_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_L_i_m_i_t_F_a_c_e_V_a_r_y_i_n_g(T const & src, U & dst, int │ │ │ │ │ +channel) const { │ │ │ │ │ +370 │ │ │ │ │ +371 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == │ │ │ │ │ +0) { │ │ │ │ │ +372 _E_r_r_o_r(_F_A_R___R_U_N_T_I_M_E___E_R_R_O_R, │ │ │ │ │ +373 "Failure in PrimvarRefiner::LimitFaceVarying() -- " │ │ │ │ │ +374 "last level of refinement does not include full topology."); │ │ │ │ │ +375 return; │ │ │ │ │ +376 } │ │ │ │ │ +377 │ │ │ │ │ +378 switch (_refiner._subdivType) { │ │ │ │ │ +379 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ +380 limitFVar(src, dst, channel); │ │ │ │ │ +381 break; │ │ │ │ │ +382 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ +383 limitFVar(src, dst, channel); │ │ │ │ │ +384 break; │ │ │ │ │ +385 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ +386 limitFVar(src, dst, channel); │ │ │ │ │ +387 break; │ │ │ │ │ +388 } │ │ │ │ │ +389} │ │ │ │ │ +390 │ │ │ │ │ +391template │ │ │ │ │ +392template │ │ │ │ │ +393inline void │ │ │ │ │ +_3_9_4_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_U_n_i_f_o_r_m(int level, T const & src, U │ │ │ │ │ +& dst) const { │ │ │ │ │ +395 │ │ │ │ │ +396 assert(level>0 && level<=(int)_refiner._refinements.size()); │ │ │ │ │ +397 │ │ │ │ │ +398 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ +(level-1); │ │ │ │ │ +399 Vtr::internal::Level const & child = refinement.child(); │ │ │ │ │ +400 │ │ │ │ │ +401 for (int cFace = 0; cFace < child.getNumFaces(); ++cFace) { │ │ │ │ │ +402 │ │ │ │ │ +403 _V_t_r_:_:_I_n_d_e_x pFace = refinement.getChildFaceParentFace(cFace); │ │ │ │ │ +404 │ │ │ │ │ +405 dst[cFace] = src[pFace]; │ │ │ │ │ +406 } │ │ │ │ │ +407} │ │ │ │ │ +408 │ │ │ │ │ +409template │ │ │ │ │ +410template │ │ │ │ │ +411inline void │ │ │ │ │ +_4_1_2_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_I_n_t_e_r_p_o_l_a_t_e_V_a_r_y_i_n_g(int level, T const & src, U & │ │ │ │ │ +dst) const { │ │ │ │ │ +413 │ │ │ │ │ +414 assert(level>0 && level<=(int)_refiner._refinements.size()); │ │ │ │ │ +415 │ │ │ │ │ +416 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ +(level-1); │ │ │ │ │ +417 Vtr::internal::Level const & parent = refinement.parent(); │ │ │ │ │ +418 │ │ │ │ │ +419 // │ │ │ │ │ +420 // Group values to interpolate based on origin -- note that there may │ │ │ │ │ +421 // be none originating from faces: │ │ │ │ │ +422 // │ │ │ │ │ +423 if (refinement.getNumChildVerticesFromFaces() > 0) { │ │ │ │ │ +424 │ │ │ │ │ +425 for (int face = 0; face < parent.getNumFaces(); ++face) { │ │ │ │ │ +426 │ │ │ │ │ +427 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getFaceChildVertex(face); │ │ │ │ │ +428 if (_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) { │ │ │ │ │ +429 │ │ │ │ │ +430 // Apply the weights to the parent face's vertices: │ │ │ │ │ +431 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y fVerts = parent.getFaceVertices(face); │ │ │ │ │ +432 │ │ │ │ │ +433 Weight fVaryingWeight = 1.0f / (Weight) fVerts._s_i_z_e(); │ │ │ │ │ +434 │ │ │ │ │ +435 dst[cVert].Clear(); │ │ │ │ │ +436 for (int i = 0; i < fVerts._s_i_z_e(); ++i) { │ │ │ │ │ +437 dst[cVert].AddWithWeight(src[fVerts[i]], fVaryingWeight); │ │ │ │ │ +438 } │ │ │ │ │ +439 } │ │ │ │ │ +440 } │ │ │ │ │ +441 } │ │ │ │ │ +442 for (int edge = 0; edge < parent.getNumEdges(); ++edge) { │ │ │ │ │ +443 │ │ │ │ │ +444 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getEdgeChildVertex(edge); │ │ │ │ │ +445 if (_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) { │ │ │ │ │ +446 │ │ │ │ │ +447 // Apply the weights to the parent edges's vertices │ │ │ │ │ +448 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eVerts = parent.getEdgeVertices(edge); │ │ │ │ │ +449 │ │ │ │ │ +450 dst[cVert].Clear(); │ │ │ │ │ +451 dst[cVert].AddWithWeight(src[eVerts[0]], 0.5f); │ │ │ │ │ +452 dst[cVert].AddWithWeight(src[eVerts[1]], 0.5f); │ │ │ │ │ +453 } │ │ │ │ │ +454 } │ │ │ │ │ +455 for (int vert = 0; vert < parent.getNumVertices(); ++vert) { │ │ │ │ │ +456 │ │ │ │ │ +457 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getVertexChildVertex(vert); │ │ │ │ │ +458 if (_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) { │ │ │ │ │ +459 │ │ │ │ │ +460 // Essentially copy the parent vertex: │ │ │ │ │ +461 dst[cVert].Clear(); │ │ │ │ │ +462 dst[cVert].AddWithWeight(src[vert], 1.0f); │ │ │ │ │ +463 } │ │ │ │ │ +464 } │ │ │ │ │ +465} │ │ │ │ │ +466 │ │ │ │ │ +467 │ │ │ │ │ +468// │ │ │ │ │ +469// Internal implementation methods -- grouping vertices to be interpolated │ │ │ │ │ +470// based on the type of parent component from which they originated: │ │ │ │ │ +471// │ │ │ │ │ +472template │ │ │ │ │ +473template │ │ │ │ │ +474inline void │ │ │ │ │ +475_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_i_n_t_e_r_p_F_r_o_m_F_a_c_e_s(int level, T const & src, U & dst) │ │ │ │ │ +const { │ │ │ │ │ +476 │ │ │ │ │ +477 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ +(level-1); │ │ │ │ │ +478 Vtr::internal::Level const & parent = refinement.parent(); │ │ │ │ │ +479 │ │ │ │ │ +480 if (refinement.getNumChildVerticesFromFaces() == 0) return; │ │ │ │ │ +481 │ │ │ │ │ +482 _S_d_c_:_:_S_c_h_e_m_e_<_S_C_H_E_M_E_> scheme(_refiner._subdivOptions); │ │ │ │ │ +483 │ │ │ │ │ +484 Vtr::internal::StackBuffer fVertWeights(parent.getMaxValence()); │ │ │ │ │ +485 │ │ │ │ │ +486 for (int face = 0; face < parent.getNumFaces(); ++face) { │ │ │ │ │ +487 │ │ │ │ │ +488 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getFaceChildVertex(face); │ │ │ │ │ +489 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ +490 continue; │ │ │ │ │ +491 │ │ │ │ │ +492 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ +face: │ │ │ │ │ +493 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y fVerts = parent.getFaceVertices(face); │ │ │ │ │ +494 │ │ │ │ │ +495 Mask fMask(fVertWeights, 0, 0); │ │ │ │ │ +496 Vtr::internal::FaceInterface fHood(fVerts._s_i_z_e()); │ │ │ │ │ +497 │ │ │ │ │ +498 scheme.ComputeFaceVertexMask(fHood, fMask); │ │ │ │ │ +499 │ │ │ │ │ +500 // Apply the weights to the parent face's vertices: │ │ │ │ │ +501 dst[cVert].Clear(); │ │ │ │ │ +502 │ │ │ │ │ +503 for (int i = 0; i < fVerts._s_i_z_e(); ++i) { │ │ │ │ │ +504 │ │ │ │ │ +505 dst[cVert].AddWithWeight(src[fVerts[i]], fVertWeights[i]); │ │ │ │ │ +506 } │ │ │ │ │ +507 } │ │ │ │ │ +508} │ │ │ │ │ +509 │ │ │ │ │ +510template │ │ │ │ │ +511template │ │ │ │ │ +512inline void │ │ │ │ │ +513PrimvarRefinerReal::interpFromEdges(int level, T const & src, U & dst) │ │ │ │ │ +const { │ │ │ │ │ +514 │ │ │ │ │ +515 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ +(level-1); │ │ │ │ │ +516 Vtr::internal::Level const & parent = refinement.parent(); │ │ │ │ │ +517 Vtr::internal::Level const & child = refinement.child(); │ │ │ │ │ +518 │ │ │ │ │ +519 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ +520 │ │ │ │ │ +521 Vtr::internal::EdgeInterface eHood(parent); │ │ │ │ │ +522 │ │ │ │ │ +523 Weight eVertWeights[2]; │ │ │ │ │ +524 Vtr::internal::StackBuffer eFaceWeights(parent.getMaxEdgeFaces │ │ │ │ │ +()); │ │ │ │ │ +525 │ │ │ │ │ +526 for (int edge = 0; edge < parent.getNumEdges(); ++edge) { │ │ │ │ │ +527 │ │ │ │ │ +528 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getEdgeChildVertex(edge); │ │ │ │ │ +529 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ +530 continue; │ │ │ │ │ +531 │ │ │ │ │ +532 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ +edge: │ │ │ │ │ +533 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eVerts = parent.getEdgeVertices(edge), │ │ │ │ │ +534 eFaces = parent.getEdgeFaces(edge); │ │ │ │ │ +535 │ │ │ │ │ +536 Mask eMask(eVertWeights, 0, eFaceWeights); │ │ │ │ │ +537 │ │ │ │ │ +538 eHood.SetIndex(edge); │ │ │ │ │ +539 │ │ │ │ │ +540 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e pRule = (parent.getEdgeSharpness(edge) > 0.0f) ? _S_d_c_:_: │ │ │ │ │ +_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E : Sdc::Crease::RULE_SMOOTH; │ │ │ │ │ +541 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e cRule = child.getVertexRule(cVert); │ │ │ │ │ +542 │ │ │ │ │ +543 scheme.ComputeEdgeVertexMask(eHood, eMask, pRule, cRule); │ │ │ │ │ +544 │ │ │ │ │ +545 // Apply the weights to the parent edges's vertices and (if applicable) to │ │ │ │ │ +546 // the child vertices of its incident faces: │ │ │ │ │ +547 dst[cVert].Clear(); │ │ │ │ │ +548 dst[cVert].AddWithWeight(src[eVerts[0]], eVertWeights[0]); │ │ │ │ │ +549 dst[cVert].AddWithWeight(src[eVerts[1]], eVertWeights[1]); │ │ │ │ │ +550 │ │ │ │ │ +551 if (eMask.GetNumFaceWeights() > 0) { │ │ │ │ │ +552 │ │ │ │ │ +553 for (int i = 0; i < eFaces.size(); ++i) { │ │ │ │ │ +554 │ │ │ │ │ +555 if (eMask.AreFaceWeightsForFaceCenters()) { │ │ │ │ │ +556 assert(refinement.getNumChildVerticesFromFaces() > 0); │ │ │ │ │ +557 _V_t_r_:_:_I_n_d_e_x cVertOfFace = refinement.getFaceChildVertex(eFaces[i]); │ │ │ │ │ +558 │ │ │ │ │ +559 assert(_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVertOfFace)); │ │ │ │ │ +560 dst[cVert].AddWithWeight(dst[cVertOfFace], eFaceWeights[i]); │ │ │ │ │ +561 } else { │ │ │ │ │ +562 _V_t_r_:_:_I_n_d_e_x pFace = eFaces[i]; │ │ │ │ │ +563 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y pFaceEdges = parent.getFaceEdges(pFace), │ │ │ │ │ +564 pFaceVerts = parent.getFaceVertices(pFace); │ │ │ │ │ +565 │ │ │ │ │ +566 int eInFace = 0; │ │ │ │ │ +567 for ( ; pFaceEdges[eInFace] != edge; ++eInFace ) ; │ │ │ │ │ +568 │ │ │ │ │ +569 int vInFace = eInFace + 2; │ │ │ │ │ +570 if (vInFace >= pFaceVerts.size()) vInFace -= pFaceVerts._s_i_z_e(); │ │ │ │ │ +571 │ │ │ │ │ +572 _V_t_r_:_:_I_n_d_e_x pVertNext = pFaceVerts[vInFace]; │ │ │ │ │ +573 dst[cVert].AddWithWeight(src[pVertNext], eFaceWeights[i]); │ │ │ │ │ +574 } │ │ │ │ │ +575 } │ │ │ │ │ +576 } │ │ │ │ │ +577 } │ │ │ │ │ +578} │ │ │ │ │ +579 │ │ │ │ │ +580template │ │ │ │ │ +581template │ │ │ │ │ +582inline void │ │ │ │ │ +583PrimvarRefinerReal::interpFromVerts(int level, T const & src, U & dst) │ │ │ │ │ +const { │ │ │ │ │ +584 │ │ │ │ │ +585 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ +(level-1); │ │ │ │ │ +586 Vtr::internal::Level const & parent = refinement.parent(); │ │ │ │ │ +587 Vtr::internal::Level const & child = refinement.child(); │ │ │ │ │ +588 │ │ │ │ │ +589 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ +590 │ │ │ │ │ +591 Vtr::internal::VertexInterface vHood(parent, child); │ │ │ │ │ +592 │ │ │ │ │ +593 Vtr::internal::StackBuffer weightBuffer(2*parent.getMaxValence │ │ │ │ │ +()); │ │ │ │ │ +594 │ │ │ │ │ +595 for (int vert = 0; vert < parent.getNumVertices(); ++vert) { │ │ │ │ │ +596 │ │ │ │ │ +597 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getVertexChildVertex(vert); │ │ │ │ │ +598 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ +599 continue; │ │ │ │ │ +600 │ │ │ │ │ +601 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ +edge: │ │ │ │ │ +602 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vEdges = parent.getVertexEdges(vert), │ │ │ │ │ +603 vFaces = parent.getVertexFaces(vert); │ │ │ │ │ +604 │ │ │ │ │ +605 Weight vVertWeight, │ │ │ │ │ +606 * vEdgeWeights = weightBuffer, │ │ │ │ │ +607 * vFaceWeights = vEdgeWeights + vEdges._s_i_z_e(); │ │ │ │ │ +608 │ │ │ │ │ +609 Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights); │ │ │ │ │ +610 │ │ │ │ │ +611 vHood.SetIndex(vert, cVert); │ │ │ │ │ +612 │ │ │ │ │ +613 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e pRule = parent.getVertexRule(vert); │ │ │ │ │ +614 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e cRule = child.getVertexRule(cVert); │ │ │ │ │ +615 │ │ │ │ │ +616 scheme.ComputeVertexVertexMask(vHood, vMask, pRule, cRule); │ │ │ │ │ +617 │ │ │ │ │ +618 // Apply the weights to the parent vertex, the vertices opposite its │ │ │ │ │ +incident │ │ │ │ │ +619 // edges, and the child vertices of its incident faces: │ │ │ │ │ +620 // │ │ │ │ │ +621 // In order to improve numerical precision, it's better to apply smaller │ │ │ │ │ +weights │ │ │ │ │ +622 // first, so begin with the face-weights followed by the edge-weights and │ │ │ │ │ +the │ │ │ │ │ +623 // vertex weight last. │ │ │ │ │ +624 dst[cVert].Clear(); │ │ │ │ │ +625 │ │ │ │ │ +626 if (vMask.GetNumFaceWeights() > 0) { │ │ │ │ │ +627 assert(vMask.AreFaceWeightsForFaceCenters()); │ │ │ │ │ +628 │ │ │ │ │ +629 for (int i = 0; i < vFaces.size(); ++i) { │ │ │ │ │ +630 │ │ │ │ │ +631 _V_t_r_:_:_I_n_d_e_x cVertOfFace = refinement.getFaceChildVertex(vFaces[i]); │ │ │ │ │ +632 assert(_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVertOfFace)); │ │ │ │ │ +633 dst[cVert].AddWithWeight(dst[cVertOfFace], vFaceWeights[i]); │ │ │ │ │ +634 } │ │ │ │ │ +635 } │ │ │ │ │ +636 if (vMask.GetNumEdgeWeights() > 0) { │ │ │ │ │ +637 │ │ │ │ │ +638 for (int i = 0; i < vEdges.size(); ++i) { │ │ │ │ │ +639 │ │ │ │ │ +640 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eVerts = parent.getEdgeVertices(vEdges[i]); │ │ │ │ │ +641 _V_t_r_:_:_I_n_d_e_x pVertOppositeEdge = (eVerts[0] == vert) ? eVerts[1] : eVerts[0]; │ │ │ │ │ +642 │ │ │ │ │ +643 dst[cVert].AddWithWeight(src[pVertOppositeEdge], vEdgeWeights[i]); │ │ │ │ │ +644 } │ │ │ │ │ +645 } │ │ │ │ │ +646 dst[cVert].AddWithWeight(src[vert], vVertWeight); │ │ │ │ │ +647 } │ │ │ │ │ +648} │ │ │ │ │ +649 │ │ │ │ │ +650 │ │ │ │ │ +651// │ │ │ │ │ +652// Internal face-varying implementation details: │ │ │ │ │ +653// │ │ │ │ │ +654template │ │ │ │ │ +655template │ │ │ │ │ +656inline void │ │ │ │ │ +657PrimvarRefinerReal::interpFVarFromFaces(int level, T const & src, U & │ │ │ │ │ +dst, int channel) const { │ │ │ │ │ +658 │ │ │ │ │ +659 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ +(level-1); │ │ │ │ │ +660 │ │ │ │ │ +661 if (refinement.getNumChildVerticesFromFaces() == 0) return; │ │ │ │ │ +662 │ │ │ │ │ +663 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ +664 │ │ │ │ │ +665 Vtr::internal::Level const & parentLevel = refinement.parent(); │ │ │ │ │ +666 Vtr::internal::Level const & childLevel = refinement.child(); │ │ │ │ │ +667 │ │ │ │ │ +668 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel │ │ │ │ │ +(channel); │ │ │ │ │ +669 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel │ │ │ │ │ +(channel); │ │ │ │ │ +670 │ │ │ │ │ +671 Vtr::internal::StackBuffer fValueWeights │ │ │ │ │ +(parentLevel.getMaxValence()); │ │ │ │ │ +672 │ │ │ │ │ +673 for (int face = 0; face < parentLevel.getNumFaces(); ++face) { │ │ │ │ │ +674 │ │ │ │ │ +675 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getFaceChildVertex(face); │ │ │ │ │ +676 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ +677 continue; │ │ │ │ │ +678 │ │ │ │ │ +679 _V_t_r_:_:_I_n_d_e_x cVertValue = childFVar.getVertexValueOffset(cVert); │ │ │ │ │ +680 │ │ │ │ │ +681 // The only difference for face-varying here is that we get the values │ │ │ │ │ +associated │ │ │ │ │ +682 // with each face-vertex directly from the FVarLevel, rather than using the │ │ │ │ │ +parent │ │ │ │ │ +683 // face-vertices directly. If any face-vertex has any sibling values, then │ │ │ │ │ +we may │ │ │ │ │ +684 // get the wrong one using the face-vertex index directly. │ │ │ │ │ +685 │ │ │ │ │ +686 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ +face: │ │ │ │ │ +687 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y fValues = parentFVar.getFaceValues(face); │ │ │ │ │ +688 │ │ │ │ │ +689 Mask fMask(fValueWeights, 0, 0); │ │ │ │ │ +690 Vtr::internal::FaceInterface fHood(fValues.size()); │ │ │ │ │ +691 │ │ │ │ │ +692 scheme.ComputeFaceVertexMask(fHood, fMask); │ │ │ │ │ +693 │ │ │ │ │ +694 // Apply the weights to the parent face's vertices: │ │ │ │ │ +695 dst[cVertValue].Clear(); │ │ │ │ │ +696 │ │ │ │ │ +697 for (int i = 0; i < fValues.size(); ++i) { │ │ │ │ │ +698 dst[cVertValue].AddWithWeight(src[fValues[i]], fValueWeights[i]); │ │ │ │ │ +699 } │ │ │ │ │ +700 } │ │ │ │ │ +701} │ │ │ │ │ +702 │ │ │ │ │ +703template │ │ │ │ │ +704template │ │ │ │ │ +705inline void │ │ │ │ │ +706PrimvarRefinerReal::interpFVarFromEdges(int level, T const & src, U & │ │ │ │ │ +dst, int channel) const { │ │ │ │ │ +707 │ │ │ │ │ +708 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ +(level-1); │ │ │ │ │ +709 │ │ │ │ │ +710 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ +711 │ │ │ │ │ +712 Vtr::internal::Level const & parentLevel = refinement.parent(); │ │ │ │ │ +713 Vtr::internal::Level const & childLevel = refinement.child(); │ │ │ │ │ +714 │ │ │ │ │ +715 Vtr::internal::FVarRefinement const & refineFVar = │ │ │ │ │ +refinement.getFVarRefinement(channel); │ │ │ │ │ +716 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel │ │ │ │ │ +(channel); │ │ │ │ │ +717 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel │ │ │ │ │ +(channel); │ │ │ │ │ +718 │ │ │ │ │ +719 // │ │ │ │ │ +720 // Allocate and initialize (if linearly interpolated) interpolation weights │ │ │ │ │ +for │ │ │ │ │ +721 // the edge mask: │ │ │ │ │ +722 // │ │ │ │ │ +723 Weight eVertWeights[2]; │ │ │ │ │ +724 Vtr::internal::StackBuffer eFaceWeights │ │ │ │ │ +(parentLevel.getMaxEdgeFaces()); │ │ │ │ │ +725 │ │ │ │ │ +726 Mask eMask(eVertWeights, 0, eFaceWeights); │ │ │ │ │ +727 │ │ │ │ │ +728 bool isLinearFVar = parentFVar.isLinear() || (_refiner._subdivType == _S_d_c_:_: │ │ │ │ │ +_S_C_H_E_M_E___B_I_L_I_N_E_A_R); │ │ │ │ │ +729 if (isLinearFVar) { │ │ │ │ │ +730 eMask.SetNumVertexWeights(2); │ │ │ │ │ +731 eMask.SetNumEdgeWeights(0); │ │ │ │ │ +732 eMask.SetNumFaceWeights(0); │ │ │ │ │ +733 │ │ │ │ │ +734 eVertWeights[0] = 0.5f; │ │ │ │ │ +735 eVertWeights[1] = 0.5f; │ │ │ │ │ +736 } │ │ │ │ │ +737 │ │ │ │ │ +738 Vtr::internal::EdgeInterface eHood(parentLevel); │ │ │ │ │ +739 │ │ │ │ │ +740 for (int edge = 0; edge < parentLevel.getNumEdges(); ++edge) { │ │ │ │ │ +741 │ │ │ │ │ +742 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getEdgeChildVertex(edge); │ │ │ │ │ +743 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ +744 continue; │ │ │ │ │ +745 │ │ │ │ │ +746 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y cVertValues = childFVar.getVertexValues(cVert); │ │ │ │ │ +747 │ │ │ │ │ +748 bool fvarEdgeVertMatchesVertex = childFVar.valueTopologyMatches(cVertValues │ │ │ │ │ +[0]); │ │ │ │ │ +749 if (fvarEdgeVertMatchesVertex) { │ │ │ │ │ +750 // │ │ │ │ │ +751 // If smoothly interpolated, compute new weights for the edge mask: │ │ │ │ │ +752 // │ │ │ │ │ +753 if (!isLinearFVar) { │ │ │ │ │ +754 eHood.SetIndex(edge); │ │ │ │ │ +755 │ │ │ │ │ +756 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e pRule = (parentLevel.getEdgeSharpness(edge) > 0.0f) │ │ │ │ │ +757 ? _S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E : Sdc::Crease::RULE_SMOOTH; │ │ │ │ │ +758 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e cRule = childLevel.getVertexRule(cVert); │ │ │ │ │ +759 │ │ │ │ │ +760 scheme.ComputeEdgeVertexMask(eHood, eMask, pRule, cRule); │ │ │ │ │ +761 } │ │ │ │ │ +762 │ │ │ │ │ +763 // Apply the weights to the parent edge's vertices and (if applicable) to │ │ │ │ │ +764 // the child vertices of its incident faces: │ │ │ │ │ +765 // │ │ │ │ │ +766 // Even though the face-varying topology matches the vertex topology, we │ │ │ │ │ +need │ │ │ │ │ +767 // to be careful here when getting values corresponding to the two end- │ │ │ │ │ +vertices. │ │ │ │ │ +768 // While the edge may be continuous, the vertices at their ends may have │ │ │ │ │ +769 // discontinuities elsewhere in their neighborhood (i.e. on the "other │ │ │ │ │ +side" │ │ │ │ │ +770 // of the end-vertex) and so have sibling values associated with them. In │ │ │ │ │ +most │ │ │ │ │ +771 // cases the topology for an end-vertex will match and we can use it │ │ │ │ │ +directly, │ │ │ │ │ +772 // but we must still check and retrieve as needed. │ │ │ │ │ +773 // │ │ │ │ │ +774 // Indices for values corresponding to face-vertices are guaranteed to │ │ │ │ │ +match, │ │ │ │ │ +775 // so we can use the child-vertex indices directly. │ │ │ │ │ +776 // │ │ │ │ │ +777 // And by "directly", we always use getVertexValue(vertexIndex) to │ │ │ │ │ +reference │ │ │ │ │ +778 // values in the "src" to account for the possible indirection that may │ │ │ │ │ +exist at │ │ │ │ │ +779 // level 0 -- where there may be fewer values than vertices and an │ │ │ │ │ +additional │ │ │ │ │ +780 // indirection is necessary. We can use a vertex index directly for "dst" │ │ │ │ │ +when │ │ │ │ │ +781 // it matches. │ │ │ │ │ +782 // │ │ │ │ │ +783 _V_t_r_:_:_I_n_d_e_x eVertValues[2]; │ │ │ │ │ +784 │ │ │ │ │ +785 parentFVar.getEdgeFaceValues(edge, 0, eVertValues); │ │ │ │ │ +786 │ │ │ │ │ +787 _I_n_d_e_x cVertValue = cVertValues[0]; │ │ │ │ │ +788 │ │ │ │ │ +789 dst[cVertValue].Clear(); │ │ │ │ │ +790 dst[cVertValue].AddWithWeight(src[eVertValues[0]], eVertWeights[0]); │ │ │ │ │ +791 dst[cVertValue].AddWithWeight(src[eVertValues[1]], eVertWeights[1]); │ │ │ │ │ +792 │ │ │ │ │ +793 if (eMask.GetNumFaceWeights() > 0) { │ │ │ │ │ +794 │ │ │ │ │ +795 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eFaces = parentLevel.getEdgeFaces(edge); │ │ │ │ │ +796 │ │ │ │ │ +797 for (int i = 0; i < eFaces.size(); ++i) { │ │ │ │ │ +798 if (eMask.AreFaceWeightsForFaceCenters()) { │ │ │ │ │ +799 │ │ │ │ │ +800 _V_t_r_:_:_I_n_d_e_x cVertOfFace = refinement.getFaceChildVertex(eFaces[i]); │ │ │ │ │ +801 assert(_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVertOfFace)); │ │ │ │ │ +802 │ │ │ │ │ +803 _V_t_r_:_:_I_n_d_e_x cValueOfFace = childFVar.getVertexValueOffset(cVertOfFace); │ │ │ │ │ +804 dst[cVertValue].AddWithWeight(dst[cValueOfFace], eFaceWeights[i]); │ │ │ │ │ +805 } else { │ │ │ │ │ +806 _V_t_r_:_:_I_n_d_e_x pFace = eFaces[i]; │ │ │ │ │ +807 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y pFaceEdges = parentLevel.getFaceEdges(pFace), │ │ │ │ │ +808 pFaceVerts = parentLevel.getFaceVertices(pFace); │ │ │ │ │ +809 │ │ │ │ │ +810 int eInFace = 0; │ │ │ │ │ +811 for ( ; pFaceEdges[eInFace] != edge; ++eInFace ) ; │ │ │ │ │ +812 │ │ │ │ │ +813 // Edge "i" spans vertices [i,i+1] so we want i+2... │ │ │ │ │ +814 int vInFace = eInFace + 2; │ │ │ │ │ +815 if (vInFace >= pFaceVerts.size()) vInFace -= pFaceVerts._s_i_z_e(); │ │ │ │ │ +816 │ │ │ │ │ +817 _V_t_r_:_:_I_n_d_e_x pValueNext = parentFVar.getFaceValues(pFace)[vInFace]; │ │ │ │ │ +818 dst[cVertValue].AddWithWeight(src[pValueNext], eFaceWeights[i]); │ │ │ │ │ +819 } │ │ │ │ │ +820 } │ │ │ │ │ +821 } │ │ │ │ │ +822 } else { │ │ │ │ │ +823 // │ │ │ │ │ +824 // Mismatched edge-verts should just be linearly interpolated between the │ │ │ │ │ +pairs of │ │ │ │ │ +825 // values for each sibling of the child edge-vertex -- the question is: │ │ │ │ │ +which face │ │ │ │ │ +826 // holds that pair of values for a given sibling? │ │ │ │ │ +827 // │ │ │ │ │ +828 // In the manifold case, the sibling and edge-face indices will correspond. │ │ │ │ │ +We │ │ │ │ │ +829 // will eventually need to update this to account for > 3 incident faces. │ │ │ │ │ +830 // │ │ │ │ │ +831 for (int i = 0; i < cVertValues.size(); ++i) { │ │ │ │ │ +832 _V_t_r_:_:_I_n_d_e_x eVertValues[2]; │ │ │ │ │ +833 int eFaceIndex = refineFVar.getChildValueParentSource(cVert, i); │ │ │ │ │ +834 assert(eFaceIndex == i); │ │ │ │ │ +835 │ │ │ │ │ +836 parentFVar.getEdgeFaceValues(edge, eFaceIndex, eVertValues); │ │ │ │ │ +837 │ │ │ │ │ +838 _I_n_d_e_x cVertValue = cVertValues[i]; │ │ │ │ │ +839 │ │ │ │ │ +840 dst[cVertValue].Clear(); │ │ │ │ │ +841 dst[cVertValue].AddWithWeight(src[eVertValues[0]], 0.5); │ │ │ │ │ +842 dst[cVertValue].AddWithWeight(src[eVertValues[1]], 0.5); │ │ │ │ │ +843 } │ │ │ │ │ +844 } │ │ │ │ │ +845 } │ │ │ │ │ +846} │ │ │ │ │ +847 │ │ │ │ │ +848template │ │ │ │ │ +849template │ │ │ │ │ +850inline void │ │ │ │ │ +851PrimvarRefinerReal::interpFVarFromVerts(int level, T const & src, U & │ │ │ │ │ +dst, int channel) const { │ │ │ │ │ +852 │ │ │ │ │ +853 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ +(level-1); │ │ │ │ │ +854 │ │ │ │ │ +855 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ +856 │ │ │ │ │ +857 Vtr::internal::Level const & parentLevel = refinement.parent(); │ │ │ │ │ +858 Vtr::internal::Level const & childLevel = refinement.child(); │ │ │ │ │ +859 │ │ │ │ │ +860 Vtr::internal::FVarRefinement const & refineFVar = │ │ │ │ │ +refinement.getFVarRefinement(channel); │ │ │ │ │ +861 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel │ │ │ │ │ +(channel); │ │ │ │ │ +862 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel │ │ │ │ │ +(channel); │ │ │ │ │ +863 │ │ │ │ │ +864 bool isLinearFVar = parentFVar.isLinear() || (_refiner._subdivType == _S_d_c_:_: │ │ │ │ │ +_S_C_H_E_M_E___B_I_L_I_N_E_A_R); │ │ │ │ │ +865 │ │ │ │ │ +866 Vtr::internal::StackBuffer weightBuffer │ │ │ │ │ +(2*parentLevel.getMaxValence()); │ │ │ │ │ +867 │ │ │ │ │ +868 Vtr::internal::StackBuffer vEdgeValues │ │ │ │ │ +(parentLevel.getMaxValence()); │ │ │ │ │ +869 │ │ │ │ │ +870 Vtr::internal::VertexInterface vHood(parentLevel, childLevel); │ │ │ │ │ +871 │ │ │ │ │ +872 for (int vert = 0; vert < parentLevel.getNumVertices(); ++vert) { │ │ │ │ │ +873 │ │ │ │ │ +874 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getVertexChildVertex(vert); │ │ │ │ │ +875 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ +876 continue; │ │ │ │ │ +877 │ │ │ │ │ +878 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y pVertValues = parentFVar.getVertexValues(vert), │ │ │ │ │ +879 cVertValues = childFVar.getVertexValues(cVert); │ │ │ │ │ +880 │ │ │ │ │ +881 bool fvarVertVertMatchesVertex = childFVar.valueTopologyMatches(cVertValues │ │ │ │ │ +[0]); │ │ │ │ │ +882 if (isLinearFVar && fvarVertVertMatchesVertex) { │ │ │ │ │ +883 dst[cVertValues[0]].Clear(); │ │ │ │ │ +884 dst[cVertValues[0]].AddWithWeight(src[pVertValues[0]], 1.0f); │ │ │ │ │ +885 continue; │ │ │ │ │ +886 } │ │ │ │ │ +887 │ │ │ │ │ +888 if (fvarVertVertMatchesVertex) { │ │ │ │ │ +889 // │ │ │ │ │ +890 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ +edge: │ │ │ │ │ +891 // │ │ │ │ │ +892 // (We really need to encapsulate this somewhere else for use here and in │ │ │ │ │ +the │ │ │ │ │ +893 // general case) │ │ │ │ │ +894 // │ │ │ │ │ +895 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vEdges = parentLevel.getVertexEdges(vert); │ │ │ │ │ +896 │ │ │ │ │ +897 Weight vVertWeight; │ │ │ │ │ +898 Weight * vEdgeWeights = weightBuffer; │ │ │ │ │ +899 Weight * vFaceWeights = vEdgeWeights + vEdges._s_i_z_e(); │ │ │ │ │ +900 │ │ │ │ │ +901 Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights); │ │ │ │ │ +902 │ │ │ │ │ +903 vHood.SetIndex(vert, cVert); │ │ │ │ │ +904 │ │ │ │ │ +905 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e pRule = parentLevel.getVertexRule(vert); │ │ │ │ │ +906 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e cRule = childLevel.getVertexRule(cVert); │ │ │ │ │ +907 │ │ │ │ │ +908 scheme.ComputeVertexVertexMask(vHood, vMask, pRule, cRule); │ │ │ │ │ +909 │ │ │ │ │ +910 // Apply the weights to the parent vertex, the vertices opposite its │ │ │ │ │ +incident │ │ │ │ │ +911 // edges, and the child vertices of its incident faces: │ │ │ │ │ +912 // │ │ │ │ │ +913 // Even though the face-varying topology matches the vertex topology, we │ │ │ │ │ +need │ │ │ │ │ +914 // to be careful here when getting values corresponding to vertices at the │ │ │ │ │ +915 // ends of edges. While the edge may be continuous, the end vertex may have │ │ │ │ │ +916 // discontinuities elsewhere in their neighborhood (i.e. on the "other │ │ │ │ │ +side" │ │ │ │ │ +917 // of the end-vertex) and so have sibling values associated with them. In │ │ │ │ │ +most │ │ │ │ │ +918 // cases the topology for an end-vertex will match and we can use it │ │ │ │ │ +directly, │ │ │ │ │ +919 // but we must still check and retrieve as needed. │ │ │ │ │ +920 // │ │ │ │ │ +921 // Indices for values corresponding to face-vertices are guaranteed to │ │ │ │ │ +match, │ │ │ │ │ +922 // so we can use the child-vertex indices directly. │ │ │ │ │ +923 // │ │ │ │ │ +924 // And by "directly", we always use getVertexValue(vertexIndex) to │ │ │ │ │ +reference │ │ │ │ │ +925 // values in the "src" to account for the possible indirection that may │ │ │ │ │ +exist at │ │ │ │ │ +926 // level 0 -- where there may be fewer values than vertices and an │ │ │ │ │ +additional │ │ │ │ │ +927 // indirection is necessary. We can use a vertex index directly for "dst" │ │ │ │ │ +when │ │ │ │ │ +928 // it matches. │ │ │ │ │ +929 // │ │ │ │ │ +930 // As with applying the mask to vertex data, in order to improve numerical │ │ │ │ │ +931 // precision, it's better to apply smaller weights first, so begin with the │ │ │ │ │ +932 // face-weights followed by the edge-weights and the vertex weight last. │ │ │ │ │ +933 // │ │ │ │ │ +934 _V_t_r_:_:_I_n_d_e_x pVertValue = pVertValues[0]; │ │ │ │ │ +935 _V_t_r_:_:_I_n_d_e_x cVertValue = cVertValues[0]; │ │ │ │ │ +936 │ │ │ │ │ +937 dst[cVertValue].Clear(); │ │ │ │ │ +938 if (vMask.GetNumFaceWeights() > 0) { │ │ │ │ │ +939 assert(vMask.AreFaceWeightsForFaceCenters()); │ │ │ │ │ +940 │ │ │ │ │ +941 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vFaces = parentLevel.getVertexFaces(vert); │ │ │ │ │ +942 │ │ │ │ │ +943 for (int i = 0; i < vFaces.size(); ++i) { │ │ │ │ │ +944 │ │ │ │ │ +945 _V_t_r_:_:_I_n_d_e_x cVertOfFace = refinement.getFaceChildVertex(vFaces[i]); │ │ │ │ │ +946 assert(_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVertOfFace)); │ │ │ │ │ +947 │ │ │ │ │ +948 _V_t_r_:_:_I_n_d_e_x cValueOfFace = childFVar.getVertexValueOffset(cVertOfFace); │ │ │ │ │ +949 dst[cVertValue].AddWithWeight(dst[cValueOfFace], vFaceWeights[i]); │ │ │ │ │ +950 } │ │ │ │ │ +951 } │ │ │ │ │ +952 if (vMask.GetNumEdgeWeights() > 0) { │ │ │ │ │ +953 │ │ │ │ │ +954 parentFVar.getVertexEdgeValues(vert, vEdgeValues); │ │ │ │ │ +955 │ │ │ │ │ +956 for (int i = 0; i < vEdges.size(); ++i) { │ │ │ │ │ +957 dst[cVertValue].AddWithWeight(src[vEdgeValues[i]], vEdgeWeights[i]); │ │ │ │ │ +958 } │ │ │ │ │ +959 } │ │ │ │ │ +960 dst[cVertValue].AddWithWeight(src[pVertValue], vVertWeight); │ │ │ │ │ +961 } else { │ │ │ │ │ +962 // │ │ │ │ │ +963 // Each FVar value associated with a vertex will be either a corner or a │ │ │ │ │ +crease, │ │ │ │ │ +964 // or potentially in transition from corner to crease: │ │ │ │ │ +965 // - if the CHILD is a corner, there can be no transition so we have a │ │ │ │ │ +corner │ │ │ │ │ +966 // - otherwise if the PARENT is a crease, both will be creases (no │ │ │ │ │ +transition) │ │ │ │ │ +967 // - otherwise the parent must be a corner and the child a crease │ │ │ │ │ +(transition) │ │ │ │ │ +968 // │ │ │ │ │ +969 Vtr::internal::FVarLevel::ConstValueTagArray pValueTags = │ │ │ │ │ +parentFVar.getVertexValueTags(vert); │ │ │ │ │ +970 Vtr::internal::FVarLevel::ConstValueTagArray cValueTags = │ │ │ │ │ +childFVar.getVertexValueTags(cVert); │ │ │ │ │ +971 │ │ │ │ │ +972 for (int cSiblingIndex = 0; cSiblingIndex < cVertValues.size(); │ │ │ │ │ +++cSiblingIndex) { │ │ │ │ │ +973 int pSiblingIndex = refineFVar.getChildValueParentSource(cVert, │ │ │ │ │ +cSiblingIndex); │ │ │ │ │ +974 assert(pSiblingIndex == cSiblingIndex); │ │ │ │ │ +975 │ │ │ │ │ +976 typedef Vtr::internal::FVarLevel::Sibling SiblingIntType; │ │ │ │ │ +977 │ │ │ │ │ +978 SiblingIntType cSibling = (SiblingIntType) cSiblingIndex; │ │ │ │ │ +979 SiblingIntType pSibling = (SiblingIntType) pSiblingIndex; │ │ │ │ │ +980 │ │ │ │ │ +981 _V_t_r_:_:_I_n_d_e_x pVertValue = pVertValues[pSibling]; │ │ │ │ │ +982 _V_t_r_:_:_I_n_d_e_x cVertValue = cVertValues[cSibling]; │ │ │ │ │ +983 │ │ │ │ │ +984 dst[cVertValue].Clear(); │ │ │ │ │ +985 if (isLinearFVar || cValueTags[cSibling].isCorner()) { │ │ │ │ │ +986 dst[cVertValue].AddWithWeight(src[pVertValue], 1.0f); │ │ │ │ │ +987 } else { │ │ │ │ │ +988 // │ │ │ │ │ +989 // We have either a crease or a transition from corner to crease -- in │ │ │ │ │ +990 // either case, we need the end values for the full/fractional crease: │ │ │ │ │ +991 // │ │ │ │ │ +992 _I_n_d_e_x pEndValues[2]; │ │ │ │ │ +993 parentFVar.getVertexCreaseEndValues(vert, pSibling, pEndValues); │ │ │ │ │ +994 │ │ │ │ │ +995 Weight vWeight = 0.75f; │ │ │ │ │ +996 Weight eWeight = 0.125f; │ │ │ │ │ +997 │ │ │ │ │ +998 // │ │ │ │ │ +999 // If semi-sharp we need to apply fractional weighting -- if made sharp │ │ │ │ │ +because │ │ │ │ │ +1000 // of the other sibling (dependent-sharp) use the fractional weight from │ │ │ │ │ +that │ │ │ │ │ +1001 // other sibling (should only occur when there are 2): │ │ │ │ │ +1002 // │ │ │ │ │ +1003 if (pValueTags[pSibling].isSemiSharp()) { │ │ │ │ │ +1004 Weight wCorner = pValueTags[pSibling].isDepSharp() │ │ │ │ │ +1005 ? refineFVar.getFractionalWeight(vert, !pSibling, cVert, !cSibling) │ │ │ │ │ +1006 : refineFVar.getFractionalWeight(vert, pSibling, cVert, cSibling); │ │ │ │ │ +1007 Weight wCrease = 1.0f - wCorner; │ │ │ │ │ +1008 │ │ │ │ │ +1009 vWeight = wCrease * 0.75f + wCorner; │ │ │ │ │ +1010 eWeight = wCrease * 0.125f; │ │ │ │ │ +1011 } │ │ │ │ │ +1012 dst[cVertValue].AddWithWeight(src[pEndValues[0]], eWeight); │ │ │ │ │ +1013 dst[cVertValue].AddWithWeight(src[pEndValues[1]], eWeight); │ │ │ │ │ +1014 dst[cVertValue].AddWithWeight(src[pVertValue], vWeight); │ │ │ │ │ +1015 } │ │ │ │ │ +1016 } │ │ │ │ │ +1017 } │ │ │ │ │ +1018 } │ │ │ │ │ +1019} │ │ │ │ │ +1020 │ │ │ │ │ +1021template │ │ │ │ │ +1022template │ │ │ │ │ +1023inline void │ │ │ │ │ +1024PrimvarRefinerReal::limit(T const & src, U & dstPos, U1 * dstTan1Ptr, │ │ │ │ │ +U2 * dstTan2Ptr) const { │ │ │ │ │ +1025 │ │ │ │ │ +1026 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ +1027 │ │ │ │ │ +1028 Vtr::internal::Level const & level = _refiner.getLevel │ │ │ │ │ +(_refiner.GetMaxLevel()); │ │ │ │ │ +1029 │ │ │ │ │ +1030 int maxWeightsPerMask = 1 + 2 * level.getMaxValence(); │ │ │ │ │ +1031 bool hasTangents = (dstTan1Ptr && dstTan2Ptr); │ │ │ │ │ +1032 int numMasks = 1 + (hasTangents ? 2 : 0); │ │ │ │ │ +1033 │ │ │ │ │ +1034 Vtr::internal::StackBuffer indexBuffer(maxWeightsPerMask); │ │ │ │ │ +1035 Vtr::internal::StackBuffer weightBuffer(numMasks * │ │ │ │ │ +maxWeightsPerMask); │ │ │ │ │ +1036 │ │ │ │ │ +1037 Weight * vPosWeights = weightBuffer, │ │ │ │ │ +1038 * ePosWeights = vPosWeights + 1, │ │ │ │ │ +1039 * fPosWeights = ePosWeights + level.getMaxValence(); │ │ │ │ │ +1040 Weight * vTan1Weights = vPosWeights + maxWeightsPerMask, │ │ │ │ │ +1041 * eTan1Weights = ePosWeights + maxWeightsPerMask, │ │ │ │ │ +1042 * fTan1Weights = fPosWeights + maxWeightsPerMask; │ │ │ │ │ +1043 Weight * vTan2Weights = vTan1Weights + maxWeightsPerMask, │ │ │ │ │ +1044 * eTan2Weights = eTan1Weights + maxWeightsPerMask, │ │ │ │ │ +1045 * fTan2Weights = fTan1Weights + maxWeightsPerMask; │ │ │ │ │ +1046 │ │ │ │ │ +1047 Mask posMask( vPosWeights, ePosWeights, fPosWeights); │ │ │ │ │ +1048 Mask tan1Mask(vTan1Weights, eTan1Weights, fTan1Weights); │ │ │ │ │ +1049 Mask tan2Mask(vTan2Weights, eTan2Weights, fTan2Weights); │ │ │ │ │ +1050 │ │ │ │ │ +1051 // This is a bit obscure -- assigning both parent and child as last level │ │ │ │ │ +-- but │ │ │ │ │ +1052 // this mask type was intended for another purpose. Consider one for the │ │ │ │ │ +limit: │ │ │ │ │ +1053 Vtr::internal::VertexInterface vHood(level, level); │ │ │ │ │ +1054 │ │ │ │ │ +1055 for (int vert = 0; vert < level.getNumVertices(); ++vert) { │ │ │ │ │ +1056 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vEdges = level.getVertexEdges(vert); │ │ │ │ │ +1057 │ │ │ │ │ +1058 // Incomplete vertices (present in sparse refinement) do not have their │ │ │ │ │ +full │ │ │ │ │ +1059 // topological neighborhood to determine a proper limit -- just leave the │ │ │ │ │ +1060 // vertex at the refined location and continue to the next: │ │ │ │ │ +1061 if (level.getVertexTag(vert)._incomplete || (vEdges.size() == 0)) { │ │ │ │ │ +1062 dstPos[vert].Clear(); │ │ │ │ │ +1063 dstPos[vert].AddWithWeight(src[vert], 1.0); │ │ │ │ │ +1064 if (hasTangents) { │ │ │ │ │ +1065 (*dstTan1Ptr)[vert].Clear(); │ │ │ │ │ +1066 (*dstTan2Ptr)[vert].Clear(); │ │ │ │ │ +1067 } │ │ │ │ │ +1068 continue; │ │ │ │ │ +1069 } │ │ │ │ │ +1070 │ │ │ │ │ +1071 // │ │ │ │ │ +1072 // Limit masks require the subdivision Rule for the vertex in order to │ │ │ │ │ +deal │ │ │ │ │ +1073 // with infinitely sharp features correctly -- including boundaries and │ │ │ │ │ +corners. │ │ │ │ │ +1074 // The vertex neighborhood is minimally defined with vertex and edge │ │ │ │ │ +counts. │ │ │ │ │ +1075 // │ │ │ │ │ +1076 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e vRule = level.getVertexRule(vert); │ │ │ │ │ +1077 │ │ │ │ │ +1078 // This is a bit obscure -- child vertex index will be ignored here │ │ │ │ │ +1079 vHood.SetIndex(vert, vert); │ │ │ │ │ +1080 │ │ │ │ │ +1081 if (hasTangents) { │ │ │ │ │ +1082 scheme.ComputeVertexLimitMask(vHood, posMask, tan1Mask, tan2Mask, vRule); │ │ │ │ │ +1083 } else { │ │ │ │ │ +1084 scheme.ComputeVertexLimitMask(vHood, posMask, vRule); │ │ │ │ │ +1085 } │ │ │ │ │ +1086 │ │ │ │ │ +1087 // │ │ │ │ │ +1088 // Gather the neighboring vertices of this vertex -- the vertices opposite │ │ │ │ │ +its │ │ │ │ │ +1089 // incident edges, and the opposite vertices of its incident faces: │ │ │ │ │ +1090 // │ │ │ │ │ +1091 _I_n_d_e_x * eIndices = indexBuffer; │ │ │ │ │ +1092 _I_n_d_e_x * fIndices = indexBuffer + vEdges._s_i_z_e(); │ │ │ │ │ +1093 │ │ │ │ │ +1094 for (int i = 0; i < vEdges.size(); ++i) { │ │ │ │ │ +1095 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eVerts = level.getEdgeVertices(vEdges[i]); │ │ │ │ │ +1096 │ │ │ │ │ +1097 eIndices[i] = (eVerts[0] == vert) ? eVerts[1] : eVerts[0]; │ │ │ │ │ +1098 } │ │ │ │ │ +1099 if (posMask.GetNumFaceWeights() || (hasTangents && │ │ │ │ │ +tan1Mask.GetNumFaceWeights())) { │ │ │ │ │ +1100 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vFaces = level.getVertexFaces(vert); │ │ │ │ │ +1101 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y vInFace = level.getVertexFaceLocalIndices(vert); │ │ │ │ │ +1102 │ │ │ │ │ +1103 for (int i = 0; i < vFaces.size(); ++i) { │ │ │ │ │ +1104 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y fVerts = level.getFaceVertices(vFaces[i]); │ │ │ │ │ +1105 │ │ │ │ │ +1106 _L_o_c_a_l_I_n_d_e_x vOppInFace = (vInFace[i] + 2); │ │ │ │ │ +1107 if (vOppInFace >= fVerts.size()) vOppInFace -= (_L_o_c_a_l_I_n_d_e_x)fVerts._s_i_z_e(); │ │ │ │ │ +1108 │ │ │ │ │ +1109 fIndices[i] = level.getFaceVertices(vFaces[i])[vOppInFace]; │ │ │ │ │ +1110 } │ │ │ │ │ +1111 } │ │ │ │ │ +1112 │ │ │ │ │ +1113 // │ │ │ │ │ +1114 // Combine the weights and indices for position and tangents. As with │ │ │ │ │ +applying │ │ │ │ │ +1115 // refinement masks to vertex data, in order to improve numerical │ │ │ │ │ +precision, it's │ │ │ │ │ +1116 // better to apply smaller weights first, so begin with the face-weights │ │ │ │ │ +followed │ │ │ │ │ +1117 // by the edge-weights and the vertex weight last. │ │ │ │ │ +1118 // │ │ │ │ │ +1119 dstPos[vert].Clear(); │ │ │ │ │ +1120 for (int i = 0; i < posMask.GetNumFaceWeights(); ++i) { │ │ │ │ │ +1121 dstPos[vert].AddWithWeight(src[fIndices[i]], fPosWeights[i]); │ │ │ │ │ +1122 } │ │ │ │ │ +1123 for (int i = 0; i < posMask.GetNumEdgeWeights(); ++i) { │ │ │ │ │ +1124 dstPos[vert].AddWithWeight(src[eIndices[i]], ePosWeights[i]); │ │ │ │ │ +1125 } │ │ │ │ │ +1126 dstPos[vert].AddWithWeight(src[vert], vPosWeights[0]); │ │ │ │ │ +1127 │ │ │ │ │ +1128 // │ │ │ │ │ +1129 // Apply the tangent masks -- both will have the same number of weights │ │ │ │ │ +and │ │ │ │ │ +1130 // indices (one tangent may be "padded" to accommodate the other), but │ │ │ │ │ +these │ │ │ │ │ +1131 // may differ from those of the position: │ │ │ │ │ +1132 // │ │ │ │ │ +1133 if (hasTangents) { │ │ │ │ │ +1134 assert(tan1Mask.GetNumFaceWeights() == tan2Mask.GetNumFaceWeights()); │ │ │ │ │ +1135 assert(tan1Mask.GetNumEdgeWeights() == tan2Mask.GetNumEdgeWeights()); │ │ │ │ │ +1136 │ │ │ │ │ +1137 U1 & dstTan1 = *dstTan1Ptr; │ │ │ │ │ +1138 U2 & dstTan2 = *dstTan2Ptr; │ │ │ │ │ +1139 │ │ │ │ │ +1140 dstTan1[vert].Clear(); │ │ │ │ │ +1141 dstTan2[vert].Clear(); │ │ │ │ │ +1142 for (int i = 0; i < tan1Mask.GetNumFaceWeights(); ++i) { │ │ │ │ │ +1143 dstTan1[vert].AddWithWeight(src[fIndices[i]], fTan1Weights[i]); │ │ │ │ │ +1144 dstTan2[vert].AddWithWeight(src[fIndices[i]], fTan2Weights[i]); │ │ │ │ │ +1145 } │ │ │ │ │ +1146 for (int i = 0; i < tan1Mask.GetNumEdgeWeights(); ++i) { │ │ │ │ │ +1147 dstTan1[vert].AddWithWeight(src[eIndices[i]], eTan1Weights[i]); │ │ │ │ │ +1148 dstTan2[vert].AddWithWeight(src[eIndices[i]], eTan2Weights[i]); │ │ │ │ │ +1149 } │ │ │ │ │ +1150 dstTan1[vert].AddWithWeight(src[vert], vTan1Weights[0]); │ │ │ │ │ +1151 dstTan2[vert].AddWithWeight(src[vert], vTan2Weights[0]); │ │ │ │ │ +1152 } │ │ │ │ │ +1153 } │ │ │ │ │ +1154} │ │ │ │ │ +1155 │ │ │ │ │ +1156template │ │ │ │ │ +1157template │ │ │ │ │ +1158inline void │ │ │ │ │ +1159PrimvarRefinerReal::limitFVar(T const & src, U & dst, int channel) │ │ │ │ │ +const { │ │ │ │ │ +1160 │ │ │ │ │ +1161 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ +1162 │ │ │ │ │ +1163 Vtr::internal::Level const & level = _refiner.getLevel │ │ │ │ │ +(_refiner.GetMaxLevel()); │ │ │ │ │ +1164 Vtr::internal::FVarLevel const & fvarChannel = level.getFVarLevel │ │ │ │ │ +(channel); │ │ │ │ │ +1165 │ │ │ │ │ +1166 int maxWeightsPerMask = 1 + 2 * level.getMaxValence(); │ │ │ │ │ +1167 │ │ │ │ │ +1168 Vtr::internal::StackBuffer weightBuffer(maxWeightsPerMask); │ │ │ │ │ +1169 Vtr::internal::StackBuffer vEdgeBuffer(level.getMaxValence()); │ │ │ │ │ +1170 │ │ │ │ │ +1171 // This is a bit obscure -- assign both parent and child as last level │ │ │ │ │ +1172 Vtr::internal::VertexInterface vHood(level, level); │ │ │ │ │ +1173 │ │ │ │ │ +1174 for (int vert = 0; vert < level.getNumVertices(); ++vert) { │ │ │ │ │ +1175 │ │ │ │ │ +1176 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vEdges = level.getVertexEdges(vert); │ │ │ │ │ +1177 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vValues = fvarChannel.getVertexValues(vert); │ │ │ │ │ +1178 │ │ │ │ │ +1179 // Incomplete vertices (present in sparse refinement) do not have their │ │ │ │ │ +full │ │ │ │ │ +1180 // topological neighborhood to determine a proper limit -- just leave the │ │ │ │ │ +1181 // values (perhaps more than one per vertex) at the refined location. │ │ │ │ │ +1182 // │ │ │ │ │ +1183 // The same can be done if the face-varying channel is purely linear. │ │ │ │ │ +1184 // │ │ │ │ │ +1185 bool isIncomplete = (level.getVertexTag(vert)._incomplete || (vEdges.size │ │ │ │ │ +() == 0)); │ │ │ │ │ +1186 if (isIncomplete || fvarChannel.isLinear()) { │ │ │ │ │ +1187 for (int i = 0; i < vValues.size(); ++i) { │ │ │ │ │ +1188 _V_t_r_:_:_I_n_d_e_x vValue = vValues[i]; │ │ │ │ │ +1189 │ │ │ │ │ +1190 dst[vValue].Clear(); │ │ │ │ │ +1191 dst[vValue].AddWithWeight(src[vValue], 1.0f); │ │ │ │ │ +1192 } │ │ │ │ │ +1193 continue; │ │ │ │ │ +1194 } │ │ │ │ │ +1195 │ │ │ │ │ +1196 bool fvarVertMatchesVertex = fvarChannel.valueTopologyMatches(vValues[0]); │ │ │ │ │ +1197 if (fvarVertMatchesVertex) { │ │ │ │ │ +1198 │ │ │ │ │ +1199 // Assign the mask weights to the common buffer and compute the mask: │ │ │ │ │ +1200 // │ │ │ │ │ +1201 Weight * vWeights = weightBuffer, │ │ │ │ │ +1202 * eWeights = vWeights + 1, │ │ │ │ │ +1203 * fWeights = eWeights + vEdges._s_i_z_e(); │ │ │ │ │ +1204 │ │ │ │ │ +1205 Mask vMask(vWeights, eWeights, fWeights); │ │ │ │ │ +1206 │ │ │ │ │ +1207 vHood.SetIndex(vert, vert); │ │ │ │ │ +1208 │ │ │ │ │ +1209 scheme.ComputeVertexLimitMask(vHood, vMask, level.getVertexRule(vert)); │ │ │ │ │ +1210 │ │ │ │ │ +1211 // │ │ │ │ │ +1212 // Apply mask to corresponding FVar values for neighboring vertices: │ │ │ │ │ +1213 // │ │ │ │ │ +1214 _V_t_r_:_:_I_n_d_e_x vValue = vValues[0]; │ │ │ │ │ +1215 │ │ │ │ │ +1216 dst[vValue].Clear(); │ │ │ │ │ +1217 if (vMask.GetNumFaceWeights() > 0) { │ │ │ │ │ +1218 assert(!vMask.AreFaceWeightsForFaceCenters()); │ │ │ │ │ +1219 │ │ │ │ │ +1220 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vFaces = level.getVertexFaces(vert); │ │ │ │ │ +1221 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y vInFace = level.getVertexFaceLocalIndices(vert); │ │ │ │ │ +1222 │ │ │ │ │ +1223 for (int i = 0; i < vFaces.size(); ++i) { │ │ │ │ │ +1224 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y faceValues = fvarChannel.getFaceValues(vFaces[i]); │ │ │ │ │ +1225 _L_o_c_a_l_I_n_d_e_x vOppInFace = vInFace[i] + 2; │ │ │ │ │ +1226 if (vOppInFace >= faceValues.size()) vOppInFace -= faceValues._s_i_z_e(); │ │ │ │ │ +1227 │ │ │ │ │ +1228 _I_n_d_e_x vValueOppositeFace = faceValues[vOppInFace]; │ │ │ │ │ +1229 │ │ │ │ │ +1230 dst[vValue].AddWithWeight(src[vValueOppositeFace], fWeights[i]); │ │ │ │ │ +1231 } │ │ │ │ │ +1232 } │ │ │ │ │ +1233 if (vMask.GetNumEdgeWeights() > 0) { │ │ │ │ │ +1234 _I_n_d_e_x * vEdgeValues = vEdgeBuffer; │ │ │ │ │ +1235 fvarChannel.getVertexEdgeValues(vert, vEdgeValues); │ │ │ │ │ +1236 │ │ │ │ │ +1237 for (int i = 0; i < vEdges.size(); ++i) { │ │ │ │ │ +1238 dst[vValue].AddWithWeight(src[vEdgeValues[i]], eWeights[i]); │ │ │ │ │ +1239 } │ │ │ │ │ +1240 } │ │ │ │ │ +1241 dst[vValue].AddWithWeight(src[vValue], vWeights[0]); │ │ │ │ │ +1242 } else { │ │ │ │ │ +1243 // │ │ │ │ │ +1244 // Sibling FVar values associated with a vertex will be either a corner or │ │ │ │ │ +a crease: │ │ │ │ │ +1245 // │ │ │ │ │ +1246 for (int i = 0; i < vValues.size(); ++i) { │ │ │ │ │ +1247 _V_t_r_:_:_I_n_d_e_x vValue = vValues[i]; │ │ │ │ │ +1248 │ │ │ │ │ +1249 dst[vValue].Clear(); │ │ │ │ │ +1250 if (fvarChannel.getValueTag(vValue).isCorner()) { │ │ │ │ │ +1251 dst[vValue].AddWithWeight(src[vValue], 1.0f); │ │ │ │ │ +1252 } else { │ │ │ │ │ +1253 _I_n_d_e_x vEndValues[2]; │ │ │ │ │ +1254 fvarChannel.getVertexCreaseEndValues(vert, i, vEndValues); │ │ │ │ │ +1255 │ │ │ │ │ +1256 dst[vValue].AddWithWeight(src[vEndValues[0]], 1.0f/6.0f); │ │ │ │ │ +1257 dst[vValue].AddWithWeight(src[vEndValues[1]], 1.0f/6.0f); │ │ │ │ │ +1258 dst[vValue].AddWithWeight(src[vValue], 2.0f/3.0f); │ │ │ │ │ +1259 } │ │ │ │ │ +1260 } │ │ │ │ │ +1261 } │ │ │ │ │ +1262 } │ │ │ │ │ +1263} │ │ │ │ │ +1264 │ │ │ │ │ +_1_2_6_5class _P_r_i_m_v_a_r_R_e_f_i_n_e_r : public _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l { │ │ │ │ │ +1266public: │ │ │ │ │ +_1_2_6_7 _P_r_i_m_v_a_r_R_e_f_i_n_e_r(_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner) │ │ │ │ │ +1268 : _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l(refiner) { } │ │ │ │ │ +1269}; │ │ │ │ │ +1270 │ │ │ │ │ +1271} // end namespace Far │ │ │ │ │ +1272 │ │ │ │ │ +1273} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +1274using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +1275} // end namespace OpenSubdiv │ │ │ │ │ +1276 │ │ │ │ │ +1277#endif /* OPENSUBDIV3_FAR_PRIMVAR_REFINER_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -Container for arrays of parametric patches. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_._h_:_5_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l │ │ │ │ │ -A specialized factory for StencilTable. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_C_r_e_a_t_e │ │ │ │ │ -static StencilTableReal< REAL > const * Create(TopologyRefiner const &refiner, │ │ │ │ │ -Options options=Options()) │ │ │ │ │ -Instantiates StencilTable from TopologyRefiner that have been refined uniformly │ │ │ │ │ -or adaptively. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static StencilTableReal< REAL > const * AppendLocalPointStencilTableFaceVarying │ │ │ │ │ -(TopologyRefiner const &refiner, StencilTableReal< REAL > const │ │ │ │ │ -*baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, int │ │ │ │ │ -channel=0, bool factorize=true) │ │ │ │ │ -Utility function for stencil splicing for local point face-varying stencils. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_M_o_d_e │ │ │ │ │ -Mode │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_I_N_T_E_R_P_O_L_A_T_E___F_A_C_E___V_A_R_Y_I_N_G │ │ │ │ │ -@ INTERPOLATE_FACE_VARYING │ │ │ │ │ -face-varying primvar stencils │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_I_N_T_E_R_P_O_L_A_T_E___V_A_R_Y_I_N_G │ │ │ │ │ -@ INTERPOLATE_VARYING │ │ │ │ │ -varying primvar stencils │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X │ │ │ │ │ -@ INTERPOLATE_VERTEX │ │ │ │ │ -vertex primvar stencils │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g │ │ │ │ │ -static StencilTableReal< REAL > const * AppendLocalPointStencilTableVarying │ │ │ │ │ -(TopologyRefiner const &refiner, StencilTableReal< REAL > const │ │ │ │ │ -*baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, bool │ │ │ │ │ -factorize=true) │ │ │ │ │ -Utility function for stencil splicing for local point varying stencils. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -static StencilTableReal< REAL > const * AppendLocalPointStencilTable │ │ │ │ │ -(TopologyRefiner const &refiner, StencilTableReal< REAL > const │ │ │ │ │ -*baseStencilTable, StencilTableReal< REAL > const *localPointStencilTable, bool │ │ │ │ │ -factorize=true) │ │ │ │ │ -Utility function for stencil splicing for local point stencils. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_C_r_e_a_t_e │ │ │ │ │ -static StencilTableReal< REAL > const * Create(int numTables, StencilTableReal< │ │ │ │ │ -REAL > const **tables) │ │ │ │ │ -Instantiates StencilTable by concatenating an array of existing stencil tables. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l │ │ │ │ │ -A specialized factory for LimitStencilTable. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_M_o_d_e │ │ │ │ │ -Mode │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_I_N_T_E_R_P_O_L_A_T_E___F_A_C_E___V_A_R_Y_I_N_G │ │ │ │ │ -@ INTERPOLATE_FACE_VARYING │ │ │ │ │ -face-varying primvar stencils │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_I_N_T_E_R_P_O_L_A_T_E___V_A_R_Y_I_N_G │ │ │ │ │ -@ INTERPOLATE_VARYING │ │ │ │ │ -varying primvar stencils │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_I_N_T_E_R_P_O_L_A_T_E___V_E_R_T_E_X │ │ │ │ │ -@ INTERPOLATE_VERTEX │ │ │ │ │ -vertex primvar stencils │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_L_o_c_a_t_i_o_n_A_r_r_a_y_V_e_c │ │ │ │ │ -std::vector< LocationArray > LocationArrayVec │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_4_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_C_r_e_a_t_e │ │ │ │ │ -static LimitStencilTableReal< REAL > const * Create(TopologyRefiner const │ │ │ │ │ -&refiner, LocationArrayVec const &locationArrays, StencilTableReal< REAL > │ │ │ │ │ -const *cvStencils=0, PatchTable const *patchTable=0, Options options=Options()) │ │ │ │ │ -Instantiates LimitStencilTable from a TopologyRefiner that has been refined │ │ │ │ │ -either uniformly or adapt... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ -Vertex stencil descriptor. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l │ │ │ │ │ -Vertex stencil class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ -Table of subdivision stencils. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_4_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -Stencil table class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ -Table of limit subdivision stencils. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_0_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -Limit stencil table class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_f_a_c_t_o_r_i_z_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s │ │ │ │ │ -unsigned int factorizeIntermediateLevels │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_:_m_a_x_L_e_v_e_l │ │ │ │ │ -unsigned int maxLevel │ │ │ │ │ -generate stencils up to 'maxLevel' │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_:_O_p_t_i_o_n_s │ │ │ │ │ -Options() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_6_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_I_n_t_e_r_m_e_d_i_a_t_e_L_e_v_e_l_s │ │ │ │ │ -unsigned int generateIntermediateLevels │ │ │ │ │ -vertices at all levels or highest only │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_C_o_n_t_r_o_l_V_e_r_t_s │ │ │ │ │ -unsigned int generateControlVerts │ │ │ │ │ -generate stencils for control-vertices │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_O_f_f_s_e_t_s │ │ │ │ │ -unsigned int generateOffsets │ │ │ │ │ -populate optional "_offsets" field │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_f_v_a_r_C_h_a_n_n_e_l │ │ │ │ │ -unsigned int fvarChannel │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e │ │ │ │ │ -unsigned int interpolationMode │ │ │ │ │ -interpolation mode │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_1_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_O_p_t_i_o_n_s │ │ │ │ │ -Options() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_f_v_a_r_C_h_a_n_n_e_l │ │ │ │ │ -unsigned int fvarChannel │ │ │ │ │ -face-varying channel to use │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_i_n_t_e_r_p_o_l_a_t_i_o_n_M_o_d_e │ │ │ │ │ -unsigned int interpolationMode │ │ │ │ │ -interpolation mode │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_2_n_d_D_e_r_i_v_a_t_i_v_e_s │ │ │ │ │ -unsigned int generate2ndDerivatives │ │ │ │ │ -Generate weights for 2nd derivatives. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_1_s_t_D_e_r_i_v_a_t_i_v_e_s │ │ │ │ │ -unsigned int generate1stDerivatives │ │ │ │ │ -Generate weights for 1st derivatives. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_2_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_L_o_c_a_t_i_o_n_A_r_r_a_y │ │ │ │ │ -Descriptor for limit surface locations. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_3_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_t │ │ │ │ │ -REAL const * t │ │ │ │ │ -array of v coordinates │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_4_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_s │ │ │ │ │ -REAL const * s │ │ │ │ │ -array of u coordinates │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_L_o_c_a_t_i_o_n_A_r_r_a_y │ │ │ │ │ -LocationArray() │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_3_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_n_u_m_L_o_c_a_t_i_o_n_s │ │ │ │ │ -int numLocations │ │ │ │ │ -number of (u,v) coordinates in the array │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_3_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l_:_: │ │ │ │ │ -_L_o_c_a_t_i_o_n_A_r_r_a_y_:_:_p_t_e_x_I_d_x │ │ │ │ │ -int ptexIdx │ │ │ │ │ -ptex face index │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ -Stencil table factory class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_8_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ -_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_V_a_r_y_i_n_g │ │ │ │ │ -static StencilTable const * AppendLocalPointStencilTableVarying(TopologyRefiner │ │ │ │ │ -const &refiner, StencilTable const *baseStencilTable, StencilTable const │ │ │ │ │ -*localPointStencilTable, bool factorize=true) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_2_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e │ │ │ │ │ -static StencilTable const * Create(TopologyRefiner const &refiner, Options │ │ │ │ │ -options=Options()) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_9_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ -_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static StencilTable const * AppendLocalPointStencilTableFaceVarying │ │ │ │ │ -(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, │ │ │ │ │ -StencilTable const *localPointStencilTable, int channel=0, bool factorize=true) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_3_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_: │ │ │ │ │ -_A_p_p_e_n_d_L_o_c_a_l_P_o_i_n_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -static StencilTable const * AppendLocalPointStencilTable(TopologyRefiner const │ │ │ │ │ -&refiner, StencilTable const *baseStencilTable, StencilTable const │ │ │ │ │ -*localPointStencilTable, bool factorize=true) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_0_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e │ │ │ │ │ -static StencilTable const * Create(int numTables, StencilTable const **tables) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ -Stencil table factory class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_5_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e │ │ │ │ │ -static LimitStencilTable const * Create(TopologyRefiner const &refiner, │ │ │ │ │ -LocationArrayVec const &locationArrays, StencilTable const *cvStencils=0, │ │ │ │ │ -PatchTable const *patchTable=0, Options options=Options()) │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_3_6_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_o_c_a_l_I_n_d_e_x │ │ │ │ │ +Vtr::LocalIndex LocalIndex │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_E_r_r_o_r │ │ │ │ │ +void Error(ErrorType err, const char *format,...) │ │ │ │ │ +Sends an OSD error with a message (internal use only) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +Vtr::ConstIndexArray ConstIndexArray │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +Vtr::ConstLocalIndexArray ConstLocalIndexArray │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_F_A_R___R_U_N_T_I_M_E___E_R_R_O_R │ │ │ │ │ +@ FAR_RUNTIME_ERROR │ │ │ │ │ +Issue a generic runtime error, but continue execution. │ │ │ │ │ +DDeeffiinniittiioonn _e_r_r_o_r_._h_:_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_I_n_d_e_x │ │ │ │ │ +Vtr::Index Index │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x │ │ │ │ │ +int Index │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d │ │ │ │ │ +bool IndexIsValid(Index index) │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_5_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R │ │ │ │ │ +@ SCHEME_BILINEAR │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_3_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K │ │ │ │ │ +@ SCHEME_CATMARK │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_3_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_C_H_E_M_E___L_O_O_P │ │ │ │ │ +@ SCHEME_LOOP │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l │ │ │ │ │ +Applies refinement operations to generic primvar data. │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_L_i_m_i_t │ │ │ │ │ +void Limit(T const &src, U &dstPos) const │ │ │ │ │ +Apply limit weights to a primvar buffer. │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_3_1_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l │ │ │ │ │ +PrimvarRefinerReal(TopologyRefiner const &refiner) │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_5_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_L_i_m_i_t │ │ │ │ │ +void Limit(T const &src, U &dstPos, U1 &dstTan1, U2 &dstTan2) const │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_3_4_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_U_n_i_f_o_r_m │ │ │ │ │ +void InterpolateFaceUniform(int level, T const &src, U &dst) const │ │ │ │ │ +Refine uniform (per-face) primvar data between levels. │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_3_9_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_G_e_t_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ +TopologyRefiner const & GetTopologyRefiner() const │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_I_n_t_e_r_p_o_l_a_t_e_V_a_r_y_i_n_g │ │ │ │ │ +void InterpolateVarying(int level, T const &src, U &dst) const │ │ │ │ │ +Apply only varying interpolation weights to a primvar buffer for a single level │ │ │ │ │ +of refinement. │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_4_1_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_I_n_t_e_r_p_o_l_a_t_e │ │ │ │ │ +void Interpolate(int level, T const &src, U &dst) const │ │ │ │ │ +Apply vertex interpolation weights to a primvar buffer for a single level of │ │ │ │ │ +refinement. │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_2_6_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +void InterpolateFaceVarying(int level, T const &src, U &dst, int channel=0) │ │ │ │ │ +const │ │ │ │ │ +Apply face-varying interpolation weights to a primvar buffer associated with a │ │ │ │ │ +particular face-varyin... │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_2_9_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_~_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l │ │ │ │ │ +~PrimvarRefinerReal() │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_6_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_L_i_m_i_t_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +void LimitFaceVarying(T const &src, U &dst, int channel=0) const │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_3_6_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_1_2_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r │ │ │ │ │ +PrimvarRefiner(TopologyRefiner const &refiner) │ │ │ │ │ +DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_1_2_6_7 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ Stores topology data for a specified set of refinement options. │ │ │ │ │ DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ +Rule │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E │ │ │ │ │ +@ RULE_CREASE │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e │ │ │ │ │ +Scheme is a class template which provides all implementation for the │ │ │ │ │ +subdivision schemes supported by... │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y │ │ │ │ │ +DDeeffiinniittiioonn _a_r_r_a_y_._h_:_5_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y_:_:_s_i_z_e │ │ │ │ │ +size_type size() const │ │ │ │ │ +DDeeffiinniittiioonn _a_r_r_a_y_._h_:_7_2 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h │ │ │ │ │ + * _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00722.html │ │ │ │ @@ -94,15 +94,15 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
ptexIndices.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/topologyRefiner.h"
│ │ │ │ +#include "../far/topologyRefiner.h"
│ │ │ │ #include "../far/types.h"
│ │ │ │ #include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00722_source.html │ │ │ │ @@ -172,23 +172,23 @@ │ │ │ │
100} // end namespace Far
│ │ │ │
101
│ │ │ │
102} // end namespace OPENSUBDIV_VERSION
│ │ │ │
103using namespace OPENSUBDIV_VERSION;
│ │ │ │
104} // end namespace OpenSubdiv
│ │ │ │
105
│ │ │ │
106#endif /* OPENSUBDIV3_FAR_PTEX_INDICES_H */
│ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │
Object used to compute and query ptex face indices.
Definition ptexIndices.h:46
│ │ │ │
int GetFaceId(Index f) const
Returns the ptex face index given a coarse face 'f' or -1.
│ │ │ │
PtexIndices(TopologyRefiner const &refiner)
Constructor.
│ │ │ │
void GetAdjacency(TopologyRefiner const &refiner, int face, int quadrant, int adjFaces[4], int adjEdges[4]) const
Returns ptex face adjacency information for a given coarse face.
│ │ │ │
int GetNumFaces() const
Returns the number of ptex faces in the mesh.
│ │ │ │ │ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
patchTableFactory.h File Reference
│ │ │ │ +
stencilTable.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/topologyRefiner.h"
│ │ │ │ -#include "../far/patchTable.h"
│ │ │ │ +#include "../far/types.h"
│ │ │ │ +#include <cassert>
│ │ │ │ +#include <cstring>
│ │ │ │ +#include <vector>
│ │ │ │ +#include <iostream>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  PatchTableFactory
 Factory for constructing a PatchTable from a TopologyRefiner. More...
class  StencilReal< REAL >
 Vertex stencil descriptor. More...
 
struct  PatchTableFactory::Options
 Public options for the PatchTable factory. More...
class  Stencil
 Vertex stencil class wrapping the template for compatibility. More...
 
struct  PatchTableFactory::PatchFaceTag
 Obsolete internal struct not intended for public use – due to be deprecated. More...
class  StencilTableReal< REAL >
 Table of subdivision stencils. More...
 
class  StencilTable
 Stencil table class wrapping the template for compatibility. More...
 
class  LimitStencilReal< REAL >
 Limit point stencil descriptor. More...
 
class  LimitStencil
 Limit point stencil class wrapping the template for compatibility. More...
 
class  LimitStencilTableReal< REAL >
 Table of limit subdivision stencils. More...
 
class  LimitStencilTable
 Limit stencil table class wrapping the template for compatibility. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -125,13 +143,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,32 +1,51 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -patchTableFactory.h File Reference │ │ │ │ │ +stencilTable.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_f_a_r_/_t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h" │ │ │ │ │ -#include "_._._/_f_a_r_/_p_a_t_c_h_T_a_b_l_e_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_t_y_p_e_s_._h" │ │ │ │ │ +#include │ │ │ │ │ +#include │ │ │ │ │ +#include │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ - class   _P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ -  Factory for constructing a _P_a_t_c_h_T_a_b_l_e from a _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r. _M_o_r_e_._._. │ │ │ │ │ +class   _S_t_e_n_c_i_l_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ +  Vertex stencil descriptor. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -struct   _P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s │ │ │ │ │ -  Public options for the _P_a_t_c_h_T_a_b_l_e factory. _M_o_r_e_._._. │ │ │ │ │ +class   _S_t_e_n_c_i_l │ │ │ │ │ +  Vertex stencil class wrapping the template for compatibility. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -struct   _P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g │ │ │ │ │ -  Obsolete internal struct not intended for public use – due to be │ │ │ │ │ - deprecated. _M_o_r_e_._._. │ │ │ │ │ +class   _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ +  Table of subdivision stencils. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +class   _S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +  _S_t_e_n_c_i_l table class wrapping the template for compatibility. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +class   _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ +  Limit point stencil descriptor. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +class   _L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ +  Limit point stencil class wrapping the template for compatibility. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +class   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ +  Table of limit subdivision stencils. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +class   _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +  Limit stencil table class wrapping the template for compatibility. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h │ │ │ │ │ + * _s_t_e_n_c_i_l_T_a_b_l_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00725.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,5 +1,10 @@ │ │ │ │ │ var a00725 = [ │ │ │ │ │ - ["PatchTableFactory", "a01017.html", "a01017"], │ │ │ │ │ - ["Options", "a01021.html", "a01021"], │ │ │ │ │ - ["PatchFaceTag", "a01025.html", "a01025"] │ │ │ │ │ + ["StencilReal< REAL >", "a01053.html", "a01053"], │ │ │ │ │ + ["Stencil", "a01057.html", "a01057"], │ │ │ │ │ + ["StencilTableReal< REAL >", "a01061.html", "a01061"], │ │ │ │ │ + ["StencilTable", "a01065.html", "a01065"], │ │ │ │ │ + ["LimitStencilReal< REAL >", "a01069.html", "a01069"], │ │ │ │ │ + ["LimitStencil", "a01073.html", "a01073"], │ │ │ │ │ + ["LimitStencilTableReal< REAL >", "a01077.html", "a01077"], │ │ │ │ │ + ["LimitStencilTable", "a01081.html", "a01081"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00725_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/patchTableFactory.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/far/stencilTable.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
patchTableFactory.h
│ │ │ │ +
stencilTable.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,249 +119,892 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H
│ │ │ │ -
26#define OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_FAR_STENCILTABLE_H
│ │ │ │ +
26#define OPENSUBDIV3_FAR_STENCILTABLE_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │
29
│ │ │ │ -
30#include "../far/topologyRefiner.h"
│ │ │ │ -
31#include "../far/patchTable.h"
│ │ │ │ -
32
│ │ │ │ -
33namespace OpenSubdiv {
│ │ │ │ -
34namespace OPENSUBDIV_VERSION {
│ │ │ │ -
35
│ │ │ │ -
36namespace Far {
│ │ │ │ -
37
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
41public:
│ │ │ │ -
42
│ │ │ │ -
│ │ │ │ -
45 struct Options {
│ │ │ │ -
46
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
61 };
│ │ │ │ -
│ │ │ │ -
62
│ │ │ │ -
│ │ │ │ -
63 Options(unsigned int maxIsolation=10) :
│ │ │ │ -
64 generateAllLevels(false),
│ │ │ │ - │ │ │ │ - │ │ │ │ -
67 triangulateQuads(false),
│ │ │ │ - │ │ │ │ -
69 useInfSharpPatch(false),
│ │ │ │ -
70 maxIsolationLevel(maxIsolation & 0xf),
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
75 generateFVarTables(false),
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
82 { }
│ │ │ │ +
30#include "../far/types.h"
│ │ │ │ +
31
│ │ │ │ +
32#include <cassert>
│ │ │ │ +
33#include <cstring>
│ │ │ │ +
34#include <vector>
│ │ │ │ +
35#include <iostream>
│ │ │ │ +
36
│ │ │ │ +
37namespace OpenSubdiv {
│ │ │ │ +
38namespace OPENSUBDIV_VERSION {
│ │ │ │ +
39
│ │ │ │ +
40namespace Far {
│ │ │ │ +
41
│ │ │ │ +
42// Forward declarations for friends:
│ │ │ │ +
43class PatchTableBuilder;
│ │ │ │ +
44
│ │ │ │ +
45template <typename REAL> class StencilTableFactoryReal;
│ │ │ │ +
46template <typename REAL> class LimitStencilTableFactoryReal;
│ │ │ │ +
47
│ │ │ │ +
52template <typename REAL>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
54public:
│ │ │ │ +
55
│ │ │ │ + │ │ │ │ +
58
│ │ │ │ +
│ │ │ │ +
67 StencilReal(int * size, Index * indices, REAL * weights)
│ │ │ │ +
68 : _size(size), _indices(indices), _weights(weights) { }
│ │ │ │ +
│ │ │ │ +
69
│ │ │ │ +
│ │ │ │ +
71 StencilReal(StencilReal const & other) {
│ │ │ │ +
72 _size = other._size;
│ │ │ │ +
73 _indices = other._indices;
│ │ │ │ +
74 _weights = other._weights;
│ │ │ │ +
75 }
│ │ │ │ +
│ │ │ │ +
76
│ │ │ │ +
│ │ │ │ +
78 int GetSize() const {
│ │ │ │ +
79 return *_size;
│ │ │ │ +
80 }
│ │ │ │ +
│ │ │ │ +
81
│ │ │ │ +
│ │ │ │ +
83 int * GetSizePtr() const {
│ │ │ │ +
84 return _size;
│ │ │ │ +
85 }
│ │ │ │
│ │ │ │ -
83
│ │ │ │ - │ │ │ │
86
│ │ │ │ -
88 void SetEndCapType(EndCapType e) { endCapType = e & 0x7; }
│ │ │ │ -
89
│ │ │ │ -
91 void SetMaxIsolationLevel(unsigned int level) { maxIsolationLevel = level & 0xf; }
│ │ │ │ -
92
│ │ │ │ -
94 template <typename REAL> void SetPatchPrecision();
│ │ │ │ -
95
│ │ │ │ -
97 template <typename REAL> void SetFVarPatchPrecision();
│ │ │ │ -
98
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ -
102
│ │ │ │ -
103 adaptiveOptions.useInfSharpPatch = useInfSharpPatch;
│ │ │ │ - │ │ │ │ -
105 adaptiveOptions.considerFVarChannels = generateFVarTables &&
│ │ │ │ - │ │ │ │ -
107 return adaptiveOptions;
│ │ │ │ -
108 }
│ │ │ │ -
│ │ │ │ -
109
│ │ │ │ -
110 unsigned int generateAllLevels : 1,
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
114
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
118
│ │ │ │ -
119 // end-capping
│ │ │ │ - │ │ │ │ - │ │ │ │ -
123
│ │ │ │ -
124 // varying
│ │ │ │ - │ │ │ │ - │ │ │ │ +
│ │ │ │ +
88 Index const * GetVertexIndices() const {
│ │ │ │ +
89 return _indices;
│ │ │ │ +
90 }
│ │ │ │ +
│ │ │ │ +
91
│ │ │ │ +
│ │ │ │ +
93 REAL const * GetWeights() const {
│ │ │ │ +
94 return _weights;
│ │ │ │ +
95 }
│ │ │ │ +
│ │ │ │ +
96
│ │ │ │ +
98 void Next() {
│ │ │ │ +
99 int stride = *_size;
│ │ │ │ +
100 ++_size;
│ │ │ │ +
101 _indices += stride;
│ │ │ │ +
102 _weights += stride;
│ │ │ │ +
103 }
│ │ │ │ +
104
│ │ │ │ +
105protected:
│ │ │ │ +
106 friend class StencilTableFactoryReal<REAL>;
│ │ │ │ +
107 friend class LimitStencilTableFactoryReal<REAL>;
│ │ │ │ +
108
│ │ │ │ +
109 int * _size;
│ │ │ │ + │ │ │ │ +
111 REAL * _weights;
│ │ │ │ +
112};
│ │ │ │ +
│ │ │ │ +
113
│ │ │ │ +
│ │ │ │ +
116class Stencil : public StencilReal<float> {
│ │ │ │ +
117protected:
│ │ │ │ + │ │ │ │ +
119
│ │ │ │ +
120public:
│ │ │ │ + │ │ │ │ +
122 Stencil(BaseStencil const & other) : BaseStencil(other) { }
│ │ │ │ +
│ │ │ │ +
123 Stencil(int * size, Index * indices, float * weights)
│ │ │ │ +
124 : BaseStencil(size, indices, weights) { }
│ │ │ │ +
│ │ │ │ +
125};
│ │ │ │ +
│ │ │ │ +
126
│ │ │ │
127
│ │ │ │ -
128 // face-varying
│ │ │ │ - │ │ │ │ -
130
│ │ │ │ -
131 // precision
│ │ │ │ - │ │ │ │ - │ │ │ │ -
134
│ │ │ │ -
135 // legacy behaviors (default to true)
│ │ │ │ - │ │ │ │ - │ │ │ │ -
138
│ │ │ │ - │ │ │ │ -
140 int const * fvarChannelIndices;
│ │ │ │ -
141 };
│ │ │ │ -
│ │ │ │ -
142
│ │ │ │ -
175 static PatchTable * Create(TopologyRefiner const & refiner,
│ │ │ │ -
176 Options options = Options(),
│ │ │ │ -
177 ConstIndexArray selectedFaces = ConstIndexArray());
│ │ │ │ -
178
│ │ │ │ -
179public:
│ │ │ │ -
180 // PatchFaceTag
│ │ │ │ -
181 //
│ │ │ │ -
182 // This simple struct was previously used within the factory to take inventory of
│ │ │ │ -
183 // various kinds of patches to fully allocate buffers prior to populating them. It
│ │ │ │ -
184 // was not intended to be exposed as part of the public interface.
│ │ │ │ -
185 //
│ │ │ │ -
186 // It is no longer used internally and is being kept here to respect preservation
│ │ │ │ -
187 // of the public interface, but it will be deprecated at the earliest opportunity.
│ │ │ │ -
188 //
│ │ │ │ -
191 //
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
193 public:
│ │ │ │ -
194 unsigned int _hasPatch : 1;
│ │ │ │ -
195 unsigned int _isRegular : 1;
│ │ │ │ -
196 unsigned int _transitionMask : 4;
│ │ │ │ -
197 unsigned int _boundaryMask : 4;
│ │ │ │ -
198 unsigned int _boundaryIndex : 2;
│ │ │ │ -
199 unsigned int _boundaryCount : 3;
│ │ │ │ -
200 unsigned int _hasBoundaryEdge : 3;
│ │ │ │ -
201 unsigned int _isSingleCrease : 1;
│ │ │ │ -
202
│ │ │ │ -
203 void clear();
│ │ │ │ -
204 void assignBoundaryPropertiesFromEdgeMask(int boundaryEdgeMask);
│ │ │ │ -
205 void assignBoundaryPropertiesFromVertexMask(int boundaryVertexMask);
│ │ │ │ -
206 void assignTransitionPropertiesFromEdgeMask(int boundaryVertexMask);
│ │ │ │ -
207 };
│ │ │ │ -
│ │ │ │ -
208 typedef std::vector<PatchFaceTag> PatchTagVector;
│ │ │ │ -
209};
│ │ │ │ -
│ │ │ │ -
210
│ │ │ │ -
211
│ │ │ │ -
│ │ │ │ -
212template <> inline void PatchTableFactory::Options::SetPatchPrecision<float>() {
│ │ │ │ -
213 patchPrecisionDouble = false;
│ │ │ │ -
214}
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
215template <> inline void PatchTableFactory::Options::SetFVarPatchPrecision<float>() {
│ │ │ │ -
216 fvarPatchPrecisionDouble = false;
│ │ │ │ -
217}
│ │ │ │ -
│ │ │ │ -
218
│ │ │ │ -
219template <> inline void PatchTableFactory::Options::SetPatchPrecision<double>() {
│ │ │ │ -
220 patchPrecisionDouble = true;
│ │ │ │ -
221}
│ │ │ │ -
222template <> inline void PatchTableFactory::Options::SetFVarPatchPrecision<double>() {
│ │ │ │ -
223 fvarPatchPrecisionDouble = true;
│ │ │ │ -
224}
│ │ │ │ +
140template <typename REAL>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
142protected:
│ │ │ │ +
143 StencilTableReal(int numControlVerts,
│ │ │ │ +
144 std::vector<int> const& offsets,
│ │ │ │ +
145 std::vector<int> const& sizes,
│ │ │ │ +
146 std::vector<int> const& sources,
│ │ │ │ +
147 std::vector<REAL> const& weights,
│ │ │ │ +
148 bool includeCoarseVerts,
│ │ │ │ +
149 size_t firstOffset);
│ │ │ │ +
150
│ │ │ │ +
151public:
│ │ │ │ +
152
│ │ │ │ +
153 virtual ~StencilTableReal() {};
│ │ │ │ +
154
│ │ │ │ +
│ │ │ │ +
156 int GetNumStencils() const {
│ │ │ │ +
157 return (int)_sizes.size();
│ │ │ │ +
158 }
│ │ │ │ +
│ │ │ │ +
159
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
162 return _numControlVertices;
│ │ │ │ +
163 }
│ │ │ │ +
│ │ │ │ +
164
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
167
│ │ │ │ +
│ │ │ │ +
169 std::vector<int> const & GetSizes() const {
│ │ │ │ +
170 return _sizes;
│ │ │ │ +
171 }
│ │ │ │ +
│ │ │ │ +
172
│ │ │ │ +
│ │ │ │ +
174 std::vector<Index> const & GetOffsets() const {
│ │ │ │ +
175 return _offsets;
│ │ │ │ +
176 }
│ │ │ │ +
│ │ │ │ +
177
│ │ │ │ +
│ │ │ │ +
179 std::vector<Index> const & GetControlIndices() const {
│ │ │ │ +
180 return _indices;
│ │ │ │ +
181 }
│ │ │ │ +
│ │ │ │ +
182
│ │ │ │ +
│ │ │ │ +
184 std::vector<REAL> const & GetWeights() const {
│ │ │ │ +
185 return _weights;
│ │ │ │ +
186 }
│ │ │ │ +
│ │ │ │ +
187
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
190
│ │ │ │ +
204 template <class T, class U>
│ │ │ │ +
│ │ │ │ +
205 void UpdateValues(T const &srcValues, U &dstValues, Index start=-1, Index end=-1) const {
│ │ │ │ +
206 this->update(srcValues, dstValues, _weights, start, end);
│ │ │ │ +
207 }
│ │ │ │ +
│ │ │ │ +
208
│ │ │ │ +
209 template <class T1, class T2, class U>
│ │ │ │ +
│ │ │ │ +
210 void UpdateValues(T1 const &srcBase, int numBase, T2 const &srcRef,
│ │ │ │ +
211 U &dstValues, Index start=-1, Index end=-1) const {
│ │ │ │ +
212 this->update(srcBase, numBase, srcRef, dstValues, _weights, start, end);
│ │ │ │ +
213 }
│ │ │ │ +
│ │ │ │ +
214
│ │ │ │ +
215 // Pointer interface for backward compatibility
│ │ │ │ +
216 template <class T, class U>
│ │ │ │ +
│ │ │ │ +
217 void UpdateValues(T const *src, U *dst, Index start=-1, Index end=-1) const {
│ │ │ │ +
218 this->update(src, dst, _weights, start, end);
│ │ │ │ +
219 }
│ │ │ │ +
│ │ │ │ +
220 template <class T1, class T2, class U>
│ │ │ │ +
│ │ │ │ +
221 void UpdateValues(T1 const *srcBase, int numBase, T2 const *srcRef,
│ │ │ │ +
222 U *dst, Index start=-1, Index end=-1) const {
│ │ │ │ +
223 this->update(srcBase, numBase, srcRef, dst, _weights, start, end);
│ │ │ │ +
224 }
│ │ │ │ +
│ │ │ │
225
│ │ │ │ -
226
│ │ │ │ -
227} // end namespace Far
│ │ │ │ +
227 void Clear();
│ │ │ │
228
│ │ │ │ -
229} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
230using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
231
│ │ │ │ -
232} // end namespace OpenSubdiv
│ │ │ │ -
233
│ │ │ │ -
234
│ │ │ │ -
235#endif /* OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H */
│ │ │ │ - │ │ │ │ -
Vtr::ConstIndexArray ConstIndexArray
Definition types.h:47
│ │ │ │ -
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ -
Factory for constructing a PatchTable from a TopologyRefiner.
│ │ │ │ - │ │ │ │ -
static PatchTable * Create(TopologyRefiner const &refiner, Options options=Options(), ConstIndexArray selectedFaces=ConstIndexArray())
Instantiates a PatchTable from a client-provided TopologyRefiner.
│ │ │ │ - │ │ │ │ -
unsigned int generateVaryingTables
Generate varying patch tables.
│ │ │ │ -
unsigned int generateLegacySharpCornerPatches
Generate sharp regular patches at smooth corners (legacy)
│ │ │ │ - │ │ │ │ -
TopologyRefiner::AdaptiveOptions GetRefineAdaptiveOptions() const
Determine adaptive refinement options to match assigned patch options.
│ │ │ │ -
unsigned int maxIsolationLevel
Cap adaptive feature isolation to the given level (max. 10)
│ │ │ │ - │ │ │ │ -
unsigned int generateFVarLegacyLinearPatches
Generate all linear face-varying patches (legacy)
│ │ │ │ -
void SetPatchPrecision()
Set precision of vertex patches.
│ │ │ │ -
unsigned int fvarPatchPrecisionDouble
Generate double-precision stencils for face-varying patches.
│ │ │ │ -
void SetMaxIsolationLevel(unsigned int level)
Set maximum isolation level.
│ │ │ │ - │ │ │ │ -
int const * fvarChannelIndices
List containing the indices of the channels selected for the factory.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
unsigned int generateVaryingLocalPoints
Generate local points with varying patches.
│ │ │ │ -
unsigned int includeFVarBaseLevelIndices
Include base level in face-varying patch point indices (Uniform mode only)
│ │ │ │ -
unsigned int generateAllLevels
Generate levels from 'firstLevel' to 'maxLevel' (Uniform mode only)
│ │ │ │ -
unsigned int patchPrecisionDouble
Generate double-precision stencils for vertex patches.
│ │ │ │ -
unsigned int generateFVarTables
Generate face-varying patch tables.
│ │ │ │ -
unsigned int includeBaseLevelIndices
Include base level in patch point indices (Uniform mode only)
│ │ │ │ -
void SetFVarPatchPrecision()
Set precision of face-varying patches.
│ │ │ │ -
int numFVarChannels
Number of channel indices and interpolation modes passed.
│ │ │ │ -
unsigned int triangulateQuads
Triangulate 'QUADS' primitives (Uniform mode only)
│ │ │ │ -
EndCapType
Choice for approximating irregular patches (end-caps)
│ │ │ │ -
@ ENDCAP_LEGACY_GREGORY
legacy option for 2.x style Gregory patches (Catmark only)
│ │ │ │ -
@ ENDCAP_GREGORY_BASIS
use Gregory patches (highest quality, recommended default)
│ │ │ │ - │ │ │ │ -
@ ENDCAP_BILINEAR_BASIS
use linear patches (simple quads or tris)
│ │ │ │ -
@ ENDCAP_BSPLINE_BASIS
use BSpline-like patches (same patch type as regular)
│ │ │ │ - │ │ │ │ -
Obsolete internal struct not intended for public use – due to be deprecated.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ +
229protected:
│ │ │ │ +
230
│ │ │ │ +
231 // Update values by applying cached stencil weights to new control values
│ │ │ │ +
232 template <class T, class U>
│ │ │ │ +
│ │ │ │ +
233 void update( T const &srcValues, U &dstValues,
│ │ │ │ +
234 std::vector<REAL> const & valueWeights, Index start, Index end) const;
│ │ │ │ +
235 template <class T1, class T2, class U>
│ │ │ │ +
│ │ │ │ +
236 void update( T1 const &srcBase, int numBase, T2 const &srcRef, U &dstValues,
│ │ │ │ +
237 std::vector<REAL> const & valueWeights, Index start, Index end) const;
│ │ │ │ +
238
│ │ │ │ +
239 // Populate the offsets table from the stencil sizes in _sizes (factory helper)
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
241
│ │ │ │ +
242 // Resize the table arrays (factory helper)
│ │ │ │ +
│ │ │ │ +
243 void resize(int nstencils, int nelems);
│ │ │ │ +
244
│ │ │ │ +
245 // Reserves the table arrays (factory helper)
│ │ │ │ +
│ │ │ │ +
246 void reserve(int nstencils, int nelems);
│ │ │ │ +
247
│ │ │ │ +
248 // Reallocates the table arrays to remove excess capacity (factory helper)
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
250
│ │ │ │ +
251 // Performs any final operations on internal tables (factory helper)
│ │ │ │ +
│ │ │ │ +
252 void finalize();
│ │ │ │ +
253
│ │ │ │ +
254protected:
│ │ │ │ + │ │ │ │ +
256 StencilTableReal(int numControlVerts)
│ │ │ │ +
257 : _numControlVertices(numControlVerts)
│ │ │ │ +
258 { }
│ │ │ │ +
259
│ │ │ │ +
260 friend class StencilTableFactoryReal<REAL>;
│ │ │ │ + │ │ │ │ +
262
│ │ │ │ +
263 int _numControlVertices; // number of control vertices
│ │ │ │ +
264
│ │ │ │ +
265 std::vector<int> _sizes; // number of coefficients for each stencil
│ │ │ │ +
266 std::vector<Index> _offsets, // offset to the start of each stencil
│ │ │ │ +
267 _indices; // indices of contributing coarse vertices
│ │ │ │ +
268 std::vector<REAL> _weights; // stencil weight coefficients
│ │ │ │ +
269};
│ │ │ │ +
270
│ │ │ │ +
│ │ │ │ +
273class StencilTable : public StencilTableReal<float> {
│ │ │ │ +
274protected:
│ │ │ │ + │ │ │ │ +
276
│ │ │ │ +
277public:
│ │ │ │ +
│ │ │ │ +
278 Stencil GetStencil(Index index) const {
│ │ │ │ +
279 return Stencil(BaseTable::GetStencil(index));
│ │ │ │ +
280 }
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
281 Stencil operator[] (Index index) const {
│ │ │ │ +
282 return Stencil(BaseTable::GetStencil(index));
│ │ │ │ +
283 }
│ │ │ │ +
│ │ │ │ +
284
│ │ │ │ +
285protected:
│ │ │ │ + │ │ │ │ +
287 StencilTable(int numControlVerts) : BaseTable(numControlVerts) { }
│ │ │ │ +
│ │ │ │ +
288 StencilTable(int numControlVerts,
│ │ │ │ +
289 std::vector<int> const& offsets,
│ │ │ │ +
290 std::vector<int> const& sizes,
│ │ │ │ +
291 std::vector<int> const& sources,
│ │ │ │ +
292 std::vector<float> const& weights,
│ │ │ │ +
293 bool includeCoarseVerts,
│ │ │ │ +
294 size_t firstOffset)
│ │ │ │ +
295 : BaseTable(numControlVerts, offsets,
│ │ │ │ +
296 sizes, sources, weights, includeCoarseVerts, firstOffset) { }
│ │ │ │ +
│ │ │ │ +
297};
│ │ │ │ +
│ │ │ │ +
298
│ │ │ │ +
299
│ │ │ │ +
302template <typename REAL>
│ │ │ │ +
│ │ │ │ +
303class LimitStencilReal : public StencilReal<REAL> {
│ │ │ │ +
304public:
│ │ │ │ +
305
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
325 Index * indices,
│ │ │ │ +
326 REAL * weights,
│ │ │ │ +
327 REAL * duWeights=0,
│ │ │ │ +
328 REAL * dvWeights=0,
│ │ │ │ +
329 REAL * duuWeights=0,
│ │ │ │ +
330 REAL * duvWeights=0,
│ │ │ │ +
331 REAL * dvvWeights=0)
│ │ │ │ +
332 : StencilReal<REAL>(size, indices, weights),
│ │ │ │ +
333 _duWeights(duWeights),
│ │ │ │ +
334 _dvWeights(dvWeights),
│ │ │ │ +
335 _duuWeights(duuWeights),
│ │ │ │ +
336 _duvWeights(duvWeights),
│ │ │ │ +
337 _dvvWeights(dvvWeights) {
│ │ │ │ +
338 }
│ │ │ │ +
│ │ │ │ +
339
│ │ │ │ +
│ │ │ │ +
341 REAL const * GetDuWeights() const {
│ │ │ │ +
342 return _duWeights;
│ │ │ │ +
343 }
│ │ │ │ +
│ │ │ │ +
344
│ │ │ │ +
│ │ │ │ +
346 REAL const * GetDvWeights() const {
│ │ │ │ +
347 return _dvWeights;
│ │ │ │ +
348 }
│ │ │ │ +
│ │ │ │ +
349
│ │ │ │ +
│ │ │ │ +
351 REAL const * GetDuuWeights() const {
│ │ │ │ +
352 return _duuWeights;
│ │ │ │ +
353 }
│ │ │ │ +
│ │ │ │ +
354
│ │ │ │ +
│ │ │ │ +
356 REAL const * GetDuvWeights() const {
│ │ │ │ +
357 return _duvWeights;
│ │ │ │ +
358 }
│ │ │ │ +
│ │ │ │ +
359
│ │ │ │ +
│ │ │ │ +
361 REAL const * GetDvvWeights() const {
│ │ │ │ +
362 return _dvvWeights;
│ │ │ │ +
363 }
│ │ │ │ +
│ │ │ │ +
364
│ │ │ │ +
366 void Next() {
│ │ │ │ +
367 int stride = *this->_size;
│ │ │ │ +
368 ++this->_size;
│ │ │ │ +
369 this->_indices += stride;
│ │ │ │ +
370 this->_weights += stride;
│ │ │ │ +
371 if (_duWeights) _duWeights += stride;
│ │ │ │ +
372 if (_dvWeights) _dvWeights += stride;
│ │ │ │ +
373 if (_duuWeights) _duuWeights += stride;
│ │ │ │ +
374 if (_duvWeights) _duvWeights += stride;
│ │ │ │ +
375 if (_dvvWeights) _dvvWeights += stride;
│ │ │ │ +
376 }
│ │ │ │ +
377
│ │ │ │ +
378private:
│ │ │ │ +
379
│ │ │ │ +
380 friend class StencilTableFactoryReal<REAL>;
│ │ │ │ +
381 friend class LimitStencilTableFactoryReal<REAL>;
│ │ │ │ +
382
│ │ │ │ +
383 REAL * _duWeights, // pointer to stencil u derivative limit weights
│ │ │ │ +
384 * _dvWeights, // pointer to stencil v derivative limit weights
│ │ │ │ +
385 * _duuWeights, // pointer to stencil uu derivative limit weights
│ │ │ │ +
386 * _duvWeights, // pointer to stencil uv derivative limit weights
│ │ │ │ +
387 * _dvvWeights; // pointer to stencil vv derivative limit weights
│ │ │ │ +
388};
│ │ │ │ +
│ │ │ │ +
389
│ │ │ │ +
│ │ │ │ +
392class LimitStencil : public LimitStencilReal<float> {
│ │ │ │ +
393protected:
│ │ │ │ + │ │ │ │ +
395
│ │ │ │ +
396public:
│ │ │ │ +
397 LimitStencil(BaseStencil const & other) : BaseStencil(other) { }
│ │ │ │ +
│ │ │ │ +
398 LimitStencil(int* size, Index * indices, float * weights,
│ │ │ │ +
399 float * duWeights=0, float * dvWeights=0,
│ │ │ │ +
400 float * duuWeights=0, float * duvWeights=0, float * dvvWeights=0)
│ │ │ │ +
401 : BaseStencil(size, indices, weights,
│ │ │ │ +
402 duWeights, dvWeights, duuWeights, duvWeights, dvvWeights) { }
│ │ │ │ +
│ │ │ │ +
403};
│ │ │ │ +
│ │ │ │ +
404
│ │ │ │ +
405
│ │ │ │ +
408template <typename REAL>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
410protected:
│ │ │ │ + │ │ │ │ +
412 int numControlVerts,
│ │ │ │ +
413 std::vector<int> const& offsets,
│ │ │ │ +
414 std::vector<int> const& sizes,
│ │ │ │ +
415 std::vector<int> const& sources,
│ │ │ │ +
416 std::vector<REAL> const& weights,
│ │ │ │ +
417 std::vector<REAL> const& duWeights,
│ │ │ │ +
418 std::vector<REAL> const& dvWeights,
│ │ │ │ +
419 std::vector<REAL> const& duuWeights,
│ │ │ │ +
420 std::vector<REAL> const& duvWeights,
│ │ │ │ +
421 std::vector<REAL> const& dvvWeights,
│ │ │ │ +
422 bool includeCoarseVerts,
│ │ │ │ +
423 size_t firstOffset);
│ │ │ │ +
424
│ │ │ │ +
425public:
│ │ │ │ +
426
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
429
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
432
│ │ │ │ +
│ │ │ │ +
434 std::vector<REAL> const & GetDuWeights() const {
│ │ │ │ +
435 return _duWeights;
│ │ │ │ +
436 }
│ │ │ │ +
│ │ │ │ +
437
│ │ │ │ +
│ │ │ │ +
439 std::vector<REAL> const & GetDvWeights() const {
│ │ │ │ +
440 return _dvWeights;
│ │ │ │ +
441 }
│ │ │ │ +
│ │ │ │ +
442
│ │ │ │ +
│ │ │ │ +
444 std::vector<REAL> const & GetDuuWeights() const {
│ │ │ │ +
445 return _duuWeights;
│ │ │ │ +
446 }
│ │ │ │ +
│ │ │ │ +
447
│ │ │ │ +
│ │ │ │ +
449 std::vector<REAL> const & GetDuvWeights() const {
│ │ │ │ +
450 return _duvWeights;
│ │ │ │ +
451 }
│ │ │ │ +
│ │ │ │ +
452
│ │ │ │ +
│ │ │ │ +
454 std::vector<REAL> const & GetDvvWeights() const {
│ │ │ │ +
455 return _dvvWeights;
│ │ │ │ +
456 }
│ │ │ │ +
│ │ │ │ +
457
│ │ │ │ +
475 template <class T, class U>
│ │ │ │ +
│ │ │ │ +
476 void UpdateDerivs(T const & srcValues, U & uderivs, U & vderivs,
│ │ │ │ +
477 int start=-1, int end=-1) const {
│ │ │ │ +
478
│ │ │ │ +
479 this->update(srcValues, uderivs, _duWeights, start, end);
│ │ │ │ +
480 this->update(srcValues, vderivs, _dvWeights, start, end);
│ │ │ │ +
481 }
│ │ │ │ +
│ │ │ │ +
482
│ │ │ │ +
483 template <class T1, class T2, class U>
│ │ │ │ +
│ │ │ │ +
484 void UpdateDerivs(T1 const & srcBase, int numBase, T2 const & srcRef,
│ │ │ │ +
485 U & uderivs, U & vderivs, int start=-1, int end=-1) const {
│ │ │ │ +
486
│ │ │ │ +
487 this->update(srcBase, numBase, srcRef, uderivs, _duWeights, start, end);
│ │ │ │ +
488 this->update(srcBase, numBase, srcRef, vderivs, _dvWeights, start, end);
│ │ │ │ +
489 }
│ │ │ │ +
│ │ │ │ +
490
│ │ │ │ +
491 // Pointer interface for backward compatibility
│ │ │ │ +
492 template <class T, class U>
│ │ │ │ +
│ │ │ │ +
493 void UpdateDerivs(T const *src, U *uderivs, U *vderivs,
│ │ │ │ +
494 int start=-1, int end=-1) const {
│ │ │ │ +
495
│ │ │ │ +
496 this->update(src, uderivs, _duWeights, start, end);
│ │ │ │ +
497 this->update(src, vderivs, _dvWeights, start, end);
│ │ │ │ +
498 }
│ │ │ │ +
│ │ │ │ +
499 template <class T1, class T2, class U>
│ │ │ │ +
│ │ │ │ +
500 void UpdateDerivs(T1 const *srcBase, int numBase, T2 const *srcRef,
│ │ │ │ +
501 U *uderivs, U *vderivs, int start=-1, int end=-1) const {
│ │ │ │ +
502
│ │ │ │ +
503 this->update(srcBase, numBase, srcRef, uderivs, _duWeights, start, end);
│ │ │ │ +
504 this->update(srcBase, numBase, srcRef, vderivs, _dvWeights, start, end);
│ │ │ │ +
505 }
│ │ │ │ +
│ │ │ │ +
506
│ │ │ │ +
527 template <class T, class U>
│ │ │ │ +
│ │ │ │ +
528 void Update2ndDerivs(T const & srcValues,
│ │ │ │ +
529 U & uuderivs, U & uvderivs, U & vvderivs,
│ │ │ │ +
530 int start=-1, int end=-1) const {
│ │ │ │ +
531
│ │ │ │ +
532 this->update(srcValues, uuderivs, _duuWeights, start, end);
│ │ │ │ +
533 this->update(srcValues, uvderivs, _duvWeights, start, end);
│ │ │ │ +
534 this->update(srcValues, vvderivs, _dvvWeights, start, end);
│ │ │ │ +
535 }
│ │ │ │ +
│ │ │ │ +
536
│ │ │ │ +
537 template <class T1, class T2, class U>
│ │ │ │ +
│ │ │ │ +
538 void Update2ndDerivs(T1 const & srcBase, int numBase, T2 const & srcRef,
│ │ │ │ +
539 U & uuderivs, U & uvderivs, U & vvderivs, int start=-1, int end=-1) const {
│ │ │ │ +
540
│ │ │ │ +
541 this->update(srcBase, numBase, srcRef, uuderivs, _duuWeights, start, end);
│ │ │ │ +
542 this->update(srcBase, numBase, srcRef, uvderivs, _duvWeights, start, end);
│ │ │ │ +
543 this->update(srcBase, numBase, srcRef, vvderivs, _dvvWeights, start, end);
│ │ │ │ +
544 }
│ │ │ │ +
│ │ │ │ +
545
│ │ │ │ +
546 // Pointer interface for backward compatibility
│ │ │ │ +
547 template <class T, class U>
│ │ │ │ +
│ │ │ │ +
548 void Update2ndDerivs(T const *src, T *uuderivs, U *uvderivs, U *vvderivs,
│ │ │ │ +
549 int start=-1, int end=-1) const {
│ │ │ │ +
550
│ │ │ │ +
551 this->update(src, uuderivs, _duuWeights, start, end);
│ │ │ │ +
552 this->update(src, uvderivs, _duvWeights, start, end);
│ │ │ │ +
553 this->update(src, vvderivs, _dvvWeights, start, end);
│ │ │ │ +
554 }
│ │ │ │ +
│ │ │ │ +
555 template <class T1, class T2, class U>
│ │ │ │ +
│ │ │ │ +
556 void Update2ndDerivs(T1 const *srcBase, int numBase, T2 const *srcRef,
│ │ │ │ +
557 U *uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const {
│ │ │ │ +
558
│ │ │ │ +
559 this->update(srcBase, numBase, srcRef, uuderivs, _duuWeights, start, end);
│ │ │ │ +
560 this->update(srcBase, numBase, srcRef, uvderivs, _duvWeights, start, end);
│ │ │ │ +
561 this->update(srcBase, numBase, srcRef, vvderivs, _dvvWeights, start, end);
│ │ │ │ +
562 }
│ │ │ │ +
│ │ │ │ +
563
│ │ │ │ +
565 void Clear();
│ │ │ │ +
566
│ │ │ │ +
567private:
│ │ │ │ +
568 friend class LimitStencilTableFactoryReal<REAL>;
│ │ │ │ +
569
│ │ │ │ +
570 // Resize the table arrays (factory helper)
│ │ │ │ +
571 void resize(int nstencils, int nelems);
│ │ │ │ +
572
│ │ │ │ +
573private:
│ │ │ │ +
574 std::vector<REAL> _duWeights, // u derivative limit stencil weights
│ │ │ │ +
575 _dvWeights, // v derivative limit stencil weights
│ │ │ │ +
576 _duuWeights, // uu derivative limit stencil weights
│ │ │ │ +
577 _duvWeights, // uv derivative limit stencil weights
│ │ │ │ +
578 _dvvWeights; // vv derivative limit stencil weights
│ │ │ │ +
579};
│ │ │ │ +
580
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
584protected:
│ │ │ │ + │ │ │ │ +
586
│ │ │ │ +
587public:
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ +
590 }
│ │ │ │ +
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ +
593 }
│ │ │ │ +
│ │ │ │ +
594
│ │ │ │ +
595protected:
│ │ │ │ +
│ │ │ │ +
596 LimitStencilTable(int numControlVerts,
│ │ │ │ +
597 std::vector<int> const& offsets,
│ │ │ │ +
598 std::vector<int> const& sizes,
│ │ │ │ +
599 std::vector<int> const& sources,
│ │ │ │ +
600 std::vector<float> const& weights,
│ │ │ │ +
601 std::vector<float> const& duWeights,
│ │ │ │ +
602 std::vector<float> const& dvWeights,
│ │ │ │ +
603 std::vector<float> const& duuWeights,
│ │ │ │ +
604 std::vector<float> const& duvWeights,
│ │ │ │ +
605 std::vector<float> const& dvvWeights,
│ │ │ │ +
606 bool includeCoarseVerts,
│ │ │ │ +
607 size_t firstOffset)
│ │ │ │ +
608 : BaseTable(numControlVerts,
│ │ │ │ +
609 offsets, sizes, sources, weights,
│ │ │ │ +
610 duWeights, dvWeights, duuWeights, duvWeights, dvvWeights,
│ │ │ │ +
611 includeCoarseVerts, firstOffset) { }
│ │ │ │ +
│ │ │ │ +
612};
│ │ │ │ +
│ │ │ │ +
613
│ │ │ │ +
614
│ │ │ │ +
615// Update values by applying cached stencil weights to new control values
│ │ │ │ +
616template <typename REAL>
│ │ │ │ +
617template <class T1, class T2, class U> void
│ │ │ │ +
│ │ │ │ +
618StencilTableReal<REAL>::update(T1 const &srcBase, int numBase,
│ │ │ │ +
619 T2 const &srcRef, U &dstValues,
│ │ │ │ +
620 std::vector<REAL> const &valueWeights, Index start, Index end) const {
│ │ │ │ +
621
│ │ │ │ +
622 int const * sizes = &_sizes.at(0);
│ │ │ │ +
623 Index const * indices = &_indices.at(0);
│ │ │ │ +
624 REAL const * weights = &valueWeights.at(0);
│ │ │ │ +
625
│ │ │ │ +
626 if (start > 0) {
│ │ │ │ +
627 assert(start < (Index)_offsets.size());
│ │ │ │ +
628 sizes += start;
│ │ │ │ +
629 indices += _offsets[start];
│ │ │ │ +
630 weights += _offsets[start];
│ │ │ │ +
631 } else {
│ │ │ │ +
632 start = 0;
│ │ │ │ +
633 }
│ │ │ │ +
634
│ │ │ │ +
635 int nstencils = ((end < start) ? GetNumStencils() : end) - start;
│ │ │ │ +
636
│ │ │ │ +
637 for (int i = 0; i < nstencils; ++i, ++sizes) {
│ │ │ │ +
638 dstValues[start + i].Clear();
│ │ │ │ +
639 for (int j = 0; j < *sizes; ++j, ++indices, ++weights) {
│ │ │ │ +
640 if (*indices < numBase) {
│ │ │ │ +
641 dstValues[start + i].AddWithWeight(srcBase[*indices], *weights);
│ │ │ │ +
642 } else {
│ │ │ │ +
643 dstValues[start + i].AddWithWeight(srcRef[*indices - numBase], *weights);
│ │ │ │ +
644 }
│ │ │ │ +
645 }
│ │ │ │ +
646 }
│ │ │ │ +
647}
│ │ │ │ +
│ │ │ │ +
648template <typename REAL>
│ │ │ │ +
649template <class T, class U> void
│ │ │ │ +
│ │ │ │ +
650StencilTableReal<REAL>::update(T const &srcValues, U &dstValues,
│ │ │ │ +
651 std::vector<REAL> const &valueWeights, Index start, Index end) const {
│ │ │ │ +
652
│ │ │ │ +
653 int const * sizes = &_sizes.at(0);
│ │ │ │ +
654 Index const * indices = &_indices.at(0);
│ │ │ │ +
655 REAL const * weights = &valueWeights.at(0);
│ │ │ │ +
656
│ │ │ │ +
657 if (start > 0) {
│ │ │ │ +
658 assert(start < (Index)_offsets.size());
│ │ │ │ +
659 sizes += start;
│ │ │ │ +
660 indices += _offsets[start];
│ │ │ │ +
661 weights += _offsets[start];
│ │ │ │ +
662 } else {
│ │ │ │ +
663 start = 0;
│ │ │ │ +
664 }
│ │ │ │ +
665
│ │ │ │ +
666 int nstencils = ((end < start) ? GetNumStencils() : end) - start;
│ │ │ │ +
667
│ │ │ │ +
668 for (int i = 0; i < nstencils; ++i, ++sizes) {
│ │ │ │ +
669 dstValues[start + i].Clear();
│ │ │ │ +
670 for (int j = 0; j < *sizes; ++j, ++indices, ++weights) {
│ │ │ │ +
671 dstValues[start + i].AddWithWeight(srcValues[*indices], *weights);
│ │ │ │ +
672 }
│ │ │ │ +
673 }
│ │ │ │ +
674}
│ │ │ │ +
│ │ │ │ +
675
│ │ │ │ +
676template <typename REAL>
│ │ │ │ +
677inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
679 Index offset=0;
│ │ │ │ +
680 int noffsets = (int)_sizes.size();
│ │ │ │ +
681 _offsets.resize(noffsets);
│ │ │ │ +
682 for (int i=0; i<(int)_sizes.size(); ++i ) {
│ │ │ │ +
683 _offsets[i]=offset;
│ │ │ │ +
684 offset+=_sizes[i];
│ │ │ │ +
685 }
│ │ │ │ +
686}
│ │ │ │ +
│ │ │ │ +
687
│ │ │ │ +
688template <typename REAL>
│ │ │ │ +
689inline void
│ │ │ │ +
│ │ │ │ +
690StencilTableReal<REAL>::resize(int nstencils, int nelems) {
│ │ │ │ +
691 _sizes.resize(nstencils);
│ │ │ │ +
692 _indices.resize(nelems);
│ │ │ │ +
693 _weights.resize(nelems);
│ │ │ │ +
694}
│ │ │ │ +
│ │ │ │ +
695
│ │ │ │ +
696template <typename REAL>
│ │ │ │ +
697inline void
│ │ │ │ +
│ │ │ │ +
698StencilTableReal<REAL>::reserve(int nstencils, int nelems) {
│ │ │ │ +
699 _sizes.reserve(nstencils);
│ │ │ │ +
700 _indices.reserve(nelems);
│ │ │ │ +
701 _weights.reserve(nelems);
│ │ │ │ +
702}
│ │ │ │ +
│ │ │ │ +
703
│ │ │ │ +
704template <typename REAL>
│ │ │ │ +
705inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
707 std::vector<int>(_sizes).swap(_sizes);
│ │ │ │ +
708 std::vector<Index>(_indices).swap(_indices);
│ │ │ │ +
709 std::vector<REAL>(_weights).swap(_weights);
│ │ │ │ +
710}
│ │ │ │ +
│ │ │ │ +
711
│ │ │ │ +
712template <typename REAL>
│ │ │ │ +
713inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
715 shrinkToFit();
│ │ │ │ +
716 generateOffsets();
│ │ │ │ +
717}
│ │ │ │ +
│ │ │ │ +
718
│ │ │ │ +
719// Returns a Stencil at index i in the table
│ │ │ │ +
720template <typename REAL>
│ │ │ │ + │ │ │ │ +
│ │ │ │ + │ │ │ │ +
723 assert((! _offsets.empty()) && i<(int)_offsets.size());
│ │ │ │ +
724
│ │ │ │ +
725 Index ofs = _offsets[i];
│ │ │ │ +
726
│ │ │ │ +
727 return StencilReal<REAL>(const_cast<int*>(&_sizes[i]),
│ │ │ │ +
728 const_cast<Index*>(&_indices[ofs]),
│ │ │ │ +
729 const_cast<REAL*>(&_weights[ofs]));
│ │ │ │ +
730}
│ │ │ │ +
│ │ │ │ +
731
│ │ │ │ +
732template <typename REAL>
│ │ │ │ + │ │ │ │ +
│ │ │ │ + │ │ │ │ +
735 return GetStencil(index);
│ │ │ │ +
736}
│ │ │ │ +
│ │ │ │ +
737
│ │ │ │ +
738template <typename REAL>
│ │ │ │ +
739inline void
│ │ │ │ +
740LimitStencilTableReal<REAL>::resize(int nstencils, int nelems) {
│ │ │ │ +
741 StencilTableReal<REAL>::resize(nstencils, nelems);
│ │ │ │ +
742 _duWeights.resize(nelems);
│ │ │ │ +
743 _dvWeights.resize(nelems);
│ │ │ │ +
744}
│ │ │ │ +
745
│ │ │ │ +
746// Returns a LimitStencil at index i in the table
│ │ │ │ +
747template <typename REAL>
│ │ │ │ +
748inline LimitStencilReal<REAL>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
750 assert((! this->GetOffsets().empty()) && i<(int)this->GetOffsets().size());
│ │ │ │ +
751
│ │ │ │ +
752 Index ofs = this->GetOffsets()[i];
│ │ │ │ +
753
│ │ │ │ +
754 if (!_duWeights.empty() && !_dvWeights.empty() &&
│ │ │ │ +
755 !_duuWeights.empty() && !_duvWeights.empty() && !_dvvWeights.empty()) {
│ │ │ │ + │ │ │ │ +
757 const_cast<int *>(&this->GetSizes()[i]),
│ │ │ │ +
758 const_cast<Index *>(&this->GetControlIndices()[ofs]),
│ │ │ │ +
759 const_cast<REAL *>(&this->GetWeights()[ofs]),
│ │ │ │ +
760 const_cast<REAL *>(&GetDuWeights()[ofs]),
│ │ │ │ +
761 const_cast<REAL *>(&GetDvWeights()[ofs]),
│ │ │ │ +
762 const_cast<REAL *>(&GetDuuWeights()[ofs]),
│ │ │ │ +
763 const_cast<REAL *>(&GetDuvWeights()[ofs]),
│ │ │ │ +
764 const_cast<REAL *>(&GetDvvWeights()[ofs]) );
│ │ │ │ +
765 } else if (!_duWeights.empty() && !_dvWeights.empty()) {
│ │ │ │ + │ │ │ │ +
767 const_cast<int *>(&this->GetSizes()[i]),
│ │ │ │ +
768 const_cast<Index *>(&this->GetControlIndices()[ofs]),
│ │ │ │ +
769 const_cast<REAL *>(&this->GetWeights()[ofs]),
│ │ │ │ +
770 const_cast<REAL *>(&GetDuWeights()[ofs]),
│ │ │ │ +
771 const_cast<REAL *>(&GetDvWeights()[ofs]) );
│ │ │ │ +
772 } else {
│ │ │ │ + │ │ │ │ +
774 const_cast<int *>(&this->GetSizes()[i]),
│ │ │ │ +
775 const_cast<Index *>(&this->GetControlIndices()[ofs]),
│ │ │ │ +
776 const_cast<REAL *>(&this->GetWeights()[ofs]) );
│ │ │ │ +
777 }
│ │ │ │ +
778}
│ │ │ │ +
│ │ │ │ +
779
│ │ │ │ +
780template <typename REAL>
│ │ │ │ + │ │ │ │ +
│ │ │ │ + │ │ │ │ +
783 return GetLimitStencil(index);
│ │ │ │ +
784}
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
785
│ │ │ │ +
786} // end namespace Far
│ │ │ │ +
787
│ │ │ │ +
788} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
789using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
790
│ │ │ │ +
791} // end namespace OpenSubdiv
│ │ │ │ +
792
│ │ │ │ +
793#endif // OPENSUBDIV3_FAR_STENCILTABLE_H
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
StencilReal(int *size, Index *indices, REAL *weights)
Constructor.
│ │ │ │ +
void Next()
Advance to the next stencil in the table.
│ │ │ │ +
StencilReal(StencilReal const &other)
Copy constructor.
│ │ │ │ + │ │ │ │ +
Index const * GetVertexIndices() const
Returns the control vertices' indices.
│ │ │ │ +
int GetSize() const
Returns the size of the stencil.
│ │ │ │ + │ │ │ │ +
int * GetSizePtr() const
Returns the size of the stencil as a pointer.
│ │ │ │ +
REAL const * GetWeights() const
Returns the interpolation weights.
│ │ │ │ +
Vertex stencil class wrapping the template for compatibility.
│ │ │ │ + │ │ │ │ +
Stencil(int *size, Index *indices, float *weights)
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
int GetNumControlVertices() const
Returns the number of control vertices indexed in the table.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
void update(T1 const &srcBase, int numBase, T2 const &srcRef, U &dstValues, std::vector< REAL > const &valueWeights, Index start, Index end) const
│ │ │ │ +
void UpdateValues(T1 const &srcBase, int numBase, T2 const &srcRef, U &dstValues, Index start=-1, Index end=-1) const
│ │ │ │ +
std::vector< Index > const & GetControlIndices() const
Returns the indices of the control vertices.
│ │ │ │ + │ │ │ │ +
StencilReal< REAL > operator[](Index index) const
Returns the stencil at index i in the table.
│ │ │ │ + │ │ │ │ +
void update(T const &srcValues, U &dstValues, std::vector< REAL > const &valueWeights, Index start, Index end) const
│ │ │ │ +
std::vector< int > const & GetSizes() const
Returns the number of control vertices of each stencil in the table.
│ │ │ │ +
int GetNumStencils() const
Returns the number of stencils in the table.
│ │ │ │ + │ │ │ │ +
std::vector< Index > const & GetOffsets() const
Returns the offset to a given stencil (factory may leave empty)
│ │ │ │ +
StencilReal< REAL > GetStencil(Index i) const
Returns a Stencil at index i in the table.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
void Clear()
Clears the stencils from the table.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
std::vector< REAL > const & GetWeights() const
Returns the stencil interpolation weights.
│ │ │ │ +
void UpdateValues(T1 const *srcBase, int numBase, T2 const *srcRef, U *dst, Index start=-1, Index end=-1) const
│ │ │ │ +
StencilTableReal(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< REAL > const &weights, bool includeCoarseVerts, size_t firstOffset)
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
void UpdateValues(T const *src, U *dst, Index start=-1, Index end=-1) const
│ │ │ │ +
void UpdateValues(T const &srcValues, U &dstValues, Index start=-1, Index end=-1) const
Updates point values based on the control values.
│ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ +
StencilTable(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< float > const &weights, bool includeCoarseVerts, size_t firstOffset)
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
REAL const * GetDuvWeights() const
Returns the uv derivative weights.
│ │ │ │ +
REAL const * GetDvWeights() const
Returns the v derivative weights.
│ │ │ │ +
void Next()
Advance to the next stencil in the table.
│ │ │ │ +
REAL const * GetDvvWeights() const
Returns the vv derivative weights.
│ │ │ │ +
LimitStencilReal(int *size, Index *indices, REAL *weights, REAL *duWeights=0, REAL *dvWeights=0, REAL *duuWeights=0, REAL *duvWeights=0, REAL *dvvWeights=0)
Constructor.
│ │ │ │ +
REAL const * GetDuWeights() const
Returns the u derivative weights.
│ │ │ │ +
REAL const * GetDuuWeights() const
Returns the uu derivative weights.
│ │ │ │ +
Limit point stencil class wrapping the template for compatibility.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
LimitStencil(int *size, Index *indices, float *weights, float *duWeights=0, float *dvWeights=0, float *duuWeights=0, float *duvWeights=0, float *dvvWeights=0)
│ │ │ │ + │ │ │ │ +
std::vector< REAL > const & GetDuuWeights() const
Returns the 'uu' derivative stencil interpolation weights.
│ │ │ │ +
LimitStencilReal< REAL > operator[](Index index) const
Returns the limit stencil at index i in the table.
│ │ │ │ +
std::vector< REAL > const & GetDvvWeights() const
Returns the 'vv' derivative stencil interpolation weights.
│ │ │ │ +
void UpdateDerivs(T const *src, U *uderivs, U *vderivs, int start=-1, int end=-1) const
│ │ │ │ +
void Update2ndDerivs(T const *src, T *uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const
│ │ │ │ +
std::vector< REAL > const & GetDvWeights() const
Returns the 'v' derivative stencil interpolation weights.
│ │ │ │ +
void Update2ndDerivs(T1 const *srcBase, int numBase, T2 const *srcRef, U *uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const
│ │ │ │ +
void UpdateDerivs(T const &srcValues, U &uderivs, U &vderivs, int start=-1, int end=-1) const
Updates derivative values based on the control values.
│ │ │ │ +
LimitStencilReal< REAL > GetLimitStencil(Index i) const
Returns a LimitStencil at index i in the table.
│ │ │ │ +
LimitStencilTableReal(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< REAL > const &weights, std::vector< REAL > const &duWeights, std::vector< REAL > const &dvWeights, std::vector< REAL > const &duuWeights, std::vector< REAL > const &duvWeights, std::vector< REAL > const &dvvWeights, bool includeCoarseVerts, size_t firstOffset)
│ │ │ │ +
void Update2ndDerivs(T const &srcValues, U &uuderivs, U &uvderivs, U &vvderivs, int start=-1, int end=-1) const
Updates 2nd derivative values based on the control values.
│ │ │ │ +
std::vector< REAL > const & GetDuWeights() const
Returns the 'u' derivative stencil interpolation weights.
│ │ │ │ +
void Clear()
Clears the stencils from the table.
│ │ │ │ +
void Update2ndDerivs(T1 const &srcBase, int numBase, T2 const &srcRef, U &uuderivs, U &uvderivs, U &vvderivs, int start=-1, int end=-1) const
│ │ │ │ +
std::vector< REAL > const & GetDuvWeights() const
Returns the 'uv' derivative stencil interpolation weights.
│ │ │ │ +
void UpdateDerivs(T1 const &srcBase, int numBase, T2 const &srcRef, U &uderivs, U &vderivs, int start=-1, int end=-1) const
│ │ │ │ +
void UpdateDerivs(T1 const *srcBase, int numBase, T2 const *srcRef, U *uderivs, U *vderivs, int start=-1, int end=-1) const
│ │ │ │ +
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
LimitStencilTable(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< float > const &weights, std::vector< float > const &duWeights, std::vector< float > const &dvWeights, std::vector< float > const &duuWeights, std::vector< float > const &duvWeights, std::vector< float > const &dvvWeights, bool includeCoarseVerts, size_t firstOffset)
│ │ │ │ + │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── encoding │ │ │ │ │ @@ -1 +1 @@ │ │ │ │ │ -utf-8 │ │ │ │ │ +us-ascii │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -patchTableFactory.h │ │ │ │ │ +stencilTable.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,409 +24,990 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H │ │ │ │ │ -26#define OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_FAR_STENCILTABLE_H │ │ │ │ │ +26#define OPENSUBDIV3_FAR_STENCILTABLE_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ 29 │ │ │ │ │ -30#include "../far/topologyRefiner.h" │ │ │ │ │ -31#include "../far/patchTable.h" │ │ │ │ │ -32 │ │ │ │ │ -33namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -34namespace OPENSUBDIV_VERSION { │ │ │ │ │ -35 │ │ │ │ │ -36namespace Far { │ │ │ │ │ -37 │ │ │ │ │ -_4_0class _P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y { │ │ │ │ │ -41public: │ │ │ │ │ -42 │ │ │ │ │ -_4_5 struct _O_p_t_i_o_n_s { │ │ │ │ │ -46 │ │ │ │ │ -_5_5 enum _E_n_d_C_a_p_T_y_p_e { │ │ │ │ │ -_5_6 _E_N_D_C_A_P___N_O_N_E = 0, │ │ │ │ │ -_5_7 _E_N_D_C_A_P___B_I_L_I_N_E_A_R___B_A_S_I_S, │ │ │ │ │ -_5_8 _E_N_D_C_A_P___B_S_P_L_I_N_E___B_A_S_I_S, │ │ │ │ │ -_5_9 _E_N_D_C_A_P___G_R_E_G_O_R_Y___B_A_S_I_S, │ │ │ │ │ -60 _E_N_D_C_A_P___L_E_G_A_C_Y___G_R_E_G_O_R_Y │ │ │ │ │ -_6_1 }; │ │ │ │ │ -62 │ │ │ │ │ -_6_3 _O_p_t_i_o_n_s(unsigned int maxIsolation=10) : │ │ │ │ │ -64 _g_e_n_e_r_a_t_e_A_l_l_L_e_v_e_l_s(false), │ │ │ │ │ -65 _i_n_c_l_u_d_e_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s(true), │ │ │ │ │ -66 _i_n_c_l_u_d_e_F_V_a_r_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s(false), │ │ │ │ │ -67 _t_r_i_a_n_g_u_l_a_t_e_Q_u_a_d_s(false), │ │ │ │ │ -68 _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h(false), │ │ │ │ │ -69 _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h(false), │ │ │ │ │ -70 _m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l(maxIsolation & 0xf), │ │ │ │ │ -71 _e_n_d_C_a_p_T_y_p_e(_E_N_D_C_A_P___G_R_E_G_O_R_Y___B_A_S_I_S), │ │ │ │ │ -72 _s_h_a_r_e_E_n_d_C_a_p_P_a_t_c_h_P_o_i_n_t_s(true), │ │ │ │ │ -73 _g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_T_a_b_l_e_s(true), │ │ │ │ │ -74 _g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_L_o_c_a_l_P_o_i_n_t_s(true), │ │ │ │ │ -75 _g_e_n_e_r_a_t_e_F_V_a_r_T_a_b_l_e_s(false), │ │ │ │ │ -76 _p_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e(false), │ │ │ │ │ -77 _f_v_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e(false), │ │ │ │ │ -78 _g_e_n_e_r_a_t_e_F_V_a_r_L_e_g_a_c_y_L_i_n_e_a_r_P_a_t_c_h_e_s(true), │ │ │ │ │ -79 _g_e_n_e_r_a_t_e_L_e_g_a_c_y_S_h_a_r_p_C_o_r_n_e_r_P_a_t_c_h_e_s(true), │ │ │ │ │ -80 _n_u_m_F_V_a_r_C_h_a_n_n_e_l_s(-1), │ │ │ │ │ -81 _f_v_a_r_C_h_a_n_n_e_l_I_n_d_i_c_e_s(0) │ │ │ │ │ -82 { } │ │ │ │ │ -83 │ │ │ │ │ -_8_5 _E_n_d_C_a_p_T_y_p_e _G_e_t_E_n_d_C_a_p_T_y_p_e() const { return (_E_n_d_C_a_p_T_y_p_e)_e_n_d_C_a_p_T_y_p_e; } │ │ │ │ │ +30#include "../far/types.h" │ │ │ │ │ +31 │ │ │ │ │ +32#include │ │ │ │ │ +33#include │ │ │ │ │ +34#include │ │ │ │ │ +35#include │ │ │ │ │ +36 │ │ │ │ │ +37namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +38namespace OPENSUBDIV_VERSION { │ │ │ │ │ +39 │ │ │ │ │ +40namespace Far { │ │ │ │ │ +41 │ │ │ │ │ +42// Forward declarations for friends: │ │ │ │ │ +43class PatchTableBuilder; │ │ │ │ │ +44 │ │ │ │ │ +45template class StencilTableFactoryReal; │ │ │ │ │ +46template class LimitStencilTableFactoryReal; │ │ │ │ │ +47 │ │ │ │ │ +52template │ │ │ │ │ +_5_3class _S_t_e_n_c_i_l_R_e_a_l { │ │ │ │ │ +54public: │ │ │ │ │ +55 │ │ │ │ │ +_5_7 _S_t_e_n_c_i_l_R_e_a_l() {} │ │ │ │ │ +58 │ │ │ │ │ +_6_7 _S_t_e_n_c_i_l_R_e_a_l(int * size, _I_n_d_e_x * indices, REAL * weights) │ │ │ │ │ +68 : ___s_i_z_e(size), ___i_n_d_i_c_e_s(indices), ___w_e_i_g_h_t_s(weights) { } │ │ │ │ │ +69 │ │ │ │ │ +_7_1 _S_t_e_n_c_i_l_R_e_a_l(_S_t_e_n_c_i_l_R_e_a_l const & other) { │ │ │ │ │ +72 ___s_i_z_e = other.___s_i_z_e; │ │ │ │ │ +73 ___i_n_d_i_c_e_s = other.___i_n_d_i_c_e_s; │ │ │ │ │ +74 ___w_e_i_g_h_t_s = other.___w_e_i_g_h_t_s; │ │ │ │ │ +75 } │ │ │ │ │ +76 │ │ │ │ │ +_7_8 int _G_e_t_S_i_z_e() const { │ │ │ │ │ +79 return *___s_i_z_e; │ │ │ │ │ +80 } │ │ │ │ │ +81 │ │ │ │ │ +_8_3 int * _G_e_t_S_i_z_e_P_t_r() const { │ │ │ │ │ +84 return ___s_i_z_e; │ │ │ │ │ +85 } │ │ │ │ │ 86 │ │ │ │ │ -_8_8 void _S_e_t_E_n_d_C_a_p_T_y_p_e(_E_n_d_C_a_p_T_y_p_e e) { _e_n_d_C_a_p_T_y_p_e = e & 0x7; } │ │ │ │ │ -89 │ │ │ │ │ -_9_1 void _S_e_t_M_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l(unsigned int level) { _m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l = level & │ │ │ │ │ -0xf; } │ │ │ │ │ -92 │ │ │ │ │ -_9_4 template void _S_e_t_P_a_t_c_h_P_r_e_c_i_s_i_o_n(); │ │ │ │ │ -95 │ │ │ │ │ -_9_7 template void _S_e_t_F_V_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n(); │ │ │ │ │ -98 │ │ │ │ │ -_1_0_0 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s _G_e_t_R_e_f_i_n_e_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s() const { │ │ │ │ │ -101 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s adaptiveOptions(_m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l); │ │ │ │ │ -102 │ │ │ │ │ -103 adaptiveOptions._u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h = _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h; │ │ │ │ │ -104 adaptiveOptions._u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h = _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h; │ │ │ │ │ -105 adaptiveOptions._c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s = _g_e_n_e_r_a_t_e_F_V_a_r_T_a_b_l_e_s && │ │ │ │ │ -106 !_g_e_n_e_r_a_t_e_F_V_a_r_L_e_g_a_c_y_L_i_n_e_a_r_P_a_t_c_h_e_s; │ │ │ │ │ -107 return adaptiveOptions; │ │ │ │ │ -108 } │ │ │ │ │ -109 │ │ │ │ │ -_1_1_0 unsigned int _g_e_n_e_r_a_t_e_A_l_l_L_e_v_e_l_s : 1, │ │ │ │ │ -_1_1_1 _i_n_c_l_u_d_e_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s : 1, │ │ │ │ │ -_1_1_2 _i_n_c_l_u_d_e_F_V_a_r_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s : 1, │ │ │ │ │ -_1_1_3 _t_r_i_a_n_g_u_l_a_t_e_Q_u_a_d_s : 1, │ │ │ │ │ -114 │ │ │ │ │ -_1_1_5 _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h : 1, │ │ │ │ │ -_1_1_6 _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h : 1, │ │ │ │ │ -_1_1_7 _m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l : 4, │ │ │ │ │ -118 │ │ │ │ │ -119 // end-capping │ │ │ │ │ -_1_2_0 _e_n_d_C_a_p_T_y_p_e : 3, │ │ │ │ │ -_1_2_1 _s_h_a_r_e_E_n_d_C_a_p_P_a_t_c_h_P_o_i_n_t_s : 1, │ │ │ │ │ -123 │ │ │ │ │ -124 // varying │ │ │ │ │ -_1_2_5 _g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_T_a_b_l_e_s : 1, │ │ │ │ │ -_1_2_6 _g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_L_o_c_a_l_P_o_i_n_t_s : 1, │ │ │ │ │ +_8_8 _I_n_d_e_x const * _G_e_t_V_e_r_t_e_x_I_n_d_i_c_e_s() const { │ │ │ │ │ +89 return ___i_n_d_i_c_e_s; │ │ │ │ │ +90 } │ │ │ │ │ +91 │ │ │ │ │ +_9_3 REAL const * _G_e_t_W_e_i_g_h_t_s() const { │ │ │ │ │ +94 return ___w_e_i_g_h_t_s; │ │ │ │ │ +95 } │ │ │ │ │ +96 │ │ │ │ │ +_9_8 void _N_e_x_t() { │ │ │ │ │ +99 int stride = *___s_i_z_e; │ │ │ │ │ +100 ++___s_i_z_e; │ │ │ │ │ +101 ___i_n_d_i_c_e_s += stride; │ │ │ │ │ +102 ___w_e_i_g_h_t_s += stride; │ │ │ │ │ +103 } │ │ │ │ │ +104 │ │ │ │ │ +105protected: │ │ │ │ │ +106 friend class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ +107 friend class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ +108 │ │ │ │ │ +_1_0_9 int * ___s_i_z_e; │ │ │ │ │ +_1_1_0 _I_n_d_e_x * ___i_n_d_i_c_e_s; │ │ │ │ │ +_1_1_1 REAL * ___w_e_i_g_h_t_s; │ │ │ │ │ +112}; │ │ │ │ │ +113 │ │ │ │ │ +_1_1_6class _S_t_e_n_c_i_l : public _S_t_e_n_c_i_l_R_e_a_l { │ │ │ │ │ +117protected: │ │ │ │ │ +_1_1_8 typedef _S_t_e_n_c_i_l_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_S_t_e_n_c_i_l; │ │ │ │ │ +119 │ │ │ │ │ +120public: │ │ │ │ │ +_1_2_1 _S_t_e_n_c_i_l() : _B_a_s_e_S_t_e_n_c_i_l() { } │ │ │ │ │ +_1_2_2 _S_t_e_n_c_i_l(_B_a_s_e_S_t_e_n_c_i_l const & other) : _B_a_s_e_S_t_e_n_c_i_l(other) { } │ │ │ │ │ +_1_2_3 _S_t_e_n_c_i_l(int * size, _I_n_d_e_x * indices, float * weights) │ │ │ │ │ +124 : _B_a_s_e_S_t_e_n_c_i_l(size, indices, weights) { } │ │ │ │ │ +125}; │ │ │ │ │ +126 │ │ │ │ │ 127 │ │ │ │ │ -128 // face-varying │ │ │ │ │ -_1_2_9 _g_e_n_e_r_a_t_e_F_V_a_r_T_a_b_l_e_s : 1, │ │ │ │ │ -130 │ │ │ │ │ -131 // precision │ │ │ │ │ -_1_3_2 _p_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e : 1, │ │ │ │ │ -_1_3_3 _f_v_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e : 1, │ │ │ │ │ -134 │ │ │ │ │ -135 // legacy behaviors (default to true) │ │ │ │ │ -_1_3_6 _g_e_n_e_r_a_t_e_F_V_a_r_L_e_g_a_c_y_L_i_n_e_a_r_P_a_t_c_h_e_s : 1, │ │ │ │ │ -_1_3_7 _g_e_n_e_r_a_t_e_L_e_g_a_c_y_S_h_a_r_p_C_o_r_n_e_r_P_a_t_c_h_e_s : 1; │ │ │ │ │ -138 │ │ │ │ │ -_1_3_9 int _n_u_m_F_V_a_r_C_h_a_n_n_e_l_s; │ │ │ │ │ -_1_4_0 int const * _f_v_a_r_C_h_a_n_n_e_l_I_n_d_i_c_e_s; │ │ │ │ │ -141 }; │ │ │ │ │ -142 │ │ │ │ │ -_1_7_5 static _P_a_t_c_h_T_a_b_l_e * _C_r_e_a_t_e(_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, │ │ │ │ │ -176 _O_p_t_i_o_n_s options = _O_p_t_i_o_n_s(), │ │ │ │ │ -177 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y selectedFaces = _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y()); │ │ │ │ │ -178 │ │ │ │ │ -179public: │ │ │ │ │ -180 // PatchFaceTag │ │ │ │ │ -181 // │ │ │ │ │ -182 // This simple struct was previously used within the factory to take │ │ │ │ │ -inventory of │ │ │ │ │ -183 // various kinds of patches to fully allocate buffers prior to populating │ │ │ │ │ -them. It │ │ │ │ │ -184 // was not intended to be exposed as part of the public interface. │ │ │ │ │ -185 // │ │ │ │ │ -186 // It is no longer used internally and is being kept here to respect │ │ │ │ │ -preservation │ │ │ │ │ -187 // of the public interface, but it will be deprecated at the earliest │ │ │ │ │ -opportunity. │ │ │ │ │ -188 // │ │ │ │ │ -191 // │ │ │ │ │ -_1_9_2 struct _P_a_t_c_h_F_a_c_e_T_a_g { │ │ │ │ │ -193 public: │ │ │ │ │ -_1_9_4 unsigned int ___h_a_s_P_a_t_c_h : 1; │ │ │ │ │ -_1_9_5 unsigned int ___i_s_R_e_g_u_l_a_r : 1; │ │ │ │ │ -_1_9_6 unsigned int ___t_r_a_n_s_i_t_i_o_n_M_a_s_k : 4; │ │ │ │ │ -_1_9_7 unsigned int ___b_o_u_n_d_a_r_y_M_a_s_k : 4; │ │ │ │ │ -_1_9_8 unsigned int ___b_o_u_n_d_a_r_y_I_n_d_e_x : 2; │ │ │ │ │ -_1_9_9 unsigned int ___b_o_u_n_d_a_r_y_C_o_u_n_t : 3; │ │ │ │ │ -_2_0_0 unsigned int ___h_a_s_B_o_u_n_d_a_r_y_E_d_g_e : 3; │ │ │ │ │ -_2_0_1 unsigned int ___i_s_S_i_n_g_l_e_C_r_e_a_s_e : 1; │ │ │ │ │ -202 │ │ │ │ │ -_2_0_3 void _c_l_e_a_r(); │ │ │ │ │ -_2_0_4 void _a_s_s_i_g_n_B_o_u_n_d_a_r_y_P_r_o_p_e_r_t_i_e_s_F_r_o_m_E_d_g_e_M_a_s_k(int boundaryEdgeMask); │ │ │ │ │ -_2_0_5 void _a_s_s_i_g_n_B_o_u_n_d_a_r_y_P_r_o_p_e_r_t_i_e_s_F_r_o_m_V_e_r_t_e_x_M_a_s_k(int boundaryVertexMask); │ │ │ │ │ -_2_0_6 void _a_s_s_i_g_n_T_r_a_n_s_i_t_i_o_n_P_r_o_p_e_r_t_i_e_s_F_r_o_m_E_d_g_e_M_a_s_k(int boundaryVertexMask); │ │ │ │ │ -207 }; │ │ │ │ │ -_2_0_8 typedef std::vector _P_a_t_c_h_T_a_g_V_e_c_t_o_r; │ │ │ │ │ -209}; │ │ │ │ │ -210 │ │ │ │ │ -211 │ │ │ │ │ -_2_1_2template <> inline void PatchTableFactory::Options::SetPatchPrecision │ │ │ │ │ -() { │ │ │ │ │ -213 _p_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e = false; │ │ │ │ │ -214} │ │ │ │ │ -_2_1_5template <> inline void PatchTableFactory::Options:: │ │ │ │ │ -SetFVarPatchPrecision() { │ │ │ │ │ -216 fvarPatchPrecisionDouble = false; │ │ │ │ │ -217} │ │ │ │ │ -218 │ │ │ │ │ -219template <> inline void PatchTableFactory::Options:: │ │ │ │ │ -SetPatchPrecision() { │ │ │ │ │ -220 patchPrecisionDouble = true; │ │ │ │ │ -221} │ │ │ │ │ -222template <> inline void PatchTableFactory::Options:: │ │ │ │ │ -SetFVarPatchPrecision() { │ │ │ │ │ -223 fvarPatchPrecisionDouble = true; │ │ │ │ │ -224} │ │ │ │ │ +140template │ │ │ │ │ +_1_4_1class _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l { │ │ │ │ │ +142protected: │ │ │ │ │ +_1_4_3 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l(int numControlVerts, │ │ │ │ │ +144 std::vector const& offsets, │ │ │ │ │ +145 std::vector const& sizes, │ │ │ │ │ +146 std::vector const& sources, │ │ │ │ │ +147 std::vector const& weights, │ │ │ │ │ +148 bool includeCoarseVerts, │ │ │ │ │ +149 size_t firstOffset); │ │ │ │ │ +150 │ │ │ │ │ +151public: │ │ │ │ │ +152 │ │ │ │ │ +_1_5_3 virtual _~_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l() {}; │ │ │ │ │ +154 │ │ │ │ │ +_1_5_6 int _G_e_t_N_u_m_S_t_e_n_c_i_l_s() const { │ │ │ │ │ +157 return (int)___s_i_z_e_s.size(); │ │ │ │ │ +158 } │ │ │ │ │ +159 │ │ │ │ │ +_1_6_1 int _G_e_t_N_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s() const { │ │ │ │ │ +162 return ___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s; │ │ │ │ │ +163 } │ │ │ │ │ +164 │ │ │ │ │ +_1_6_6 _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> _G_e_t_S_t_e_n_c_i_l(_I_n_d_e_x i) const; │ │ │ │ │ +167 │ │ │ │ │ +_1_6_9 std::vector const & _G_e_t_S_i_z_e_s() const { │ │ │ │ │ +170 return ___s_i_z_e_s; │ │ │ │ │ +171 } │ │ │ │ │ +172 │ │ │ │ │ +_1_7_4 std::vector const & _G_e_t_O_f_f_s_e_t_s() const { │ │ │ │ │ +175 return ___o_f_f_s_e_t_s; │ │ │ │ │ +176 } │ │ │ │ │ +177 │ │ │ │ │ +_1_7_9 std::vector const & _G_e_t_C_o_n_t_r_o_l_I_n_d_i_c_e_s() const { │ │ │ │ │ +180 return ___i_n_d_i_c_e_s; │ │ │ │ │ +181 } │ │ │ │ │ +182 │ │ │ │ │ +_1_8_4 std::vector const & _G_e_t_W_e_i_g_h_t_s() const { │ │ │ │ │ +185 return ___w_e_i_g_h_t_s; │ │ │ │ │ +186 } │ │ │ │ │ +187 │ │ │ │ │ +_1_8_9 _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> _o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const; │ │ │ │ │ +190 │ │ │ │ │ +204 template │ │ │ │ │ +_2_0_5 void _U_p_d_a_t_e_V_a_l_u_e_s(T const &srcValues, U &dstValues, _I_n_d_e_x start=-1, _I_n_d_e_x │ │ │ │ │ +end=-1) const { │ │ │ │ │ +206 this->_u_p_d_a_t_e(srcValues, dstValues, ___w_e_i_g_h_t_s, start, end); │ │ │ │ │ +207 } │ │ │ │ │ +208 │ │ │ │ │ +209 template │ │ │ │ │ +_2_1_0 void _U_p_d_a_t_e_V_a_l_u_e_s(T1 const &srcBase, int numBase, T2 const &srcRef, │ │ │ │ │ +211 U &dstValues, _I_n_d_e_x start=-1, _I_n_d_e_x end=-1) const { │ │ │ │ │ +212 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, dstValues, ___w_e_i_g_h_t_s, start, end); │ │ │ │ │ +213 } │ │ │ │ │ +214 │ │ │ │ │ +215 // Pointer interface for backward compatibility │ │ │ │ │ +216 template │ │ │ │ │ +_2_1_7 void _U_p_d_a_t_e_V_a_l_u_e_s(T const *src, U *dst, _I_n_d_e_x start=-1, _I_n_d_e_x end=-1) const │ │ │ │ │ +{ │ │ │ │ │ +218 this->_u_p_d_a_t_e(src, dst, ___w_e_i_g_h_t_s, start, end); │ │ │ │ │ +219 } │ │ │ │ │ +220 template │ │ │ │ │ +_2_2_1 void _U_p_d_a_t_e_V_a_l_u_e_s(T1 const *srcBase, int numBase, T2 const *srcRef, │ │ │ │ │ +222 U *dst, _I_n_d_e_x start=-1, _I_n_d_e_x end=-1) const { │ │ │ │ │ +223 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, dst, ___w_e_i_g_h_t_s, start, end); │ │ │ │ │ +224 } │ │ │ │ │ 225 │ │ │ │ │ -226 │ │ │ │ │ -227} // end namespace Far │ │ │ │ │ +_2_2_7 void _C_l_e_a_r(); │ │ │ │ │ 228 │ │ │ │ │ -229} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -230using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -231 │ │ │ │ │ -232} // end namespace OpenSubdiv │ │ │ │ │ -233 │ │ │ │ │ -234 │ │ │ │ │ -235#endif /* OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H */ │ │ │ │ │ +229protected: │ │ │ │ │ +230 │ │ │ │ │ +231 // Update values by applying cached stencil weights to new control values │ │ │ │ │ +232 template │ │ │ │ │ +_2_3_3 void _u_p_d_a_t_e( T const &srcValues, U &dstValues, │ │ │ │ │ +234 std::vector const & valueWeights, _I_n_d_e_x start, _I_n_d_e_x end) const; │ │ │ │ │ +235 template │ │ │ │ │ +_2_3_6 void _u_p_d_a_t_e( T1 const &srcBase, int numBase, T2 const &srcRef, U │ │ │ │ │ +&dstValues, │ │ │ │ │ +237 std::vector const & valueWeights, _I_n_d_e_x start, _I_n_d_e_x end) const; │ │ │ │ │ +238 │ │ │ │ │ +239 // Populate the offsets table from the stencil sizes in _sizes (factory │ │ │ │ │ +helper) │ │ │ │ │ +_2_4_0 void _g_e_n_e_r_a_t_e_O_f_f_s_e_t_s(); │ │ │ │ │ +241 │ │ │ │ │ +242 // Resize the table arrays (factory helper) │ │ │ │ │ +_2_4_3 void _r_e_s_i_z_e(int nstencils, int nelems); │ │ │ │ │ +244 │ │ │ │ │ +245 // Reserves the table arrays (factory helper) │ │ │ │ │ +_2_4_6 void _r_e_s_e_r_v_e(int nstencils, int nelems); │ │ │ │ │ +247 │ │ │ │ │ +248 // Reallocates the table arrays to remove excess capacity (factory helper) │ │ │ │ │ +_2_4_9 void _s_h_r_i_n_k_T_o_F_i_t(); │ │ │ │ │ +250 │ │ │ │ │ +251 // Performs any final operations on internal tables (factory helper) │ │ │ │ │ +_2_5_2 void _f_i_n_a_l_i_z_e(); │ │ │ │ │ +253 │ │ │ │ │ +254protected: │ │ │ │ │ +_2_5_5 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l() : ___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s(0) {} │ │ │ │ │ +_2_5_6 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l(int numControlVerts) │ │ │ │ │ +257 : ___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s(numControlVerts) │ │ │ │ │ +258 { } │ │ │ │ │ +259 │ │ │ │ │ +260 friend class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ +_2_6_1 friend class _F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_B_u_i_l_d_e_r; │ │ │ │ │ +262 │ │ │ │ │ +_2_6_3 int ___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s; // number of control vertices │ │ │ │ │ +264 │ │ │ │ │ +_2_6_5 std::vector ___s_i_z_e_s; // number of coefficients for each stencil │ │ │ │ │ +_2_6_6 std::vector ___o_f_f_s_e_t_s, // offset to the start of each stencil │ │ │ │ │ +_2_6_7 ___i_n_d_i_c_e_s; // indices of contributing coarse vertices │ │ │ │ │ +_2_6_8 std::vector ___w_e_i_g_h_t_s; // stencil weight coefficients │ │ │ │ │ +269}; │ │ │ │ │ +270 │ │ │ │ │ +_2_7_3class _S_t_e_n_c_i_l_T_a_b_l_e : public _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l { │ │ │ │ │ +274protected: │ │ │ │ │ +_2_7_5 typedef _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_T_a_b_l_e; │ │ │ │ │ +276 │ │ │ │ │ +277public: │ │ │ │ │ +_2_7_8 _S_t_e_n_c_i_l _G_e_t_S_t_e_n_c_i_l(_I_n_d_e_x index) const { │ │ │ │ │ +279 return _S_t_e_n_c_i_l(_B_a_s_e_T_a_b_l_e_:_:_G_e_t_S_t_e_n_c_i_l(index)); │ │ │ │ │ +280 } │ │ │ │ │ +_2_8_1 _S_t_e_n_c_i_l _o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const { │ │ │ │ │ +282 return _S_t_e_n_c_i_l(_B_a_s_e_T_a_b_l_e_:_:_G_e_t_S_t_e_n_c_i_l(index)); │ │ │ │ │ +283 } │ │ │ │ │ +284 │ │ │ │ │ +285protected: │ │ │ │ │ +_2_8_6 _S_t_e_n_c_i_l_T_a_b_l_e() : _B_a_s_e_T_a_b_l_e() { } │ │ │ │ │ +_2_8_7 _S_t_e_n_c_i_l_T_a_b_l_e(int numControlVerts) : _B_a_s_e_T_a_b_l_e(numControlVerts) { } │ │ │ │ │ +_2_8_8 _S_t_e_n_c_i_l_T_a_b_l_e(int numControlVerts, │ │ │ │ │ +289 std::vector const& offsets, │ │ │ │ │ +290 std::vector const& sizes, │ │ │ │ │ +291 std::vector const& sources, │ │ │ │ │ +292 std::vector const& weights, │ │ │ │ │ +293 bool includeCoarseVerts, │ │ │ │ │ +294 size_t firstOffset) │ │ │ │ │ +295 : _B_a_s_e_T_a_b_l_e(numControlVerts, offsets, │ │ │ │ │ +296 sizes, sources, weights, includeCoarseVerts, firstOffset) { } │ │ │ │ │ +297}; │ │ │ │ │ +298 │ │ │ │ │ +299 │ │ │ │ │ +302template │ │ │ │ │ +_3_0_3class _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l : public _S_t_e_n_c_i_l_R_e_a_l { │ │ │ │ │ +304public: │ │ │ │ │ +305 │ │ │ │ │ +_3_2_4 _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l( int* size, │ │ │ │ │ +325 _I_n_d_e_x * indices, │ │ │ │ │ +326 REAL * weights, │ │ │ │ │ +327 REAL * duWeights=0, │ │ │ │ │ +328 REAL * dvWeights=0, │ │ │ │ │ +329 REAL * duuWeights=0, │ │ │ │ │ +330 REAL * duvWeights=0, │ │ │ │ │ +331 REAL * dvvWeights=0) │ │ │ │ │ +332 : _S_t_e_n_c_i_l_R_e_a_l(size, indices, weights), │ │ │ │ │ +333 _duWeights(duWeights), │ │ │ │ │ +334 _dvWeights(dvWeights), │ │ │ │ │ +335 _duuWeights(duuWeights), │ │ │ │ │ +336 _duvWeights(duvWeights), │ │ │ │ │ +337 _dvvWeights(dvvWeights) { │ │ │ │ │ +338 } │ │ │ │ │ +339 │ │ │ │ │ +_3_4_1 REAL const * _G_e_t_D_u_W_e_i_g_h_t_s() const { │ │ │ │ │ +342 return _duWeights; │ │ │ │ │ +343 } │ │ │ │ │ +344 │ │ │ │ │ +_3_4_6 REAL const * _G_e_t_D_v_W_e_i_g_h_t_s() const { │ │ │ │ │ +347 return _dvWeights; │ │ │ │ │ +348 } │ │ │ │ │ +349 │ │ │ │ │ +_3_5_1 REAL const * _G_e_t_D_u_u_W_e_i_g_h_t_s() const { │ │ │ │ │ +352 return _duuWeights; │ │ │ │ │ +353 } │ │ │ │ │ +354 │ │ │ │ │ +_3_5_6 REAL const * _G_e_t_D_u_v_W_e_i_g_h_t_s() const { │ │ │ │ │ +357 return _duvWeights; │ │ │ │ │ +358 } │ │ │ │ │ +359 │ │ │ │ │ +_3_6_1 REAL const * _G_e_t_D_v_v_W_e_i_g_h_t_s() const { │ │ │ │ │ +362 return _dvvWeights; │ │ │ │ │ +363 } │ │ │ │ │ +364 │ │ │ │ │ +_3_6_6 void _N_e_x_t() { │ │ │ │ │ +367 int stride = *this->___s_i_z_e; │ │ │ │ │ +368 ++this->___s_i_z_e; │ │ │ │ │ +369 this->___i_n_d_i_c_e_s += stride; │ │ │ │ │ +370 this->___w_e_i_g_h_t_s += stride; │ │ │ │ │ +371 if (_duWeights) _duWeights += stride; │ │ │ │ │ +372 if (_dvWeights) _dvWeights += stride; │ │ │ │ │ +373 if (_duuWeights) _duuWeights += stride; │ │ │ │ │ +374 if (_duvWeights) _duvWeights += stride; │ │ │ │ │ +375 if (_dvvWeights) _dvvWeights += stride; │ │ │ │ │ +376 } │ │ │ │ │ +377 │ │ │ │ │ +378private: │ │ │ │ │ +379 │ │ │ │ │ +380 friend class _S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ +381 friend class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ +382 │ │ │ │ │ +383 REAL * _duWeights, // pointer to stencil u derivative limit weights │ │ │ │ │ +384 * _dvWeights, // pointer to stencil v derivative limit weights │ │ │ │ │ +385 * _duuWeights, // pointer to stencil uu derivative limit weights │ │ │ │ │ +386 * _duvWeights, // pointer to stencil uv derivative limit weights │ │ │ │ │ +387 * _dvvWeights; // pointer to stencil vv derivative limit weights │ │ │ │ │ +388}; │ │ │ │ │ +389 │ │ │ │ │ +_3_9_2class _L_i_m_i_t_S_t_e_n_c_i_l : public _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l { │ │ │ │ │ +393protected: │ │ │ │ │ +_3_9_4 typedef _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_S_t_e_n_c_i_l; │ │ │ │ │ +395 │ │ │ │ │ +396public: │ │ │ │ │ +_3_9_7 _L_i_m_i_t_S_t_e_n_c_i_l(_B_a_s_e_S_t_e_n_c_i_l const & other) : _B_a_s_e_S_t_e_n_c_i_l(other) { } │ │ │ │ │ +_3_9_8 _L_i_m_i_t_S_t_e_n_c_i_l(int* size, _I_n_d_e_x * indices, float * weights, │ │ │ │ │ +399 float * duWeights=0, float * dvWeights=0, │ │ │ │ │ +400 float * duuWeights=0, float * duvWeights=0, float * dvvWeights=0) │ │ │ │ │ +401 : _B_a_s_e_S_t_e_n_c_i_l(size, indices, weights, │ │ │ │ │ +402 duWeights, dvWeights, duuWeights, duvWeights, dvvWeights) { } │ │ │ │ │ +403}; │ │ │ │ │ +404 │ │ │ │ │ +405 │ │ │ │ │ +408template │ │ │ │ │ +_4_0_9class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l : public _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l { │ │ │ │ │ +410protected: │ │ │ │ │ +_4_1_1 _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l( │ │ │ │ │ +412 int numControlVerts, │ │ │ │ │ +413 std::vector const& offsets, │ │ │ │ │ +414 std::vector const& sizes, │ │ │ │ │ +415 std::vector const& sources, │ │ │ │ │ +416 std::vector const& weights, │ │ │ │ │ +417 std::vector const& duWeights, │ │ │ │ │ +418 std::vector const& dvWeights, │ │ │ │ │ +419 std::vector const& duuWeights, │ │ │ │ │ +420 std::vector const& duvWeights, │ │ │ │ │ +421 std::vector const& dvvWeights, │ │ │ │ │ +422 bool includeCoarseVerts, │ │ │ │ │ +423 size_t firstOffset); │ │ │ │ │ +424 │ │ │ │ │ +425public: │ │ │ │ │ +426 │ │ │ │ │ +_4_2_8 _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> _G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(_I_n_d_e_x i) const; │ │ │ │ │ +429 │ │ │ │ │ +_4_3_1 _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> _o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const; │ │ │ │ │ +432 │ │ │ │ │ +_4_3_4 std::vector const & _G_e_t_D_u_W_e_i_g_h_t_s() const { │ │ │ │ │ +435 return _duWeights; │ │ │ │ │ +436 } │ │ │ │ │ +437 │ │ │ │ │ +_4_3_9 std::vector const & _G_e_t_D_v_W_e_i_g_h_t_s() const { │ │ │ │ │ +440 return _dvWeights; │ │ │ │ │ +441 } │ │ │ │ │ +442 │ │ │ │ │ +_4_4_4 std::vector const & _G_e_t_D_u_u_W_e_i_g_h_t_s() const { │ │ │ │ │ +445 return _duuWeights; │ │ │ │ │ +446 } │ │ │ │ │ +447 │ │ │ │ │ +_4_4_9 std::vector const & _G_e_t_D_u_v_W_e_i_g_h_t_s() const { │ │ │ │ │ +450 return _duvWeights; │ │ │ │ │ +451 } │ │ │ │ │ +452 │ │ │ │ │ +_4_5_4 std::vector const & _G_e_t_D_v_v_W_e_i_g_h_t_s() const { │ │ │ │ │ +455 return _dvvWeights; │ │ │ │ │ +456 } │ │ │ │ │ +457 │ │ │ │ │ +475 template │ │ │ │ │ +_4_7_6 void _U_p_d_a_t_e_D_e_r_i_v_s(T const & srcValues, U & uderivs, U & vderivs, │ │ │ │ │ +477 int start=-1, int end=-1) const { │ │ │ │ │ +478 │ │ │ │ │ +479 this->_u_p_d_a_t_e(srcValues, uderivs, _duWeights, start, end); │ │ │ │ │ +480 this->_u_p_d_a_t_e(srcValues, vderivs, _dvWeights, start, end); │ │ │ │ │ +481 } │ │ │ │ │ +482 │ │ │ │ │ +483 template │ │ │ │ │ +_4_8_4 void _U_p_d_a_t_e_D_e_r_i_v_s(T1 const & srcBase, int numBase, T2 const & srcRef, │ │ │ │ │ +485 U & uderivs, U & vderivs, int start=-1, int end=-1) const { │ │ │ │ │ +486 │ │ │ │ │ +487 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uderivs, _duWeights, start, end); │ │ │ │ │ +488 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, vderivs, _dvWeights, start, end); │ │ │ │ │ +489 } │ │ │ │ │ +490 │ │ │ │ │ +491 // Pointer interface for backward compatibility │ │ │ │ │ +492 template │ │ │ │ │ +_4_9_3 void _U_p_d_a_t_e_D_e_r_i_v_s(T const *src, U *uderivs, U *vderivs, │ │ │ │ │ +494 int start=-1, int end=-1) const { │ │ │ │ │ +495 │ │ │ │ │ +496 this->_u_p_d_a_t_e(src, uderivs, _duWeights, start, end); │ │ │ │ │ +497 this->_u_p_d_a_t_e(src, vderivs, _dvWeights, start, end); │ │ │ │ │ +498 } │ │ │ │ │ +499 template │ │ │ │ │ +_5_0_0 void _U_p_d_a_t_e_D_e_r_i_v_s(T1 const *srcBase, int numBase, T2 const *srcRef, │ │ │ │ │ +501 U *uderivs, U *vderivs, int start=-1, int end=-1) const { │ │ │ │ │ +502 │ │ │ │ │ +503 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uderivs, _duWeights, start, end); │ │ │ │ │ +504 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, vderivs, _dvWeights, start, end); │ │ │ │ │ +505 } │ │ │ │ │ +506 │ │ │ │ │ +527 template │ │ │ │ │ +_5_2_8 void _U_p_d_a_t_e_2_n_d_D_e_r_i_v_s(T const & srcValues, │ │ │ │ │ +529 U & uuderivs, U & uvderivs, U & vvderivs, │ │ │ │ │ +530 int start=-1, int end=-1) const { │ │ │ │ │ +531 │ │ │ │ │ +532 this->_u_p_d_a_t_e(srcValues, uuderivs, _duuWeights, start, end); │ │ │ │ │ +533 this->_u_p_d_a_t_e(srcValues, uvderivs, _duvWeights, start, end); │ │ │ │ │ +534 this->_u_p_d_a_t_e(srcValues, vvderivs, _dvvWeights, start, end); │ │ │ │ │ +535 } │ │ │ │ │ +536 │ │ │ │ │ +537 template │ │ │ │ │ +_5_3_8 void _U_p_d_a_t_e_2_n_d_D_e_r_i_v_s(T1 const & srcBase, int numBase, T2 const & srcRef, │ │ │ │ │ +539 U & uuderivs, U & uvderivs, U & vvderivs, int start=-1, int end=-1) const { │ │ │ │ │ +540 │ │ │ │ │ +541 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uuderivs, _duuWeights, start, end); │ │ │ │ │ +542 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uvderivs, _duvWeights, start, end); │ │ │ │ │ +543 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, vvderivs, _dvvWeights, start, end); │ │ │ │ │ +544 } │ │ │ │ │ +545 │ │ │ │ │ +546 // Pointer interface for backward compatibility │ │ │ │ │ +547 template │ │ │ │ │ +_5_4_8 void _U_p_d_a_t_e_2_n_d_D_e_r_i_v_s(T const *src, T *uuderivs, U *uvderivs, U *vvderivs, │ │ │ │ │ +549 int start=-1, int end=-1) const { │ │ │ │ │ +550 │ │ │ │ │ +551 this->_u_p_d_a_t_e(src, uuderivs, _duuWeights, start, end); │ │ │ │ │ +552 this->_u_p_d_a_t_e(src, uvderivs, _duvWeights, start, end); │ │ │ │ │ +553 this->_u_p_d_a_t_e(src, vvderivs, _dvvWeights, start, end); │ │ │ │ │ +554 } │ │ │ │ │ +555 template │ │ │ │ │ +_5_5_6 void _U_p_d_a_t_e_2_n_d_D_e_r_i_v_s(T1 const *srcBase, int numBase, T2 const *srcRef, │ │ │ │ │ +557 U *uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const { │ │ │ │ │ +558 │ │ │ │ │ +559 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uuderivs, _duuWeights, start, end); │ │ │ │ │ +560 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, uvderivs, _duvWeights, start, end); │ │ │ │ │ +561 this->_u_p_d_a_t_e(srcBase, numBase, srcRef, vvderivs, _dvvWeights, start, end); │ │ │ │ │ +562 } │ │ │ │ │ +563 │ │ │ │ │ +_5_6_5 void _C_l_e_a_r(); │ │ │ │ │ +566 │ │ │ │ │ +567private: │ │ │ │ │ +568 friend class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l; │ │ │ │ │ +569 │ │ │ │ │ +570 // Resize the table arrays (factory helper) │ │ │ │ │ +571 void resize(int nstencils, int nelems); │ │ │ │ │ +572 │ │ │ │ │ +573private: │ │ │ │ │ +574 std::vector _duWeights, // u derivative limit stencil weights │ │ │ │ │ +575 _dvWeights, // v derivative limit stencil weights │ │ │ │ │ +576 _duuWeights, // uu derivative limit stencil weights │ │ │ │ │ +577 _duvWeights, // uv derivative limit stencil weights │ │ │ │ │ +578 _dvvWeights; // vv derivative limit stencil weights │ │ │ │ │ +579}; │ │ │ │ │ +580 │ │ │ │ │ +_5_8_3class _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e : public _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l { │ │ │ │ │ +584protected: │ │ │ │ │ +_5_8_5 typedef _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_f_l_o_a_t_> _B_a_s_e_T_a_b_l_e; │ │ │ │ │ +586 │ │ │ │ │ +587public: │ │ │ │ │ +_5_8_8 _L_i_m_i_t_S_t_e_n_c_i_l _G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(_I_n_d_e_x index) const { │ │ │ │ │ +589 return _L_i_m_i_t_S_t_e_n_c_i_l(_B_a_s_e_T_a_b_l_e_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(index)); │ │ │ │ │ +590 } │ │ │ │ │ +_5_9_1 _L_i_m_i_t_S_t_e_n_c_i_l _o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const { │ │ │ │ │ +592 return _L_i_m_i_t_S_t_e_n_c_i_l(_B_a_s_e_T_a_b_l_e_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(index)); │ │ │ │ │ +593 } │ │ │ │ │ +594 │ │ │ │ │ +595protected: │ │ │ │ │ +_5_9_6 _L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e(int numControlVerts, │ │ │ │ │ +597 std::vector const& offsets, │ │ │ │ │ +598 std::vector const& sizes, │ │ │ │ │ +599 std::vector const& sources, │ │ │ │ │ +600 std::vector const& weights, │ │ │ │ │ +601 std::vector const& duWeights, │ │ │ │ │ +602 std::vector const& dvWeights, │ │ │ │ │ +603 std::vector const& duuWeights, │ │ │ │ │ +604 std::vector const& duvWeights, │ │ │ │ │ +605 std::vector const& dvvWeights, │ │ │ │ │ +606 bool includeCoarseVerts, │ │ │ │ │ +607 size_t firstOffset) │ │ │ │ │ +608 : _B_a_s_e_T_a_b_l_e(numControlVerts, │ │ │ │ │ +609 offsets, sizes, sources, weights, │ │ │ │ │ +610 duWeights, dvWeights, duuWeights, duvWeights, dvvWeights, │ │ │ │ │ +611 includeCoarseVerts, firstOffset) { } │ │ │ │ │ +612}; │ │ │ │ │ +613 │ │ │ │ │ +614 │ │ │ │ │ +615// Update values by applying cached stencil weights to new control values │ │ │ │ │ +616template │ │ │ │ │ +617template void │ │ │ │ │ +_6_1_8_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_u_p_d_a_t_e(T1 const &srcBase, int numBase, │ │ │ │ │ +619 T2 const &srcRef, U &dstValues, │ │ │ │ │ +620 std::vector const &valueWeights, _I_n_d_e_x start, _I_n_d_e_x end) const { │ │ │ │ │ +621 │ │ │ │ │ +622 int const * sizes = &_sizes.at(0); │ │ │ │ │ +623 _I_n_d_e_x const * indices = &_indices.at(0); │ │ │ │ │ +624 REAL const * weights = &valueWeights.at(0); │ │ │ │ │ +625 │ │ │ │ │ +626 if (start > 0) { │ │ │ │ │ +627 assert(start < (_I_n_d_e_x)_offsets.size()); │ │ │ │ │ +628 sizes += start; │ │ │ │ │ +629 indices += _offsets[start]; │ │ │ │ │ +630 weights += _offsets[start]; │ │ │ │ │ +631 } else { │ │ │ │ │ +632 start = 0; │ │ │ │ │ +633 } │ │ │ │ │ +634 │ │ │ │ │ +635 int nstencils = ((end < start) ? GetNumStencils() : end) - start; │ │ │ │ │ +636 │ │ │ │ │ +637 for (int i = 0; i < nstencils; ++i, ++sizes) { │ │ │ │ │ +638 dstValues[start + i].Clear(); │ │ │ │ │ +639 for (int j = 0; j < *sizes; ++j, ++indices, ++weights) { │ │ │ │ │ +640 if (*indices < numBase) { │ │ │ │ │ +641 dstValues[start + i].AddWithWeight(srcBase[*indices], *weights); │ │ │ │ │ +642 } else { │ │ │ │ │ +643 dstValues[start + i].AddWithWeight(srcRef[*indices - numBase], *weights); │ │ │ │ │ +644 } │ │ │ │ │ +645 } │ │ │ │ │ +646 } │ │ │ │ │ +647} │ │ │ │ │ +648template │ │ │ │ │ +649template void │ │ │ │ │ +_6_5_0_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_u_p_d_a_t_e(T const &srcValues, U &dstValues, │ │ │ │ │ +651 std::vector const &valueWeights, _I_n_d_e_x start, _I_n_d_e_x end) const { │ │ │ │ │ +652 │ │ │ │ │ +653 int const * sizes = &_sizes.at(0); │ │ │ │ │ +654 _I_n_d_e_x const * indices = &_indices.at(0); │ │ │ │ │ +655 REAL const * weights = &valueWeights.at(0); │ │ │ │ │ +656 │ │ │ │ │ +657 if (start > 0) { │ │ │ │ │ +658 assert(start < (_I_n_d_e_x)_offsets.size()); │ │ │ │ │ +659 sizes += start; │ │ │ │ │ +660 indices += _offsets[start]; │ │ │ │ │ +661 weights += _offsets[start]; │ │ │ │ │ +662 } else { │ │ │ │ │ +663 start = 0; │ │ │ │ │ +664 } │ │ │ │ │ +665 │ │ │ │ │ +666 int nstencils = ((end < start) ? GetNumStencils() : end) - start; │ │ │ │ │ +667 │ │ │ │ │ +668 for (int i = 0; i < nstencils; ++i, ++sizes) { │ │ │ │ │ +669 dstValues[start + i].Clear(); │ │ │ │ │ +670 for (int j = 0; j < *sizes; ++j, ++indices, ++weights) { │ │ │ │ │ +671 dstValues[start + i].AddWithWeight(srcValues[*indices], *weights); │ │ │ │ │ +672 } │ │ │ │ │ +673 } │ │ │ │ │ +674} │ │ │ │ │ +675 │ │ │ │ │ +676template │ │ │ │ │ +677inline void │ │ │ │ │ +_6_7_8_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_g_e_n_e_r_a_t_e_O_f_f_s_e_t_s() { │ │ │ │ │ +679 _I_n_d_e_x offset=0; │ │ │ │ │ +680 int noffsets = (int)_sizes.size(); │ │ │ │ │ +681 _offsets.resize(noffsets); │ │ │ │ │ +682 for (int i=0; i<(int)_sizes.size(); ++i ) { │ │ │ │ │ +683 _offsets[i]=offset; │ │ │ │ │ +684 offset+=_sizes[i]; │ │ │ │ │ +685 } │ │ │ │ │ +686} │ │ │ │ │ +687 │ │ │ │ │ +688template │ │ │ │ │ +689inline void │ │ │ │ │ +_6_9_0_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_r_e_s_i_z_e(int nstencils, int nelems) { │ │ │ │ │ +691 _sizes.resize(nstencils); │ │ │ │ │ +692 _indices.resize(nelems); │ │ │ │ │ +693 _weights.resize(nelems); │ │ │ │ │ +694} │ │ │ │ │ +695 │ │ │ │ │ +696template │ │ │ │ │ +697inline void │ │ │ │ │ +_6_9_8_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_r_e_s_e_r_v_e(int nstencils, int nelems) { │ │ │ │ │ +699 _sizes.reserve(nstencils); │ │ │ │ │ +700 _indices.reserve(nelems); │ │ │ │ │ +701 _weights.reserve(nelems); │ │ │ │ │ +702} │ │ │ │ │ +703 │ │ │ │ │ +704template │ │ │ │ │ +705inline void │ │ │ │ │ +_7_0_6_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_s_h_r_i_n_k_T_o_F_i_t() { │ │ │ │ │ +707 std::vector(_sizes).swap(_sizes); │ │ │ │ │ +708 std::vector(_indices).swap(_indices); │ │ │ │ │ +709 std::vector(_weights).swap(_weights); │ │ │ │ │ +710} │ │ │ │ │ +711 │ │ │ │ │ +712template │ │ │ │ │ +713inline void │ │ │ │ │ +_7_1_4_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_f_i_n_a_l_i_z_e() { │ │ │ │ │ +715 shrinkToFit(); │ │ │ │ │ +716 generateOffsets(); │ │ │ │ │ +717} │ │ │ │ │ +718 │ │ │ │ │ +719// Returns a Stencil at index i in the table │ │ │ │ │ +720template │ │ │ │ │ +721inline _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> │ │ │ │ │ +_7_2_2_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_G_e_t_S_t_e_n_c_i_l(_I_n_d_e_x i) const { │ │ │ │ │ +723 assert((! _offsets.empty()) && i<(int)_offsets.size()); │ │ │ │ │ +724 │ │ │ │ │ +725 _I_n_d_e_x ofs = _offsets[i]; │ │ │ │ │ +726 │ │ │ │ │ +727 return _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_>(const_cast(&_sizes[i]), │ │ │ │ │ +728 const_cast<_I_n_d_e_x*>(&_indices[ofs]), │ │ │ │ │ +729 const_cast(&_weights[ofs])); │ │ │ │ │ +730} │ │ │ │ │ +731 │ │ │ │ │ +732template │ │ │ │ │ +733inline _S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> │ │ │ │ │ +_7_3_4_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const { │ │ │ │ │ +735 return GetStencil(index); │ │ │ │ │ +736} │ │ │ │ │ +737 │ │ │ │ │ +738template │ │ │ │ │ +739inline void │ │ │ │ │ +740_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_r_e_s_i_z_e(int nstencils, int nelems) { │ │ │ │ │ +741 _S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_r_e_s_i_z_e(nstencils, nelems); │ │ │ │ │ +742 _duWeights.resize(nelems); │ │ │ │ │ +743 _dvWeights.resize(nelems); │ │ │ │ │ +744} │ │ │ │ │ +745 │ │ │ │ │ +746// Returns a LimitStencil at index i in the table │ │ │ │ │ +747template │ │ │ │ │ +748inline LimitStencilReal │ │ │ │ │ +_7_4_9_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l(_I_n_d_e_x i) const { │ │ │ │ │ +750 assert((! this->GetOffsets().empty()) && i<(int)this->GetOffsets().size()); │ │ │ │ │ +751 │ │ │ │ │ +752 _I_n_d_e_x ofs = this->GetOffsets()[i]; │ │ │ │ │ +753 │ │ │ │ │ +754 if (!_duWeights.empty() && !_dvWeights.empty() && │ │ │ │ │ +755 !_duuWeights.empty() && !_duvWeights.empty() && !_dvvWeights.empty()) { │ │ │ │ │ +756 return _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_>( │ │ │ │ │ +757 const_cast(&this->GetSizes()[i]), │ │ │ │ │ +758 const_cast<_I_n_d_e_x *>(&this->GetControlIndices()[ofs]), │ │ │ │ │ +759 const_cast(&this->GetWeights()[ofs]), │ │ │ │ │ +760 const_cast(&GetDuWeights()[ofs]), │ │ │ │ │ +761 const_cast(&GetDvWeights()[ofs]), │ │ │ │ │ +762 const_cast(&GetDuuWeights()[ofs]), │ │ │ │ │ +763 const_cast(&GetDuvWeights()[ofs]), │ │ │ │ │ +764 const_cast(&GetDvvWeights()[ofs]) ); │ │ │ │ │ +765 } else if (!_duWeights.empty() && !_dvWeights.empty()) { │ │ │ │ │ +766 return _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_>( │ │ │ │ │ +767 const_cast(&this->GetSizes()[i]), │ │ │ │ │ +768 const_cast<_I_n_d_e_x *>(&this->GetControlIndices()[ofs]), │ │ │ │ │ +769 const_cast(&this->GetWeights()[ofs]), │ │ │ │ │ +770 const_cast(&GetDuWeights()[ofs]), │ │ │ │ │ +771 const_cast(&GetDvWeights()[ofs]) ); │ │ │ │ │ +772 } else { │ │ │ │ │ +773 return _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_>( │ │ │ │ │ +774 const_cast(&this->GetSizes()[i]), │ │ │ │ │ +775 const_cast<_I_n_d_e_x *>(&this->GetControlIndices()[ofs]), │ │ │ │ │ +776 const_cast(&this->GetWeights()[ofs]) ); │ │ │ │ │ +777 } │ │ │ │ │ +778} │ │ │ │ │ +779 │ │ │ │ │ +780template │ │ │ │ │ +781inline _L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_<_R_E_A_L_> │ │ │ │ │ +_7_8_2_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_<_R_E_A_L_>_:_:_o_p_e_r_a_t_o_r_[_]_ (_I_n_d_e_x index) const { │ │ │ │ │ +783 return GetLimitStencil(index); │ │ │ │ │ +784} │ │ │ │ │ +785 │ │ │ │ │ +786} // end namespace Far │ │ │ │ │ +787 │ │ │ │ │ +788} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +789using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +790 │ │ │ │ │ +791} // end namespace OpenSubdiv │ │ │ │ │ +792 │ │ │ │ │ +793#endif // OPENSUBDIV3_FAR_STENCILTABLE_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -Vtr::ConstIndexArray ConstIndexArray │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -Container for arrays of parametric patches. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_._h_:_5_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ -Factory for constructing a PatchTable from a TopologyRefiner. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_T_a_g_V_e_c_t_o_r │ │ │ │ │ -std::vector< PatchFaceTag > PatchTagVector │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e │ │ │ │ │ -static PatchTable * Create(TopologyRefiner const &refiner, Options │ │ │ │ │ -options=Options(), ConstIndexArray selectedFaces=ConstIndexArray()) │ │ │ │ │ -Instantiates a PatchTable from a client-provided TopologyRefiner. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s │ │ │ │ │ -Public options for the PatchTable factory. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_4_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_T_a_b_l_e_s │ │ │ │ │ -unsigned int generateVaryingTables │ │ │ │ │ -Generate varying patch tables. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_L_e_g_a_c_y_S_h_a_r_p_C_o_r_n_e_r_P_a_t_c_h_e_s │ │ │ │ │ -unsigned int generateLegacySharpCornerPatches │ │ │ │ │ -Generate sharp regular patches at smooth corners (legacy) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_s_h_a_r_e_E_n_d_C_a_p_P_a_t_c_h_P_o_i_n_t_s │ │ │ │ │ -unsigned int shareEndCapPatchPoints │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_G_e_t_R_e_f_i_n_e_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ -TopologyRefiner::AdaptiveOptions GetRefineAdaptiveOptions() const │ │ │ │ │ -Determine adaptive refinement options to match assigned patch options. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l │ │ │ │ │ -unsigned int maxIsolationLevel │ │ │ │ │ -Cap adaptive feature isolation to the given level (max. 10) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_G_e_t_E_n_d_C_a_p_T_y_p_e │ │ │ │ │ -EndCapType GetEndCapType() const │ │ │ │ │ -Get endcap basis type. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_8_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_F_V_a_r_L_e_g_a_c_y_L_i_n_e_a_r_P_a_t_c_h_e_s │ │ │ │ │ -unsigned int generateFVarLegacyLinearPatches │ │ │ │ │ -Generate all linear face-varying patches (legacy) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_S_e_t_P_a_t_c_h_P_r_e_c_i_s_i_o_n │ │ │ │ │ -void SetPatchPrecision() │ │ │ │ │ -Set precision of vertex patches. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_f_v_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e │ │ │ │ │ -unsigned int fvarPatchPrecisionDouble │ │ │ │ │ -Generate double-precision stencils for face-varying patches. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_S_e_t_M_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l │ │ │ │ │ -void SetMaxIsolationLevel(unsigned int level) │ │ │ │ │ -Set maximum isolation level. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_9_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_e_n_d_C_a_p_T_y_p_e │ │ │ │ │ -unsigned int endCapType │ │ │ │ │ -EndCapType. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_f_v_a_r_C_h_a_n_n_e_l_I_n_d_i_c_e_s │ │ │ │ │ -int const * fvarChannelIndices │ │ │ │ │ -List containing the indices of the channels selected for the factory. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h │ │ │ │ │ -unsigned int useSingleCreasePatch │ │ │ │ │ -Use single crease patch. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h │ │ │ │ │ -unsigned int useInfSharpPatch │ │ │ │ │ -Use infinitely-sharp patch. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_S_e_t_E_n_d_C_a_p_T_y_p_e │ │ │ │ │ -void SetEndCapType(EndCapType e) │ │ │ │ │ -Set endcap basis type. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_8_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_L_o_c_a_l_P_o_i_n_t_s │ │ │ │ │ -unsigned int generateVaryingLocalPoints │ │ │ │ │ -Generate local points with varying patches. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_i_n_c_l_u_d_e_F_V_a_r_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s │ │ │ │ │ -unsigned int includeFVarBaseLevelIndices │ │ │ │ │ -Include base level in face-varying patch point indices (Uniform mode only) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_A_l_l_L_e_v_e_l_s │ │ │ │ │ -unsigned int generateAllLevels │ │ │ │ │ -Generate levels from 'firstLevel' to 'maxLevel' (Uniform mode only) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_p_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e │ │ │ │ │ -unsigned int patchPrecisionDouble │ │ │ │ │ -Generate double-precision stencils for vertex patches. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_g_e_n_e_r_a_t_e_F_V_a_r_T_a_b_l_e_s │ │ │ │ │ -unsigned int generateFVarTables │ │ │ │ │ -Generate face-varying patch tables. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_i_n_c_l_u_d_e_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s │ │ │ │ │ -unsigned int includeBaseLevelIndices │ │ │ │ │ -Include base level in patch point indices (Uniform mode only) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_S_e_t_F_V_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n │ │ │ │ │ -void SetFVarPatchPrecision() │ │ │ │ │ -Set precision of face-varying patches. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_n_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ -int numFVarChannels │ │ │ │ │ -Number of channel indices and interpolation modes passed. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_t_r_i_a_n_g_u_l_a_t_e_Q_u_a_d_s │ │ │ │ │ -unsigned int triangulateQuads │ │ │ │ │ -Triangulate 'QUADS' primitives (Uniform mode only) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_E_n_d_C_a_p_T_y_p_e │ │ │ │ │ -EndCapType │ │ │ │ │ -Choice for approximating irregular patches (end-caps) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_E_N_D_C_A_P___L_E_G_A_C_Y___G_R_E_G_O_R_Y │ │ │ │ │ -@ ENDCAP_LEGACY_GREGORY │ │ │ │ │ -legacy option for 2.x style Gregory patches (Catmark only) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_6_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_E_N_D_C_A_P___G_R_E_G_O_R_Y___B_A_S_I_S │ │ │ │ │ -@ ENDCAP_GREGORY_BASIS │ │ │ │ │ -use Gregory patches (highest quality, recommended default) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_E_N_D_C_A_P___N_O_N_E │ │ │ │ │ -@ ENDCAP_NONE │ │ │ │ │ -unspecified │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_E_N_D_C_A_P___B_I_L_I_N_E_A_R___B_A_S_I_S │ │ │ │ │ -@ ENDCAP_BILINEAR_BASIS │ │ │ │ │ -use linear patches (simple quads or tris) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_E_N_D_C_A_P___B_S_P_L_I_N_E___B_A_S_I_S │ │ │ │ │ -@ ENDCAP_BSPLINE_BASIS │ │ │ │ │ -use BSpline-like patches (same patch type as regular) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_O_p_t_i_o_n_s │ │ │ │ │ -Options(unsigned int maxIsolation=10) │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_6_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g │ │ │ │ │ -Obsolete internal struct not intended for public use – due to be deprecated. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -___i_s_S_i_n_g_l_e_C_r_e_a_s_e │ │ │ │ │ -unsigned int _isSingleCrease │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -___i_s_R_e_g_u_l_a_r │ │ │ │ │ -unsigned int _isRegular │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -___b_o_u_n_d_a_r_y_I_n_d_e_x │ │ │ │ │ -unsigned int _boundaryIndex │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -_a_s_s_i_g_n_B_o_u_n_d_a_r_y_P_r_o_p_e_r_t_i_e_s_F_r_o_m_V_e_r_t_e_x_M_a_s_k │ │ │ │ │ -void assignBoundaryPropertiesFromVertexMask(int boundaryVertexMask) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -___t_r_a_n_s_i_t_i_o_n_M_a_s_k │ │ │ │ │ -unsigned int _transitionMask │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -___h_a_s_B_o_u_n_d_a_r_y_E_d_g_e │ │ │ │ │ -unsigned int _hasBoundaryEdge │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -___b_o_u_n_d_a_r_y_M_a_s_k │ │ │ │ │ -unsigned int _boundaryMask │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_:___h_a_s_P_a_t_c_h │ │ │ │ │ -unsigned int _hasPatch │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -_a_s_s_i_g_n_T_r_a_n_s_i_t_i_o_n_P_r_o_p_e_r_t_i_e_s_F_r_o_m_E_d_g_e_M_a_s_k │ │ │ │ │ -void assignTransitionPropertiesFromEdgeMask(int boundaryVertexMask) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_:_c_l_e_a_r │ │ │ │ │ -void clear() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -_a_s_s_i_g_n_B_o_u_n_d_a_r_y_P_r_o_p_e_r_t_i_e_s_F_r_o_m_E_d_g_e_M_a_s_k │ │ │ │ │ -void assignBoundaryPropertiesFromEdgeMask(int boundaryEdgeMask) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ -___b_o_u_n_d_a_r_y_C_o_u_n_t │ │ │ │ │ -unsigned int _boundaryCount │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ -Stores topology data for a specified set of refinement options. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ -Adaptive refinement options. │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h │ │ │ │ │ -unsigned int useSingleCreasePatch │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h │ │ │ │ │ -unsigned int useInfSharpPatch │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ -_c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ -unsigned int considerFVarChannels │ │ │ │ │ -DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_8_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y │ │ │ │ │ -DDeeffiinniittiioonn _a_r_r_a_y_._h_:_5_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_I_n_d_e_x │ │ │ │ │ +Vtr::Index Index │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l │ │ │ │ │ +A specialized factory for StencilTable. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_R_e_a_l │ │ │ │ │ +A specialized factory for LimitStencilTable. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ +Vertex stencil descriptor. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ +StencilReal() │ │ │ │ │ +Default constructor. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:___s_i_z_e │ │ │ │ │ +int * _size │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_0_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ +StencilReal(int *size, Index *indices, REAL *weights) │ │ │ │ │ +Constructor. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_N_e_x_t │ │ │ │ │ +void Next() │ │ │ │ │ +Advance to the next stencil in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ +StencilReal(StencilReal const &other) │ │ │ │ │ +Copy constructor. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:___i_n_d_i_c_e_s │ │ │ │ │ +Index * _indices │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_V_e_r_t_e_x_I_n_d_i_c_e_s │ │ │ │ │ +Index const * GetVertexIndices() const │ │ │ │ │ +Returns the control vertices' indices. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_8_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_S_i_z_e │ │ │ │ │ +int GetSize() const │ │ │ │ │ +Returns the size of the stencil. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:___w_e_i_g_h_t_s │ │ │ │ │ +REAL * _weights │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_S_i_z_e_P_t_r │ │ │ │ │ +int * GetSizePtr() const │ │ │ │ │ +Returns the size of the stencil as a pointer. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_8_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_W_e_i_g_h_t_s │ │ │ │ │ +REAL const * GetWeights() const │ │ │ │ │ +Returns the interpolation weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_9_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l │ │ │ │ │ +Vertex stencil class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_:_:_S_t_e_n_c_i_l │ │ │ │ │ +Stencil(BaseStencil const &other) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_2_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_:_:_S_t_e_n_c_i_l │ │ │ │ │ +Stencil(int *size, Index *indices, float *weights) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_2_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_:_:_B_a_s_e_S_t_e_n_c_i_l │ │ │ │ │ +StencilReal< float > BaseStencil │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_1_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_:_:_S_t_e_n_c_i_l │ │ │ │ │ +Stencil() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_2_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ +Table of subdivision stencils. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_4_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_N_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s │ │ │ │ │ +int GetNumControlVertices() const │ │ │ │ │ +Returns the number of control vertices indexed in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___s_i_z_e_s │ │ │ │ │ +std::vector< int > _sizes │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_P_a_t_c_h_T_a_b_l_e_B_u_i_l_d_e_r │ │ │ │ │ +friend class Far::PatchTableBuilder │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_u_p_d_a_t_e │ │ │ │ │ +void update(T1 const &srcBase, int numBase, T2 const &srcRef, U &dstValues, │ │ │ │ │ +std::vector< REAL > const &valueWeights, Index start, Index end) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_1_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_V_a_l_u_e_s │ │ │ │ │ +void UpdateValues(T1 const &srcBase, int numBase, T2 const &srcRef, U │ │ │ │ │ +&dstValues, Index start=-1, Index end=-1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_1_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_C_o_n_t_r_o_l_I_n_d_i_c_e_s │ │ │ │ │ +std::vector< Index > const & GetControlIndices() const │ │ │ │ │ +Returns the indices of the control vertices. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_7_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_f_i_n_a_l_i_z_e │ │ │ │ │ +void finalize() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_1_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_o_p_e_r_a_t_o_r_[_] │ │ │ │ │ +StencilReal< REAL > operator[](Index index) const │ │ │ │ │ +Returns the stencil at index i in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_3_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___n_u_m_C_o_n_t_r_o_l_V_e_r_t_i_c_e_s │ │ │ │ │ +int _numControlVertices │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_u_p_d_a_t_e │ │ │ │ │ +void update(T const &srcValues, U &dstValues, std::vector< REAL > const │ │ │ │ │ +&valueWeights, Index start, Index end) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_5_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_S_i_z_e_s │ │ │ │ │ +std::vector< int > const & GetSizes() const │ │ │ │ │ +Returns the number of control vertices of each stencil in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_6_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_N_u_m_S_t_e_n_c_i_l_s │ │ │ │ │ +int GetNumStencils() const │ │ │ │ │ +Returns the number of stencils in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_~_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ +virtual ~StencilTableReal() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_5_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_O_f_f_s_e_t_s │ │ │ │ │ +std::vector< Index > const & GetOffsets() const │ │ │ │ │ +Returns the offset to a given stencil (factory may leave empty) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_7_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_S_t_e_n_c_i_l │ │ │ │ │ +StencilReal< REAL > GetStencil(Index i) const │ │ │ │ │ +Returns a Stencil at index i in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_2_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_s_h_r_i_n_k_T_o_F_i_t │ │ │ │ │ +void shrinkToFit() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_0_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_g_e_n_e_r_a_t_e_O_f_f_s_e_t_s │ │ │ │ │ +void generateOffsets() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_C_l_e_a_r │ │ │ │ │ +void Clear() │ │ │ │ │ +Clears the stencils from the table. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___o_f_f_s_e_t_s │ │ │ │ │ +std::vector< Index > _offsets │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___w_e_i_g_h_t_s │ │ │ │ │ +std::vector< REAL > _weights │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_r_e_s_i_z_e │ │ │ │ │ +void resize(int nstencils, int nelems) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_9_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_W_e_i_g_h_t_s │ │ │ │ │ +std::vector< REAL > const & GetWeights() const │ │ │ │ │ +Returns the stencil interpolation weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_1_8_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_V_a_l_u_e_s │ │ │ │ │ +void UpdateValues(T1 const *srcBase, int numBase, T2 const *srcRef, U *dst, │ │ │ │ │ +Index start=-1, Index end=-1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_2_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ +StencilTableReal(int numControlVerts, std::vector< int > const &offsets, std:: │ │ │ │ │ +vector< int > const &sizes, std::vector< int > const &sources, std::vector< │ │ │ │ │ +REAL > const &weights, bool includeCoarseVerts, size_t firstOffset) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:___i_n_d_i_c_e_s │ │ │ │ │ +std::vector< Index > _indices │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_6_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ +StencilTableReal() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_5_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_r_e_s_e_r_v_e │ │ │ │ │ +void reserve(int nstencils, int nelems) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_6_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_V_a_l_u_e_s │ │ │ │ │ +void UpdateValues(T const *src, U *dst, Index start=-1, Index end=-1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_1_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_V_a_l_u_e_s │ │ │ │ │ +void UpdateValues(T const &srcValues, U &dstValues, Index start=-1, Index end=- │ │ │ │ │ +1) const │ │ │ │ │ +Updates point values based on the control values. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_0_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +Stencil table class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +StencilTable(int numControlVerts, std::vector< int > const &offsets, std:: │ │ │ │ │ +vector< int > const &sizes, std::vector< int > const &sources, std::vector< │ │ │ │ │ +float > const &weights, bool includeCoarseVerts, size_t firstOffset) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_8_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +StencilTable(int numControlVerts) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_8_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_B_a_s_e_T_a_b_l_e │ │ │ │ │ +StencilTableReal< float > BaseTable │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_S_t_e_n_c_i_l │ │ │ │ │ +Stencil GetStencil(Index index) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_o_p_e_r_a_t_o_r_[_] │ │ │ │ │ +Stencil operator[](Index index) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_8_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +StencilTable() │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ +Limit point stencil descriptor. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_0_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_u_v_W_e_i_g_h_t_s │ │ │ │ │ +REAL const * GetDuvWeights() const │ │ │ │ │ +Returns the uv derivative weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_v_W_e_i_g_h_t_s │ │ │ │ │ +REAL const * GetDvWeights() const │ │ │ │ │ +Returns the v derivative weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_4_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_N_e_x_t │ │ │ │ │ +void Next() │ │ │ │ │ +Advance to the next stencil in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_v_v_W_e_i_g_h_t_s │ │ │ │ │ +REAL const * GetDvvWeights() const │ │ │ │ │ +Returns the vv derivative weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l │ │ │ │ │ +LimitStencilReal(int *size, Index *indices, REAL *weights, REAL *duWeights=0, │ │ │ │ │ +REAL *dvWeights=0, REAL *duuWeights=0, REAL *duvWeights=0, REAL *dvvWeights=0) │ │ │ │ │ +Constructor. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_2_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_u_W_e_i_g_h_t_s │ │ │ │ │ +REAL const * GetDuWeights() const │ │ │ │ │ +Returns the u derivative weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_4_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_R_e_a_l_:_:_G_e_t_D_u_u_W_e_i_g_h_t_s │ │ │ │ │ +REAL const * GetDuuWeights() const │ │ │ │ │ +Returns the uu derivative weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ +Limit point stencil class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_9_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_:_:_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ +LimitStencil(BaseStencil const &other) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_9_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_:_:_B_a_s_e_S_t_e_n_c_i_l │ │ │ │ │ +LimitStencilReal< float > BaseStencil │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_9_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_:_:_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ +LimitStencil(int *size, Index *indices, float *weights, float *duWeights=0, │ │ │ │ │ +float *dvWeights=0, float *duuWeights=0, float *duvWeights=0, float │ │ │ │ │ +*dvvWeights=0) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_3_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ +Table of limit subdivision stencils. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_0_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_u_u_W_e_i_g_h_t_s │ │ │ │ │ +std::vector< REAL > const & GetDuuWeights() const │ │ │ │ │ +Returns the 'uu' derivative stencil interpolation weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_4_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_o_p_e_r_a_t_o_r_[_] │ │ │ │ │ +LimitStencilReal< REAL > operator[](Index index) const │ │ │ │ │ +Returns the limit stencil at index i in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_v_v_W_e_i_g_h_t_s │ │ │ │ │ +std::vector< REAL > const & GetDvvWeights() const │ │ │ │ │ +Returns the 'vv' derivative stencil interpolation weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_D_e_r_i_v_s │ │ │ │ │ +void UpdateDerivs(T const *src, U *uderivs, U *vderivs, int start=-1, int end=- │ │ │ │ │ +1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_9_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_2_n_d_D_e_r_i_v_s │ │ │ │ │ +void Update2ndDerivs(T const *src, T *uuderivs, U *uvderivs, U *vvderivs, int │ │ │ │ │ +start=-1, int end=-1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_4_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_v_W_e_i_g_h_t_s │ │ │ │ │ +std::vector< REAL > const & GetDvWeights() const │ │ │ │ │ +Returns the 'v' derivative stencil interpolation weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_3_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_2_n_d_D_e_r_i_v_s │ │ │ │ │ +void Update2ndDerivs(T1 const *srcBase, int numBase, T2 const *srcRef, U │ │ │ │ │ +*uuderivs, U *uvderivs, U *vvderivs, int start=-1, int end=-1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_D_e_r_i_v_s │ │ │ │ │ +void UpdateDerivs(T const &srcValues, U &uderivs, U &vderivs, int start=-1, int │ │ │ │ │ +end=-1) const │ │ │ │ │ +Updates derivative values based on the control values. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_7_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ +LimitStencilReal< REAL > GetLimitStencil(Index i) const │ │ │ │ │ +Returns a LimitStencil at index i in the table. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_7_4_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_: │ │ │ │ │ +_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l │ │ │ │ │ +LimitStencilTableReal(int numControlVerts, std::vector< int > const &offsets, │ │ │ │ │ +std::vector< int > const &sizes, std::vector< int > const &sources, std:: │ │ │ │ │ +vector< REAL > const &weights, std::vector< REAL > const &duWeights, std:: │ │ │ │ │ +vector< REAL > const &dvWeights, std::vector< REAL > const &duuWeights, std:: │ │ │ │ │ +vector< REAL > const &duvWeights, std::vector< REAL > const &dvvWeights, bool │ │ │ │ │ +includeCoarseVerts, size_t firstOffset) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_2_n_d_D_e_r_i_v_s │ │ │ │ │ +void Update2ndDerivs(T const &srcValues, U &uuderivs, U &uvderivs, U &vvderivs, │ │ │ │ │ +int start=-1, int end=-1) const │ │ │ │ │ +Updates 2nd derivative values based on the control values. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_2_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_u_W_e_i_g_h_t_s │ │ │ │ │ +std::vector< REAL > const & GetDuWeights() const │ │ │ │ │ +Returns the 'u' derivative stencil interpolation weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_3_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_C_l_e_a_r │ │ │ │ │ +void Clear() │ │ │ │ │ +Clears the stencils from the table. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_2_n_d_D_e_r_i_v_s │ │ │ │ │ +void Update2ndDerivs(T1 const &srcBase, int numBase, T2 const &srcRef, U │ │ │ │ │ +&uuderivs, U &uvderivs, U &vvderivs, int start=-1, int end=-1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_3_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_G_e_t_D_u_v_W_e_i_g_h_t_s │ │ │ │ │ +std::vector< REAL > const & GetDuvWeights() const │ │ │ │ │ +Returns the 'uv' derivative stencil interpolation weights. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_4_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_D_e_r_i_v_s │ │ │ │ │ +void UpdateDerivs(T1 const &srcBase, int numBase, T2 const &srcRef, U &uderivs, │ │ │ │ │ +U &vderivs, int start=-1, int end=-1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_4_8_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_R_e_a_l_:_:_U_p_d_a_t_e_D_e_r_i_v_s │ │ │ │ │ +void UpdateDerivs(T1 const *srcBase, int numBase, T2 const *srcRef, U *uderivs, │ │ │ │ │ +U *vderivs, int start=-1, int end=-1) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +Limit stencil table class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_:_:_B_a_s_e_T_a_b_l_e │ │ │ │ │ +LimitStencilTableReal< float > BaseTable │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_L_i_m_i_t_S_t_e_n_c_i_l │ │ │ │ │ +LimitStencil GetLimitStencil(Index index) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +LimitStencilTable(int numControlVerts, std::vector< int > const &offsets, std:: │ │ │ │ │ +vector< int > const &sizes, std::vector< int > const &sources, std::vector< │ │ │ │ │ +float > const &weights, std::vector< float > const &duWeights, std::vector< │ │ │ │ │ +float > const &dvWeights, std::vector< float > const &duuWeights, std::vector< │ │ │ │ │ +float > const &duvWeights, std::vector< float > const &dvvWeights, bool │ │ │ │ │ +includeCoarseVerts, size_t firstOffset) │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_9_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e_:_:_o_p_e_r_a_t_o_r_[_] │ │ │ │ │ +LimitStencil operator[](Index index) const │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_9_1 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h │ │ │ │ │ + * _s_t_e_n_c_i_l_T_a_b_l_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00728.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/primvarRefiner.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/far/patchTableFactory.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,43 +90,33 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
primvarRefiner.h File Reference
│ │ │ │ +
patchTableFactory.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/types.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ -#include "../sdc/bilinearScheme.h"
│ │ │ │ -#include "../sdc/catmarkScheme.h"
│ │ │ │ -#include "../sdc/loopScheme.h"
│ │ │ │ -#include "../vtr/level.h"
│ │ │ │ -#include "../vtr/fvarLevel.h"
│ │ │ │ -#include "../vtr/refinement.h"
│ │ │ │ -#include "../vtr/fvarRefinement.h"
│ │ │ │ -#include "../vtr/stackBuffer.h"
│ │ │ │ -#include "../vtr/componentInterfaces.h"
│ │ │ │ -#include "../far/types.h"
│ │ │ │ -#include "../far/error.h"
│ │ │ │ -#include "../far/topologyLevel.h"
│ │ │ │ -#include "../far/topologyRefiner.h"
│ │ │ │ -#include <cassert>
│ │ │ │ +#include "../far/topologyRefiner.h"
│ │ │ │ +#include "../far/patchTable.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  PrimvarRefinerReal< REAL >
 Applies refinement operations to generic primvar data. More...
class  PatchTableFactory
 Factory for constructing a PatchTable from a TopologyRefiner. More...
 
class  PrimvarRefiner
struct  PatchTableFactory::Options
 Public options for the PatchTable factory. More...
 
struct  PatchTableFactory::PatchFaceTag
 Obsolete internal struct not intended for public use – due to be deprecated. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -135,13 +125,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,41 +1,32 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -primvarRefiner.h File Reference │ │ │ │ │ +patchTableFactory.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_b_i_l_i_n_e_a_r_S_c_h_e_m_e_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_c_a_t_m_a_r_k_S_c_h_e_m_e_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_l_o_o_p_S_c_h_e_m_e_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_l_e_v_e_l_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_f_v_a_r_L_e_v_e_l_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_r_e_f_i_n_e_m_e_n_t_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_f_v_a_r_R_e_f_i_n_e_m_e_n_t_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_s_t_a_c_k_B_u_f_f_e_r_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_c_o_m_p_o_n_e_n_t_I_n_t_e_r_f_a_c_e_s_._h" │ │ │ │ │ -#include "_._._/_f_a_r_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_f_a_r_/_e_r_r_o_r_._h" │ │ │ │ │ -#include "_._._/_f_a_r_/_t_o_p_o_l_o_g_y_L_e_v_e_l_._h" │ │ │ │ │ #include "_._._/_f_a_r_/_t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h" │ │ │ │ │ -#include │ │ │ │ │ +#include "_._._/_f_a_r_/_p_a_t_c_h_T_a_b_l_e_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_ _R_E_A_L_ _> │ │ │ │ │ -  Applies refinement operations to generic primvar data. _M_o_r_e_._._. │ │ │ │ │ + class   _P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ +  Factory for constructing a _P_a_t_c_h_T_a_b_l_e from a _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ -class   _P_r_i_m_v_a_r_R_e_f_i_n_e_r │ │ │ │ │ +struct   _P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s │ │ │ │ │ +  Public options for the _P_a_t_c_h_T_a_b_l_e factory. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +struct   _P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g │ │ │ │ │ +  Obsolete internal struct not intended for public use – due to be │ │ │ │ │ + deprecated. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h │ │ │ │ │ + * _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00728.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,5 @@ │ │ │ │ │ var a00728 = [ │ │ │ │ │ - ["PrimvarRefinerReal< REAL >", "a01029.html", "a01029"], │ │ │ │ │ - ["PrimvarRefiner", "a01037.html", "a01037"] │ │ │ │ │ + ["PatchTableFactory", "a01017.html", "a01017"], │ │ │ │ │ + ["Options", "a01021.html", "a01021"], │ │ │ │ │ + ["PatchFaceTag", "a01025.html", "a01025"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00728_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/far/primvarRefiner.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/far/patchTableFactory.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
primvarRefiner.h
│ │ │ │ +
patchTableFactory.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2015 DreamWorks Animation LLC.
│ │ │ │ +
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -118,1233 +118,250 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24#ifndef OPENSUBDIV3_FAR_PRIMVAR_REFINER_H
│ │ │ │ -
25#define OPENSUBDIV3_FAR_PRIMVAR_REFINER_H
│ │ │ │ -
26
│ │ │ │ -
27#include "../version.h"
│ │ │ │ -
28
│ │ │ │ -
29#include "../sdc/types.h"
│ │ │ │ -
30#include "../sdc/options.h"
│ │ │ │ -
31#include "../sdc/bilinearScheme.h"
│ │ │ │ -
32#include "../sdc/catmarkScheme.h"
│ │ │ │ -
33#include "../sdc/loopScheme.h"
│ │ │ │ -
34#include "../vtr/level.h"
│ │ │ │ -
35#include "../vtr/fvarLevel.h"
│ │ │ │ -
36#include "../vtr/refinement.h"
│ │ │ │ -
37#include "../vtr/fvarRefinement.h"
│ │ │ │ -
38#include "../vtr/stackBuffer.h"
│ │ │ │ -
39#include "../vtr/componentInterfaces.h"
│ │ │ │ -
40#include "../far/types.h"
│ │ │ │ -
41#include "../far/error.h"
│ │ │ │ -
42#include "../far/topologyLevel.h"
│ │ │ │ -
43#include "../far/topologyRefiner.h"
│ │ │ │ -
44
│ │ │ │ -
45#include <cassert>
│ │ │ │ +
24
│ │ │ │ +
25#ifndef OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H
│ │ │ │ +
26#define OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H
│ │ │ │ +
27
│ │ │ │ +
28#include "../version.h"
│ │ │ │ +
29
│ │ │ │ +
30#include "../far/topologyRefiner.h"
│ │ │ │ +
31#include "../far/patchTable.h"
│ │ │ │ +
32
│ │ │ │ +
33namespace OpenSubdiv {
│ │ │ │ +
34namespace OPENSUBDIV_VERSION {
│ │ │ │ +
35
│ │ │ │ +
36namespace Far {
│ │ │ │ +
37
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
41public:
│ │ │ │ +
42
│ │ │ │ +
│ │ │ │ +
45 struct Options {
│ │ │ │
46
│ │ │ │ -
47namespace OpenSubdiv {
│ │ │ │ -
48namespace OPENSUBDIV_VERSION {
│ │ │ │ -
49
│ │ │ │ -
50namespace Far {
│ │ │ │ -
51
│ │ │ │ -
55template <typename REAL>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
57
│ │ │ │ -
58public:
│ │ │ │ -
59 PrimvarRefinerReal(TopologyRefiner const & refiner) : _refiner(refiner) { }
│ │ │ │ - │ │ │ │ -
61
│ │ │ │ -
62 TopologyRefiner const & GetTopologyRefiner() const { return _refiner; }
│ │ │ │ -
63
│ │ │ │ -
65
│ │ │ │ -
100
│ │ │ │ -
│ │ │ │ -
113 template <class T, class U> void Interpolate(int level, T const & src, U & dst) const;
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
61 };
│ │ │ │ +
│ │ │ │ +
62
│ │ │ │ +
│ │ │ │ +
63 Options(unsigned int maxIsolation=10) :
│ │ │ │ +
64 generateAllLevels(false),
│ │ │ │ + │ │ │ │ + │ │ │ │ +
67 triangulateQuads(false),
│ │ │ │ + │ │ │ │ +
69 useInfSharpPatch(false),
│ │ │ │ +
70 maxIsolationLevel(maxIsolation & 0xf),
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
75 generateFVarTables(false),
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
82 { }
│ │ │ │ +
│ │ │ │ +
83
│ │ │ │ + │ │ │ │ +
86
│ │ │ │ +
88 void SetEndCapType(EndCapType e) { endCapType = e & 0x7; }
│ │ │ │ +
89
│ │ │ │ +
91 void SetMaxIsolationLevel(unsigned int level) { maxIsolationLevel = level & 0xf; }
│ │ │ │ +
92
│ │ │ │ +
94 template <typename REAL> void SetPatchPrecision();
│ │ │ │ +
95
│ │ │ │ +
97 template <typename REAL> void SetFVarPatchPrecision();
│ │ │ │ +
98
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ +
102
│ │ │ │ +
103 adaptiveOptions.useInfSharpPatch = useInfSharpPatch;
│ │ │ │ + │ │ │ │ +
105 adaptiveOptions.considerFVarChannels = generateFVarTables &&
│ │ │ │ + │ │ │ │ +
107 return adaptiveOptions;
│ │ │ │ +
108 }
│ │ │ │ +
│ │ │ │ +
109
│ │ │ │ +
110 unsigned int generateAllLevels : 1,
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │
114
│ │ │ │ -
│ │ │ │ -
130 template <class T, class U> void InterpolateVarying(int level, T const & src, U & dst) const;
│ │ │ │ -
131
│ │ │ │ -
│ │ │ │ -
148 template <class T, class U> void InterpolateFaceUniform(int level, T const & src, U & dst) const;
│ │ │ │ -
149
│ │ │ │ -
│ │ │ │ -
161 template <class T, class U> void InterpolateFaceVarying(int level, T const & src, U & dst, int channel = 0) const;
│ │ │ │ -
162
│ │ │ │ -
163
│ │ │ │ -
│ │ │ │ -
175 template <class T, class U> void Limit(T const & src, U & dstPos) const;
│ │ │ │ -
176
│ │ │ │ -
177 template <class T, class U, class U1, class U2>
│ │ │ │ -
│ │ │ │ -
178 void Limit(T const & src, U & dstPos, U1 & dstTan1, U2 & dstTan2) const;
│ │ │ │ -
179
│ │ │ │ -
│ │ │ │ -
180 template <class T, class U> void LimitFaceVarying(T const & src, U & dst, int channel = 0) const;
│ │ │ │ -
181
│ │ │ │ -
183
│ │ │ │ -
184private:
│ │ │ │ -
185 typedef REAL Weight;
│ │ │ │ -
186
│ │ │ │ -
187 // Non-copyable:
│ │ │ │ -
188 PrimvarRefinerReal(PrimvarRefinerReal const & src) : _refiner(src._refiner) { }
│ │ │ │ -
189 PrimvarRefinerReal & operator=(PrimvarRefinerReal const &) { return *this; }
│ │ │ │ -
190
│ │ │ │ -
191 template <Sdc::SchemeType SCHEME, class T, class U> void interpFromFaces(int, T const &, U &) const;
│ │ │ │ -
192 template <Sdc::SchemeType SCHEME, class T, class U> void interpFromEdges(int, T const &, U &) const;
│ │ │ │ -
193 template <Sdc::SchemeType SCHEME, class T, class U> void interpFromVerts(int, T const &, U &) const;
│ │ │ │ -
194
│ │ │ │ -
195 template <Sdc::SchemeType SCHEME, class T, class U> void interpFVarFromFaces(int, T const &, U &, int) const;
│ │ │ │ -
196 template <Sdc::SchemeType SCHEME, class T, class U> void interpFVarFromEdges(int, T const &, U &, int) const;
│ │ │ │ -
197 template <Sdc::SchemeType SCHEME, class T, class U> void interpFVarFromVerts(int, T const &, U &, int) const;
│ │ │ │ -
198
│ │ │ │ -
199 template <Sdc::SchemeType SCHEME, class T, class U, class U1, class U2>
│ │ │ │ -
200 void limit(T const & src, U & pos, U1 * tan1, U2 * tan2) const;
│ │ │ │ -
201
│ │ │ │ -
202 template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ -
203 void limitFVar(T const & src, U & dst, int channel) const;
│ │ │ │ -
204
│ │ │ │ -
205private:
│ │ │ │ -
206 TopologyRefiner const & _refiner;
│ │ │ │ -
207
│ │ │ │ -
208private:
│ │ │ │ -
209 //
│ │ │ │ -
210 // Local class to fulfill interface for <typename MASK> in the Scheme mask queries:
│ │ │ │ -
211 //
│ │ │ │ -
212 class Mask {
│ │ │ │ -
213 public:
│ │ │ │ -
214 typedef REAL Weight; // Also part of the expected interface
│ │ │ │ -
215
│ │ │ │ -
216 public:
│ │ │ │ -
217 Mask(Weight* v, Weight* e, Weight* f) :
│ │ │ │ -
218 _vertWeights(v), _edgeWeights(e), _faceWeights(f),
│ │ │ │ -
219 _vertCount(0), _edgeCount(0), _faceCount(0),
│ │ │ │ -
220 _faceWeightsForFaceCenters(false)
│ │ │ │ -
221 { }
│ │ │ │ -
222
│ │ │ │ -
223 ~Mask() { }
│ │ │ │ -
224
│ │ │ │ -
225 public: // Generic interface expected of <typename MASK>:
│ │ │ │ -
226 int GetNumVertexWeights() const { return _vertCount; }
│ │ │ │ -
227 int GetNumEdgeWeights() const { return _edgeCount; }
│ │ │ │ -
228 int GetNumFaceWeights() const { return _faceCount; }
│ │ │ │ -
229
│ │ │ │ -
230 void SetNumVertexWeights(int count) { _vertCount = count; }
│ │ │ │ -
231 void SetNumEdgeWeights( int count) { _edgeCount = count; }
│ │ │ │ -
232 void SetNumFaceWeights( int count) { _faceCount = count; }
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
118
│ │ │ │ +
119 // end-capping
│ │ │ │ + │ │ │ │ + │ │ │ │ +
123
│ │ │ │ +
124 // varying
│ │ │ │ + │ │ │ │ + │ │ │ │ +
127
│ │ │ │ +
128 // face-varying
│ │ │ │ + │ │ │ │ +
130
│ │ │ │ +
131 // precision
│ │ │ │ + │ │ │ │ + │ │ │ │ +
134
│ │ │ │ +
135 // legacy behaviors (default to true)
│ │ │ │ + │ │ │ │ + │ │ │ │ +
138
│ │ │ │ + │ │ │ │ +
140 int const * fvarChannelIndices;
│ │ │ │ +
141 };
│ │ │ │ +
│ │ │ │ +
142
│ │ │ │ +
175 static PatchTable * Create(TopologyRefiner const & refiner,
│ │ │ │ +
176 Options options = Options(),
│ │ │ │ +
177 ConstIndexArray selectedFaces = ConstIndexArray());
│ │ │ │ +
178
│ │ │ │ +
179public:
│ │ │ │ +
180 // PatchFaceTag
│ │ │ │ +
181 //
│ │ │ │ +
182 // This simple struct was previously used within the factory to take inventory of
│ │ │ │ +
183 // various kinds of patches to fully allocate buffers prior to populating them. It
│ │ │ │ +
184 // was not intended to be exposed as part of the public interface.
│ │ │ │ +
185 //
│ │ │ │ +
186 // It is no longer used internally and is being kept here to respect preservation
│ │ │ │ +
187 // of the public interface, but it will be deprecated at the earliest opportunity.
│ │ │ │ +
188 //
│ │ │ │ +
191 //
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
193 public:
│ │ │ │ +
194 unsigned int _hasPatch : 1;
│ │ │ │ +
195 unsigned int _isRegular : 1;
│ │ │ │ +
196 unsigned int _transitionMask : 4;
│ │ │ │ +
197 unsigned int _boundaryMask : 4;
│ │ │ │ +
198 unsigned int _boundaryIndex : 2;
│ │ │ │ +
199 unsigned int _boundaryCount : 3;
│ │ │ │ +
200 unsigned int _hasBoundaryEdge : 3;
│ │ │ │ +
201 unsigned int _isSingleCrease : 1;
│ │ │ │ +
202
│ │ │ │ +
203 void clear();
│ │ │ │ +
204 void assignBoundaryPropertiesFromEdgeMask(int boundaryEdgeMask);
│ │ │ │ +
205 void assignBoundaryPropertiesFromVertexMask(int boundaryVertexMask);
│ │ │ │ +
206 void assignTransitionPropertiesFromEdgeMask(int boundaryVertexMask);
│ │ │ │ +
207 };
│ │ │ │ +
│ │ │ │ +
208 typedef std::vector<PatchFaceTag> PatchTagVector;
│ │ │ │ +
209};
│ │ │ │ +
│ │ │ │ +
210
│ │ │ │ +
211
│ │ │ │ +
│ │ │ │ +
212template <> inline void PatchTableFactory::Options::SetPatchPrecision<float>() {
│ │ │ │ +
213 patchPrecisionDouble = false;
│ │ │ │ +
214}
│ │ │ │ +
│ │ │ │ +
│ │ │ │ +
215template <> inline void PatchTableFactory::Options::SetFVarPatchPrecision<float>() {
│ │ │ │ +
216 fvarPatchPrecisionDouble = false;
│ │ │ │ +
217}
│ │ │ │ +
│ │ │ │ +
218
│ │ │ │ +
219template <> inline void PatchTableFactory::Options::SetPatchPrecision<double>() {
│ │ │ │ +
220 patchPrecisionDouble = true;
│ │ │ │ +
221}
│ │ │ │ +
222template <> inline void PatchTableFactory::Options::SetFVarPatchPrecision<double>() {
│ │ │ │ +
223 fvarPatchPrecisionDouble = true;
│ │ │ │ +
224}
│ │ │ │ +
225
│ │ │ │ +
226
│ │ │ │ +
227} // end namespace Far
│ │ │ │ +
228
│ │ │ │ +
229} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
230using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
231
│ │ │ │ +
232} // end namespace OpenSubdiv
│ │ │ │
233
│ │ │ │ -
234 Weight const& VertexWeight(int index) const { return _vertWeights[index]; }
│ │ │ │ -
235 Weight const& EdgeWeight( int index) const { return _edgeWeights[index]; }
│ │ │ │ -
236 Weight const& FaceWeight( int index) const { return _faceWeights[index]; }
│ │ │ │ -
237
│ │ │ │ -
238 Weight& VertexWeight(int index) { return _vertWeights[index]; }
│ │ │ │ -
239 Weight& EdgeWeight( int index) { return _edgeWeights[index]; }
│ │ │ │ -
240 Weight& FaceWeight( int index) { return _faceWeights[index]; }
│ │ │ │ -
241
│ │ │ │ -
242 bool AreFaceWeightsForFaceCenters() const { return _faceWeightsForFaceCenters; }
│ │ │ │ -
243 void SetFaceWeightsForFaceCenters(bool on) { _faceWeightsForFaceCenters = on; }
│ │ │ │ -
244
│ │ │ │ -
245 private:
│ │ │ │ -
246 Weight* _vertWeights;
│ │ │ │ -
247 Weight* _edgeWeights;
│ │ │ │ -
248 Weight* _faceWeights;
│ │ │ │ -
249
│ │ │ │ -
250 int _vertCount;
│ │ │ │ -
251 int _edgeCount;
│ │ │ │ -
252 int _faceCount;
│ │ │ │ -
253
│ │ │ │ -
254 bool _faceWeightsForFaceCenters;
│ │ │ │ -
255 };
│ │ │ │ -
256};
│ │ │ │ -
257
│ │ │ │ -
258
│ │ │ │ -
259//
│ │ │ │ -
260// Public entry points to the methods. Queries of the scheme type and its
│ │ │ │ -
261// use as a template parameter in subsequent implementation will be factored
│ │ │ │ -
262// out of a later release:
│ │ │ │ -
263//
│ │ │ │ -
264template <typename REAL>
│ │ │ │ -
265template <class T, class U>
│ │ │ │ -
266inline void
│ │ │ │ -
│ │ │ │ -
267PrimvarRefinerReal<REAL>::Interpolate(int level, T const & src, U & dst) const {
│ │ │ │ -
268
│ │ │ │ -
269 assert(level>0 && level<=(int)_refiner._refinements.size());
│ │ │ │ -
270
│ │ │ │ -
271 switch (_refiner._subdivType) {
│ │ │ │ - │ │ │ │ -
273 interpFromFaces<Sdc::SCHEME_CATMARK>(level, src, dst);
│ │ │ │ -
274 interpFromEdges<Sdc::SCHEME_CATMARK>(level, src, dst);
│ │ │ │ -
275 interpFromVerts<Sdc::SCHEME_CATMARK>(level, src, dst);
│ │ │ │ -
276 break;
│ │ │ │ -
277 case Sdc::SCHEME_LOOP:
│ │ │ │ -
278 interpFromFaces<Sdc::SCHEME_LOOP>(level, src, dst);
│ │ │ │ -
279 interpFromEdges<Sdc::SCHEME_LOOP>(level, src, dst);
│ │ │ │ -
280 interpFromVerts<Sdc::SCHEME_LOOP>(level, src, dst);
│ │ │ │ -
281 break;
│ │ │ │ - │ │ │ │ -
283 interpFromFaces<Sdc::SCHEME_BILINEAR>(level, src, dst);
│ │ │ │ -
284 interpFromEdges<Sdc::SCHEME_BILINEAR>(level, src, dst);
│ │ │ │ -
285 interpFromVerts<Sdc::SCHEME_BILINEAR>(level, src, dst);
│ │ │ │ -
286 break;
│ │ │ │ -
287 }
│ │ │ │ -
288}
│ │ │ │ -
│ │ │ │ -
289
│ │ │ │ -
290template <typename REAL>
│ │ │ │ -
291template <class T, class U>
│ │ │ │ -
292inline void
│ │ │ │ -
│ │ │ │ -
293PrimvarRefinerReal<REAL>::InterpolateFaceVarying(int level, T const & src, U & dst, int channel) const {
│ │ │ │ -
294
│ │ │ │ -
295 assert(level>0 && level<=(int)_refiner._refinements.size());
│ │ │ │ -
296
│ │ │ │ -
297 switch (_refiner._subdivType) {
│ │ │ │ - │ │ │ │ -
299 interpFVarFromFaces<Sdc::SCHEME_CATMARK>(level, src, dst, channel);
│ │ │ │ -
300 interpFVarFromEdges<Sdc::SCHEME_CATMARK>(level, src, dst, channel);
│ │ │ │ -
301 interpFVarFromVerts<Sdc::SCHEME_CATMARK>(level, src, dst, channel);
│ │ │ │ -
302 break;
│ │ │ │ -
303 case Sdc::SCHEME_LOOP:
│ │ │ │ -
304 interpFVarFromFaces<Sdc::SCHEME_LOOP>(level, src, dst, channel);
│ │ │ │ -
305 interpFVarFromEdges<Sdc::SCHEME_LOOP>(level, src, dst, channel);
│ │ │ │ -
306 interpFVarFromVerts<Sdc::SCHEME_LOOP>(level, src, dst, channel);
│ │ │ │ -
307 break;
│ │ │ │ - │ │ │ │ -
309 interpFVarFromFaces<Sdc::SCHEME_BILINEAR>(level, src, dst, channel);
│ │ │ │ -
310 interpFVarFromEdges<Sdc::SCHEME_BILINEAR>(level, src, dst, channel);
│ │ │ │ -
311 interpFVarFromVerts<Sdc::SCHEME_BILINEAR>(level, src, dst, channel);
│ │ │ │ -
312 break;
│ │ │ │ -
313 }
│ │ │ │ -
314}
│ │ │ │ -
│ │ │ │ -
315
│ │ │ │ -
316template <typename REAL>
│ │ │ │ -
317template <class T, class U>
│ │ │ │ -
318inline void
│ │ │ │ -
│ │ │ │ -
319PrimvarRefinerReal<REAL>::Limit(T const & src, U & dst) const {
│ │ │ │ -
320
│ │ │ │ -
321 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == 0) {
│ │ │ │ - │ │ │ │ -
323 "Failure in PrimvarRefiner::Limit() -- "
│ │ │ │ -
324 "last level of refinement does not include full topology.");
│ │ │ │ -
325 return;
│ │ │ │ -
326 }
│ │ │ │ -
327
│ │ │ │ -
328 switch (_refiner._subdivType) {
│ │ │ │ - │ │ │ │ -
330 limit<Sdc::SCHEME_CATMARK>(src, dst, (U*)0, (U*)0);
│ │ │ │ -
331 break;
│ │ │ │ -
332 case Sdc::SCHEME_LOOP:
│ │ │ │ -
333 limit<Sdc::SCHEME_LOOP>(src, dst, (U*)0, (U*)0);
│ │ │ │ -
334 break;
│ │ │ │ - │ │ │ │ -
336 limit<Sdc::SCHEME_BILINEAR>(src, dst, (U*)0, (U*)0);
│ │ │ │ -
337 break;
│ │ │ │ -
338 }
│ │ │ │ -
339}
│ │ │ │ -
│ │ │ │ -
340
│ │ │ │ -
341template <typename REAL>
│ │ │ │ -
342template <class T, class U, class U1, class U2>
│ │ │ │ -
343inline void
│ │ │ │ -
│ │ │ │ -
344PrimvarRefinerReal<REAL>::Limit(T const & src, U & dstPos, U1 & dstTan1, U2 & dstTan2) const {
│ │ │ │ -
345
│ │ │ │ -
346 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == 0) {
│ │ │ │ - │ │ │ │ -
348 "Failure in PrimvarRefiner::Limit() -- "
│ │ │ │ -
349 "last level of refinement does not include full topology.");
│ │ │ │ -
350 return;
│ │ │ │ -
351 }
│ │ │ │ -
352
│ │ │ │ -
353 switch (_refiner._subdivType) {
│ │ │ │ - │ │ │ │ -
355 limit<Sdc::SCHEME_CATMARK>(src, dstPos, &dstTan1, &dstTan2);
│ │ │ │ -
356 break;
│ │ │ │ -
357 case Sdc::SCHEME_LOOP:
│ │ │ │ -
358 limit<Sdc::SCHEME_LOOP>(src, dstPos, &dstTan1, &dstTan2);
│ │ │ │ -
359 break;
│ │ │ │ - │ │ │ │ -
361 limit<Sdc::SCHEME_BILINEAR>(src, dstPos, &dstTan1, &dstTan2);
│ │ │ │ -
362 break;
│ │ │ │ -
363 }
│ │ │ │ -
364}
│ │ │ │ -
│ │ │ │ -
365
│ │ │ │ -
366template <typename REAL>
│ │ │ │ -
367template <class T, class U>
│ │ │ │ -
368inline void
│ │ │ │ -
│ │ │ │ -
369PrimvarRefinerReal<REAL>::LimitFaceVarying(T const & src, U & dst, int channel) const {
│ │ │ │ -
370
│ │ │ │ -
371 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == 0) {
│ │ │ │ - │ │ │ │ -
373 "Failure in PrimvarRefiner::LimitFaceVarying() -- "
│ │ │ │ -
374 "last level of refinement does not include full topology.");
│ │ │ │ -
375 return;
│ │ │ │ -
376 }
│ │ │ │ -
377
│ │ │ │ -
378 switch (_refiner._subdivType) {
│ │ │ │ - │ │ │ │ -
380 limitFVar<Sdc::SCHEME_CATMARK>(src, dst, channel);
│ │ │ │ -
381 break;
│ │ │ │ -
382 case Sdc::SCHEME_LOOP:
│ │ │ │ -
383 limitFVar<Sdc::SCHEME_LOOP>(src, dst, channel);
│ │ │ │ -
384 break;
│ │ │ │ - │ │ │ │ -
386 limitFVar<Sdc::SCHEME_BILINEAR>(src, dst, channel);
│ │ │ │ -
387 break;
│ │ │ │ -
388 }
│ │ │ │ -
389}
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
390
│ │ │ │ -
391template <typename REAL>
│ │ │ │ -
392template <class T, class U>
│ │ │ │ -
393inline void
│ │ │ │ -
│ │ │ │ -
394PrimvarRefinerReal<REAL>::InterpolateFaceUniform(int level, T const & src, U & dst) const {
│ │ │ │ -
395
│ │ │ │ -
396 assert(level>0 && level<=(int)_refiner._refinements.size());
│ │ │ │ -
397
│ │ │ │ -
398 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ -
399 Vtr::internal::Level const & child = refinement.child();
│ │ │ │ -
400
│ │ │ │ -
401 for (int cFace = 0; cFace < child.getNumFaces(); ++cFace) {
│ │ │ │ -
402
│ │ │ │ -
403 Vtr::Index pFace = refinement.getChildFaceParentFace(cFace);
│ │ │ │ -
404
│ │ │ │ -
405 dst[cFace] = src[pFace];
│ │ │ │ -
406 }
│ │ │ │ -
407}
│ │ │ │ -
│ │ │ │ -
408
│ │ │ │ -
409template <typename REAL>
│ │ │ │ -
410template <class T, class U>
│ │ │ │ -
411inline void
│ │ │ │ -
│ │ │ │ -
412PrimvarRefinerReal<REAL>::InterpolateVarying(int level, T const & src, U & dst) const {
│ │ │ │ -
413
│ │ │ │ -
414 assert(level>0 && level<=(int)_refiner._refinements.size());
│ │ │ │ -
415
│ │ │ │ -
416 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ -
417 Vtr::internal::Level const & parent = refinement.parent();
│ │ │ │ -
418
│ │ │ │ -
419 //
│ │ │ │ -
420 // Group values to interpolate based on origin -- note that there may
│ │ │ │ -
421 // be none originating from faces:
│ │ │ │ -
422 //
│ │ │ │ -
423 if (refinement.getNumChildVerticesFromFaces() > 0) {
│ │ │ │ -
424
│ │ │ │ -
425 for (int face = 0; face < parent.getNumFaces(); ++face) {
│ │ │ │ -
426
│ │ │ │ -
427 Vtr::Index cVert = refinement.getFaceChildVertex(face);
│ │ │ │ -
428 if (Vtr::IndexIsValid(cVert)) {
│ │ │ │ -
429
│ │ │ │ -
430 // Apply the weights to the parent face's vertices:
│ │ │ │ -
431 ConstIndexArray fVerts = parent.getFaceVertices(face);
│ │ │ │ -
432
│ │ │ │ -
433 Weight fVaryingWeight = 1.0f / (Weight) fVerts.size();
│ │ │ │ -
434
│ │ │ │ -
435 dst[cVert].Clear();
│ │ │ │ -
436 for (int i = 0; i < fVerts.size(); ++i) {
│ │ │ │ -
437 dst[cVert].AddWithWeight(src[fVerts[i]], fVaryingWeight);
│ │ │ │ -
438 }
│ │ │ │ -
439 }
│ │ │ │ -
440 }
│ │ │ │ -
441 }
│ │ │ │ -
442 for (int edge = 0; edge < parent.getNumEdges(); ++edge) {
│ │ │ │ -
443
│ │ │ │ -
444 Vtr::Index cVert = refinement.getEdgeChildVertex(edge);
│ │ │ │ -
445 if (Vtr::IndexIsValid(cVert)) {
│ │ │ │ -
446
│ │ │ │ -
447 // Apply the weights to the parent edges's vertices
│ │ │ │ -
448 ConstIndexArray eVerts = parent.getEdgeVertices(edge);
│ │ │ │ -
449
│ │ │ │ -
450 dst[cVert].Clear();
│ │ │ │ -
451 dst[cVert].AddWithWeight(src[eVerts[0]], 0.5f);
│ │ │ │ -
452 dst[cVert].AddWithWeight(src[eVerts[1]], 0.5f);
│ │ │ │ -
453 }
│ │ │ │ -
454 }
│ │ │ │ -
455 for (int vert = 0; vert < parent.getNumVertices(); ++vert) {
│ │ │ │ -
456
│ │ │ │ -
457 Vtr::Index cVert = refinement.getVertexChildVertex(vert);
│ │ │ │ -
458 if (Vtr::IndexIsValid(cVert)) {
│ │ │ │ -
459
│ │ │ │ -
460 // Essentially copy the parent vertex:
│ │ │ │ -
461 dst[cVert].Clear();
│ │ │ │ -
462 dst[cVert].AddWithWeight(src[vert], 1.0f);
│ │ │ │ -
463 }
│ │ │ │ -
464 }
│ │ │ │ -
465}
│ │ │ │ -
│ │ │ │ -
466
│ │ │ │ -
467
│ │ │ │ -
468//
│ │ │ │ -
469// Internal implementation methods -- grouping vertices to be interpolated
│ │ │ │ -
470// based on the type of parent component from which they originated:
│ │ │ │ -
471//
│ │ │ │ -
472template <typename REAL>
│ │ │ │ -
473template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ -
474inline void
│ │ │ │ -
475PrimvarRefinerReal<REAL>::interpFromFaces(int level, T const & src, U & dst) const {
│ │ │ │ -
476
│ │ │ │ -
477 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ -
478 Vtr::internal::Level const & parent = refinement.parent();
│ │ │ │ -
479
│ │ │ │ -
480 if (refinement.getNumChildVerticesFromFaces() == 0) return;
│ │ │ │ -
481
│ │ │ │ -
482 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ -
483
│ │ │ │ -
484 Vtr::internal::StackBuffer<Weight,16> fVertWeights(parent.getMaxValence());
│ │ │ │ -
485
│ │ │ │ -
486 for (int face = 0; face < parent.getNumFaces(); ++face) {
│ │ │ │ -
487
│ │ │ │ -
488 Vtr::Index cVert = refinement.getFaceChildVertex(face);
│ │ │ │ -
489 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ -
490 continue;
│ │ │ │ -
491
│ │ │ │ -
492 // Declare and compute mask weights for this vertex relative to its parent face:
│ │ │ │ -
493 ConstIndexArray fVerts = parent.getFaceVertices(face);
│ │ │ │ -
494
│ │ │ │ -
495 Mask fMask(fVertWeights, 0, 0);
│ │ │ │ -
496 Vtr::internal::FaceInterface fHood(fVerts.size());
│ │ │ │ -
497
│ │ │ │ -
498 scheme.ComputeFaceVertexMask(fHood, fMask);
│ │ │ │ -
499
│ │ │ │ -
500 // Apply the weights to the parent face's vertices:
│ │ │ │ -
501 dst[cVert].Clear();
│ │ │ │ -
502
│ │ │ │ -
503 for (int i = 0; i < fVerts.size(); ++i) {
│ │ │ │ -
504
│ │ │ │ -
505 dst[cVert].AddWithWeight(src[fVerts[i]], fVertWeights[i]);
│ │ │ │ -
506 }
│ │ │ │ -
507 }
│ │ │ │ -
508}
│ │ │ │ -
509
│ │ │ │ -
510template <typename REAL>
│ │ │ │ -
511template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ -
512inline void
│ │ │ │ -
513PrimvarRefinerReal<REAL>::interpFromEdges(int level, T const & src, U & dst) const {
│ │ │ │ -
514
│ │ │ │ -
515 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ -
516 Vtr::internal::Level const & parent = refinement.parent();
│ │ │ │ -
517 Vtr::internal::Level const & child = refinement.child();
│ │ │ │ -
518
│ │ │ │ -
519 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ -
520
│ │ │ │ -
521 Vtr::internal::EdgeInterface eHood(parent);
│ │ │ │ -
522
│ │ │ │ -
523 Weight eVertWeights[2];
│ │ │ │ -
524 Vtr::internal::StackBuffer<Weight,8> eFaceWeights(parent.getMaxEdgeFaces());
│ │ │ │ -
525
│ │ │ │ -
526 for (int edge = 0; edge < parent.getNumEdges(); ++edge) {
│ │ │ │ -
527
│ │ │ │ -
528 Vtr::Index cVert = refinement.getEdgeChildVertex(edge);
│ │ │ │ -
529 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ -
530 continue;
│ │ │ │ -
531
│ │ │ │ -
532 // Declare and compute mask weights for this vertex relative to its parent edge:
│ │ │ │ -
533 ConstIndexArray eVerts = parent.getEdgeVertices(edge),
│ │ │ │ -
534 eFaces = parent.getEdgeFaces(edge);
│ │ │ │ -
535
│ │ │ │ -
536 Mask eMask(eVertWeights, 0, eFaceWeights);
│ │ │ │ -
537
│ │ │ │ -
538 eHood.SetIndex(edge);
│ │ │ │ -
539
│ │ │ │ -
540 Sdc::Crease::Rule pRule = (parent.getEdgeSharpness(edge) > 0.0f) ? Sdc::Crease::RULE_CREASE : Sdc::Crease::RULE_SMOOTH;
│ │ │ │ -
541 Sdc::Crease::Rule cRule = child.getVertexRule(cVert);
│ │ │ │ -
542
│ │ │ │ -
543 scheme.ComputeEdgeVertexMask(eHood, eMask, pRule, cRule);
│ │ │ │ -
544
│ │ │ │ -
545 // Apply the weights to the parent edges's vertices and (if applicable) to
│ │ │ │ -
546 // the child vertices of its incident faces:
│ │ │ │ -
547 dst[cVert].Clear();
│ │ │ │ -
548 dst[cVert].AddWithWeight(src[eVerts[0]], eVertWeights[0]);
│ │ │ │ -
549 dst[cVert].AddWithWeight(src[eVerts[1]], eVertWeights[1]);
│ │ │ │ -
550
│ │ │ │ -
551 if (eMask.GetNumFaceWeights() > 0) {
│ │ │ │ -
552
│ │ │ │ -
553 for (int i = 0; i < eFaces.size(); ++i) {
│ │ │ │ -
554
│ │ │ │ -
555 if (eMask.AreFaceWeightsForFaceCenters()) {
│ │ │ │ -
556 assert(refinement.getNumChildVerticesFromFaces() > 0);
│ │ │ │ -
557 Vtr::Index cVertOfFace = refinement.getFaceChildVertex(eFaces[i]);
│ │ │ │ -
558
│ │ │ │ -
559 assert(Vtr::IndexIsValid(cVertOfFace));
│ │ │ │ -
560 dst[cVert].AddWithWeight(dst[cVertOfFace], eFaceWeights[i]);
│ │ │ │ -
561 } else {
│ │ │ │ -
562 Vtr::Index pFace = eFaces[i];
│ │ │ │ -
563 ConstIndexArray pFaceEdges = parent.getFaceEdges(pFace),
│ │ │ │ -
564 pFaceVerts = parent.getFaceVertices(pFace);
│ │ │ │ -
565
│ │ │ │ -
566 int eInFace = 0;
│ │ │ │ -
567 for ( ; pFaceEdges[eInFace] != edge; ++eInFace ) ;
│ │ │ │ -
568
│ │ │ │ -
569 int vInFace = eInFace + 2;
│ │ │ │ -
570 if (vInFace >= pFaceVerts.size()) vInFace -= pFaceVerts.size();
│ │ │ │ -
571
│ │ │ │ -
572 Vtr::Index pVertNext = pFaceVerts[vInFace];
│ │ │ │ -
573 dst[cVert].AddWithWeight(src[pVertNext], eFaceWeights[i]);
│ │ │ │ -
574 }
│ │ │ │ -
575 }
│ │ │ │ -
576 }
│ │ │ │ -
577 }
│ │ │ │ -
578}
│ │ │ │ -
579
│ │ │ │ -
580template <typename REAL>
│ │ │ │ -
581template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ -
582inline void
│ │ │ │ -
583PrimvarRefinerReal<REAL>::interpFromVerts(int level, T const & src, U & dst) const {
│ │ │ │ -
584
│ │ │ │ -
585 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ -
586 Vtr::internal::Level const & parent = refinement.parent();
│ │ │ │ -
587 Vtr::internal::Level const & child = refinement.child();
│ │ │ │ -
588
│ │ │ │ -
589 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ -
590
│ │ │ │ -
591 Vtr::internal::VertexInterface vHood(parent, child);
│ │ │ │ -
592
│ │ │ │ -
593 Vtr::internal::StackBuffer<Weight,32> weightBuffer(2*parent.getMaxValence());
│ │ │ │ -
594
│ │ │ │ -
595 for (int vert = 0; vert < parent.getNumVertices(); ++vert) {
│ │ │ │ -
596
│ │ │ │ -
597 Vtr::Index cVert = refinement.getVertexChildVertex(vert);
│ │ │ │ -
598 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ -
599 continue;
│ │ │ │ -
600
│ │ │ │ -
601 // Declare and compute mask weights for this vertex relative to its parent edge:
│ │ │ │ -
602 ConstIndexArray vEdges = parent.getVertexEdges(vert),
│ │ │ │ -
603 vFaces = parent.getVertexFaces(vert);
│ │ │ │ -
604
│ │ │ │ -
605 Weight vVertWeight,
│ │ │ │ -
606 * vEdgeWeights = weightBuffer,
│ │ │ │ -
607 * vFaceWeights = vEdgeWeights + vEdges.size();
│ │ │ │ -
608
│ │ │ │ -
609 Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights);
│ │ │ │ -
610
│ │ │ │ -
611 vHood.SetIndex(vert, cVert);
│ │ │ │ -
612
│ │ │ │ -
613 Sdc::Crease::Rule pRule = parent.getVertexRule(vert);
│ │ │ │ -
614 Sdc::Crease::Rule cRule = child.getVertexRule(cVert);
│ │ │ │ -
615
│ │ │ │ -
616 scheme.ComputeVertexVertexMask(vHood, vMask, pRule, cRule);
│ │ │ │ -
617
│ │ │ │ -
618 // Apply the weights to the parent vertex, the vertices opposite its incident
│ │ │ │ -
619 // edges, and the child vertices of its incident faces:
│ │ │ │ -
620 //
│ │ │ │ -
621 // In order to improve numerical precision, it's better to apply smaller weights
│ │ │ │ -
622 // first, so begin with the face-weights followed by the edge-weights and the
│ │ │ │ -
623 // vertex weight last.
│ │ │ │ -
624 dst[cVert].Clear();
│ │ │ │ -
625
│ │ │ │ -
626 if (vMask.GetNumFaceWeights() > 0) {
│ │ │ │ -
627 assert(vMask.AreFaceWeightsForFaceCenters());
│ │ │ │ -
628
│ │ │ │ -
629 for (int i = 0; i < vFaces.size(); ++i) {
│ │ │ │ -
630
│ │ │ │ -
631 Vtr::Index cVertOfFace = refinement.getFaceChildVertex(vFaces[i]);
│ │ │ │ -
632 assert(Vtr::IndexIsValid(cVertOfFace));
│ │ │ │ -
633 dst[cVert].AddWithWeight(dst[cVertOfFace], vFaceWeights[i]);
│ │ │ │ -
634 }
│ │ │ │ -
635 }
│ │ │ │ -
636 if (vMask.GetNumEdgeWeights() > 0) {
│ │ │ │ -
637
│ │ │ │ -
638 for (int i = 0; i < vEdges.size(); ++i) {
│ │ │ │ -
639
│ │ │ │ -
640 ConstIndexArray eVerts = parent.getEdgeVertices(vEdges[i]);
│ │ │ │ -
641 Vtr::Index pVertOppositeEdge = (eVerts[0] == vert) ? eVerts[1] : eVerts[0];
│ │ │ │ -
642
│ │ │ │ -
643 dst[cVert].AddWithWeight(src[pVertOppositeEdge], vEdgeWeights[i]);
│ │ │ │ -
644 }
│ │ │ │ -
645 }
│ │ │ │ -
646 dst[cVert].AddWithWeight(src[vert], vVertWeight);
│ │ │ │ -
647 }
│ │ │ │ -
648}
│ │ │ │ -
649
│ │ │ │ -
650
│ │ │ │ -
651//
│ │ │ │ -
652// Internal face-varying implementation details:
│ │ │ │ -
653//
│ │ │ │ -
654template <typename REAL>
│ │ │ │ -
655template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ -
656inline void
│ │ │ │ -
657PrimvarRefinerReal<REAL>::interpFVarFromFaces(int level, T const & src, U & dst, int channel) const {
│ │ │ │ -
658
│ │ │ │ -
659 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ -
660
│ │ │ │ -
661 if (refinement.getNumChildVerticesFromFaces() == 0) return;
│ │ │ │ -
662
│ │ │ │ -
663 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ -
664
│ │ │ │ -
665 Vtr::internal::Level const & parentLevel = refinement.parent();
│ │ │ │ -
666 Vtr::internal::Level const & childLevel = refinement.child();
│ │ │ │ -
667
│ │ │ │ -
668 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel(channel);
│ │ │ │ -
669 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel(channel);
│ │ │ │ -
670
│ │ │ │ -
671 Vtr::internal::StackBuffer<Weight,16> fValueWeights(parentLevel.getMaxValence());
│ │ │ │ -
672
│ │ │ │ -
673 for (int face = 0; face < parentLevel.getNumFaces(); ++face) {
│ │ │ │ -
674
│ │ │ │ -
675 Vtr::Index cVert = refinement.getFaceChildVertex(face);
│ │ │ │ -
676 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ -
677 continue;
│ │ │ │ -
678
│ │ │ │ -
679 Vtr::Index cVertValue = childFVar.getVertexValueOffset(cVert);
│ │ │ │ -
680
│ │ │ │ -
681 // The only difference for face-varying here is that we get the values associated
│ │ │ │ -
682 // with each face-vertex directly from the FVarLevel, rather than using the parent
│ │ │ │ -
683 // face-vertices directly. If any face-vertex has any sibling values, then we may
│ │ │ │ -
684 // get the wrong one using the face-vertex index directly.
│ │ │ │ -
685
│ │ │ │ -
686 // Declare and compute mask weights for this vertex relative to its parent face:
│ │ │ │ -
687 ConstIndexArray fValues = parentFVar.getFaceValues(face);
│ │ │ │ -
688
│ │ │ │ -
689 Mask fMask(fValueWeights, 0, 0);
│ │ │ │ -
690 Vtr::internal::FaceInterface fHood(fValues.size());
│ │ │ │ -
691
│ │ │ │ -
692 scheme.ComputeFaceVertexMask(fHood, fMask);
│ │ │ │ -
693
│ │ │ │ -
694 // Apply the weights to the parent face's vertices:
│ │ │ │ -
695 dst[cVertValue].Clear();
│ │ │ │ -
696
│ │ │ │ -
697 for (int i = 0; i < fValues.size(); ++i) {
│ │ │ │ -
698 dst[cVertValue].AddWithWeight(src[fValues[i]], fValueWeights[i]);
│ │ │ │ -
699 }
│ │ │ │ -
700 }
│ │ │ │ -
701}
│ │ │ │ -
702
│ │ │ │ -
703template <typename REAL>
│ │ │ │ -
704template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ -
705inline void
│ │ │ │ -
706PrimvarRefinerReal<REAL>::interpFVarFromEdges(int level, T const & src, U & dst, int channel) const {
│ │ │ │ -
707
│ │ │ │ -
708 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ -
709
│ │ │ │ -
710 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ -
711
│ │ │ │ -
712 Vtr::internal::Level const & parentLevel = refinement.parent();
│ │ │ │ -
713 Vtr::internal::Level const & childLevel = refinement.child();
│ │ │ │ -
714
│ │ │ │ -
715 Vtr::internal::FVarRefinement const & refineFVar = refinement.getFVarRefinement(channel);
│ │ │ │ -
716 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel(channel);
│ │ │ │ -
717 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel(channel);
│ │ │ │ -
718
│ │ │ │ -
719 //
│ │ │ │ -
720 // Allocate and initialize (if linearly interpolated) interpolation weights for
│ │ │ │ -
721 // the edge mask:
│ │ │ │ -
722 //
│ │ │ │ -
723 Weight eVertWeights[2];
│ │ │ │ -
724 Vtr::internal::StackBuffer<Weight,8> eFaceWeights(parentLevel.getMaxEdgeFaces());
│ │ │ │ -
725
│ │ │ │ -
726 Mask eMask(eVertWeights, 0, eFaceWeights);
│ │ │ │ -
727
│ │ │ │ -
728 bool isLinearFVar = parentFVar.isLinear() || (_refiner._subdivType == Sdc::SCHEME_BILINEAR);
│ │ │ │ -
729 if (isLinearFVar) {
│ │ │ │ -
730 eMask.SetNumVertexWeights(2);
│ │ │ │ -
731 eMask.SetNumEdgeWeights(0);
│ │ │ │ -
732 eMask.SetNumFaceWeights(0);
│ │ │ │ -
733
│ │ │ │ -
734 eVertWeights[0] = 0.5f;
│ │ │ │ -
735 eVertWeights[1] = 0.5f;
│ │ │ │ -
736 }
│ │ │ │ -
737
│ │ │ │ -
738 Vtr::internal::EdgeInterface eHood(parentLevel);
│ │ │ │ -
739
│ │ │ │ -
740 for (int edge = 0; edge < parentLevel.getNumEdges(); ++edge) {
│ │ │ │ -
741
│ │ │ │ -
742 Vtr::Index cVert = refinement.getEdgeChildVertex(edge);
│ │ │ │ -
743 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ -
744 continue;
│ │ │ │ -
745
│ │ │ │ -
746 ConstIndexArray cVertValues = childFVar.getVertexValues(cVert);
│ │ │ │ -
747
│ │ │ │ -
748 bool fvarEdgeVertMatchesVertex = childFVar.valueTopologyMatches(cVertValues[0]);
│ │ │ │ -
749 if (fvarEdgeVertMatchesVertex) {
│ │ │ │ -
750 //
│ │ │ │ -
751 // If smoothly interpolated, compute new weights for the edge mask:
│ │ │ │ -
752 //
│ │ │ │ -
753 if (!isLinearFVar) {
│ │ │ │ -
754 eHood.SetIndex(edge);
│ │ │ │ -
755
│ │ │ │ -
756 Sdc::Crease::Rule pRule = (parentLevel.getEdgeSharpness(edge) > 0.0f)
│ │ │ │ -
757 ? Sdc::Crease::RULE_CREASE : Sdc::Crease::RULE_SMOOTH;
│ │ │ │ -
758 Sdc::Crease::Rule cRule = childLevel.getVertexRule(cVert);
│ │ │ │ -
759
│ │ │ │ -
760 scheme.ComputeEdgeVertexMask(eHood, eMask, pRule, cRule);
│ │ │ │ -
761 }
│ │ │ │ -
762
│ │ │ │ -
763 // Apply the weights to the parent edge's vertices and (if applicable) to
│ │ │ │ -
764 // the child vertices of its incident faces:
│ │ │ │ -
765 //
│ │ │ │ -
766 // Even though the face-varying topology matches the vertex topology, we need
│ │ │ │ -
767 // to be careful here when getting values corresponding to the two end-vertices.
│ │ │ │ -
768 // While the edge may be continuous, the vertices at their ends may have
│ │ │ │ -
769 // discontinuities elsewhere in their neighborhood (i.e. on the "other side"
│ │ │ │ -
770 // of the end-vertex) and so have sibling values associated with them. In most
│ │ │ │ -
771 // cases the topology for an end-vertex will match and we can use it directly,
│ │ │ │ -
772 // but we must still check and retrieve as needed.
│ │ │ │ -
773 //
│ │ │ │ -
774 // Indices for values corresponding to face-vertices are guaranteed to match,
│ │ │ │ -
775 // so we can use the child-vertex indices directly.
│ │ │ │ -
776 //
│ │ │ │ -
777 // And by "directly", we always use getVertexValue(vertexIndex) to reference
│ │ │ │ -
778 // values in the "src" to account for the possible indirection that may exist at
│ │ │ │ -
779 // level 0 -- where there may be fewer values than vertices and an additional
│ │ │ │ -
780 // indirection is necessary. We can use a vertex index directly for "dst" when
│ │ │ │ -
781 // it matches.
│ │ │ │ -
782 //
│ │ │ │ -
783 Vtr::Index eVertValues[2];
│ │ │ │ -
784
│ │ │ │ -
785 parentFVar.getEdgeFaceValues(edge, 0, eVertValues);
│ │ │ │ -
786
│ │ │ │ -
787 Index cVertValue = cVertValues[0];
│ │ │ │ -
788
│ │ │ │ -
789 dst[cVertValue].Clear();
│ │ │ │ -
790 dst[cVertValue].AddWithWeight(src[eVertValues[0]], eVertWeights[0]);
│ │ │ │ -
791 dst[cVertValue].AddWithWeight(src[eVertValues[1]], eVertWeights[1]);
│ │ │ │ -
792
│ │ │ │ -
793 if (eMask.GetNumFaceWeights() > 0) {
│ │ │ │ -
794
│ │ │ │ -
795 ConstIndexArray eFaces = parentLevel.getEdgeFaces(edge);
│ │ │ │ -
796
│ │ │ │ -
797 for (int i = 0; i < eFaces.size(); ++i) {
│ │ │ │ -
798 if (eMask.AreFaceWeightsForFaceCenters()) {
│ │ │ │ -
799
│ │ │ │ -
800 Vtr::Index cVertOfFace = refinement.getFaceChildVertex(eFaces[i]);
│ │ │ │ -
801 assert(Vtr::IndexIsValid(cVertOfFace));
│ │ │ │ -
802
│ │ │ │ -
803 Vtr::Index cValueOfFace = childFVar.getVertexValueOffset(cVertOfFace);
│ │ │ │ -
804 dst[cVertValue].AddWithWeight(dst[cValueOfFace], eFaceWeights[i]);
│ │ │ │ -
805 } else {
│ │ │ │ -
806 Vtr::Index pFace = eFaces[i];
│ │ │ │ -
807 ConstIndexArray pFaceEdges = parentLevel.getFaceEdges(pFace),
│ │ │ │ -
808 pFaceVerts = parentLevel.getFaceVertices(pFace);
│ │ │ │ -
809
│ │ │ │ -
810 int eInFace = 0;
│ │ │ │ -
811 for ( ; pFaceEdges[eInFace] != edge; ++eInFace ) ;
│ │ │ │ -
812
│ │ │ │ -
813 // Edge "i" spans vertices [i,i+1] so we want i+2...
│ │ │ │ -
814 int vInFace = eInFace + 2;
│ │ │ │ -
815 if (vInFace >= pFaceVerts.size()) vInFace -= pFaceVerts.size();
│ │ │ │ -
816
│ │ │ │ -
817 Vtr::Index pValueNext = parentFVar.getFaceValues(pFace)[vInFace];
│ │ │ │ -
818 dst[cVertValue].AddWithWeight(src[pValueNext], eFaceWeights[i]);
│ │ │ │ -
819 }
│ │ │ │ -
820 }
│ │ │ │ -
821 }
│ │ │ │ -
822 } else {
│ │ │ │ -
823 //
│ │ │ │ -
824 // Mismatched edge-verts should just be linearly interpolated between the pairs of
│ │ │ │ -
825 // values for each sibling of the child edge-vertex -- the question is: which face
│ │ │ │ -
826 // holds that pair of values for a given sibling?
│ │ │ │ -
827 //
│ │ │ │ -
828 // In the manifold case, the sibling and edge-face indices will correspond. We
│ │ │ │ -
829 // will eventually need to update this to account for > 3 incident faces.
│ │ │ │ -
830 //
│ │ │ │ -
831 for (int i = 0; i < cVertValues.size(); ++i) {
│ │ │ │ -
832 Vtr::Index eVertValues[2];
│ │ │ │ -
833 int eFaceIndex = refineFVar.getChildValueParentSource(cVert, i);
│ │ │ │ -
834 assert(eFaceIndex == i);
│ │ │ │ -
835
│ │ │ │ -
836 parentFVar.getEdgeFaceValues(edge, eFaceIndex, eVertValues);
│ │ │ │ -
837
│ │ │ │ -
838 Index cVertValue = cVertValues[i];
│ │ │ │ -
839
│ │ │ │ -
840 dst[cVertValue].Clear();
│ │ │ │ -
841 dst[cVertValue].AddWithWeight(src[eVertValues[0]], 0.5);
│ │ │ │ -
842 dst[cVertValue].AddWithWeight(src[eVertValues[1]], 0.5);
│ │ │ │ -
843 }
│ │ │ │ -
844 }
│ │ │ │ -
845 }
│ │ │ │ -
846}
│ │ │ │ -
847
│ │ │ │ -
848template <typename REAL>
│ │ │ │ -
849template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ -
850inline void
│ │ │ │ -
851PrimvarRefinerReal<REAL>::interpFVarFromVerts(int level, T const & src, U & dst, int channel) const {
│ │ │ │ -
852
│ │ │ │ -
853 Vtr::internal::Refinement const & refinement = _refiner.getRefinement(level-1);
│ │ │ │ -
854
│ │ │ │ -
855 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ -
856
│ │ │ │ -
857 Vtr::internal::Level const & parentLevel = refinement.parent();
│ │ │ │ -
858 Vtr::internal::Level const & childLevel = refinement.child();
│ │ │ │ -
859
│ │ │ │ -
860 Vtr::internal::FVarRefinement const & refineFVar = refinement.getFVarRefinement(channel);
│ │ │ │ -
861 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel(channel);
│ │ │ │ -
862 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel(channel);
│ │ │ │ -
863
│ │ │ │ -
864 bool isLinearFVar = parentFVar.isLinear() || (_refiner._subdivType == Sdc::SCHEME_BILINEAR);
│ │ │ │ -
865
│ │ │ │ -
866 Vtr::internal::StackBuffer<Weight,32> weightBuffer(2*parentLevel.getMaxValence());
│ │ │ │ -
867
│ │ │ │ -
868 Vtr::internal::StackBuffer<Vtr::Index,16> vEdgeValues(parentLevel.getMaxValence());
│ │ │ │ -
869
│ │ │ │ -
870 Vtr::internal::VertexInterface vHood(parentLevel, childLevel);
│ │ │ │ -
871
│ │ │ │ -
872 for (int vert = 0; vert < parentLevel.getNumVertices(); ++vert) {
│ │ │ │ -
873
│ │ │ │ -
874 Vtr::Index cVert = refinement.getVertexChildVertex(vert);
│ │ │ │ -
875 if (!Vtr::IndexIsValid(cVert))
│ │ │ │ -
876 continue;
│ │ │ │ -
877
│ │ │ │ -
878 ConstIndexArray pVertValues = parentFVar.getVertexValues(vert),
│ │ │ │ -
879 cVertValues = childFVar.getVertexValues(cVert);
│ │ │ │ -
880
│ │ │ │ -
881 bool fvarVertVertMatchesVertex = childFVar.valueTopologyMatches(cVertValues[0]);
│ │ │ │ -
882 if (isLinearFVar && fvarVertVertMatchesVertex) {
│ │ │ │ -
883 dst[cVertValues[0]].Clear();
│ │ │ │ -
884 dst[cVertValues[0]].AddWithWeight(src[pVertValues[0]], 1.0f);
│ │ │ │ -
885 continue;
│ │ │ │ -
886 }
│ │ │ │ -
887
│ │ │ │ -
888 if (fvarVertVertMatchesVertex) {
│ │ │ │ -
889 //
│ │ │ │ -
890 // Declare and compute mask weights for this vertex relative to its parent edge:
│ │ │ │ -
891 //
│ │ │ │ -
892 // (We really need to encapsulate this somewhere else for use here and in the
│ │ │ │ -
893 // general case)
│ │ │ │ -
894 //
│ │ │ │ -
895 ConstIndexArray vEdges = parentLevel.getVertexEdges(vert);
│ │ │ │ -
896
│ │ │ │ -
897 Weight vVertWeight;
│ │ │ │ -
898 Weight * vEdgeWeights = weightBuffer;
│ │ │ │ -
899 Weight * vFaceWeights = vEdgeWeights + vEdges.size();
│ │ │ │ -
900
│ │ │ │ -
901 Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights);
│ │ │ │ -
902
│ │ │ │ -
903 vHood.SetIndex(vert, cVert);
│ │ │ │ -
904
│ │ │ │ -
905 Sdc::Crease::Rule pRule = parentLevel.getVertexRule(vert);
│ │ │ │ -
906 Sdc::Crease::Rule cRule = childLevel.getVertexRule(cVert);
│ │ │ │ -
907
│ │ │ │ -
908 scheme.ComputeVertexVertexMask(vHood, vMask, pRule, cRule);
│ │ │ │ -
909
│ │ │ │ -
910 // Apply the weights to the parent vertex, the vertices opposite its incident
│ │ │ │ -
911 // edges, and the child vertices of its incident faces:
│ │ │ │ -
912 //
│ │ │ │ -
913 // Even though the face-varying topology matches the vertex topology, we need
│ │ │ │ -
914 // to be careful here when getting values corresponding to vertices at the
│ │ │ │ -
915 // ends of edges. While the edge may be continuous, the end vertex may have
│ │ │ │ -
916 // discontinuities elsewhere in their neighborhood (i.e. on the "other side"
│ │ │ │ -
917 // of the end-vertex) and so have sibling values associated with them. In most
│ │ │ │ -
918 // cases the topology for an end-vertex will match and we can use it directly,
│ │ │ │ -
919 // but we must still check and retrieve as needed.
│ │ │ │ -
920 //
│ │ │ │ -
921 // Indices for values corresponding to face-vertices are guaranteed to match,
│ │ │ │ -
922 // so we can use the child-vertex indices directly.
│ │ │ │ -
923 //
│ │ │ │ -
924 // And by "directly", we always use getVertexValue(vertexIndex) to reference
│ │ │ │ -
925 // values in the "src" to account for the possible indirection that may exist at
│ │ │ │ -
926 // level 0 -- where there may be fewer values than vertices and an additional
│ │ │ │ -
927 // indirection is necessary. We can use a vertex index directly for "dst" when
│ │ │ │ -
928 // it matches.
│ │ │ │ -
929 //
│ │ │ │ -
930 // As with applying the mask to vertex data, in order to improve numerical
│ │ │ │ -
931 // precision, it's better to apply smaller weights first, so begin with the
│ │ │ │ -
932 // face-weights followed by the edge-weights and the vertex weight last.
│ │ │ │ -
933 //
│ │ │ │ -
934 Vtr::Index pVertValue = pVertValues[0];
│ │ │ │ -
935 Vtr::Index cVertValue = cVertValues[0];
│ │ │ │ -
936
│ │ │ │ -
937 dst[cVertValue].Clear();
│ │ │ │ -
938 if (vMask.GetNumFaceWeights() > 0) {
│ │ │ │ -
939 assert(vMask.AreFaceWeightsForFaceCenters());
│ │ │ │ -
940
│ │ │ │ -
941 ConstIndexArray vFaces = parentLevel.getVertexFaces(vert);
│ │ │ │ -
942
│ │ │ │ -
943 for (int i = 0; i < vFaces.size(); ++i) {
│ │ │ │ -
944
│ │ │ │ -
945 Vtr::Index cVertOfFace = refinement.getFaceChildVertex(vFaces[i]);
│ │ │ │ -
946 assert(Vtr::IndexIsValid(cVertOfFace));
│ │ │ │ -
947
│ │ │ │ -
948 Vtr::Index cValueOfFace = childFVar.getVertexValueOffset(cVertOfFace);
│ │ │ │ -
949 dst[cVertValue].AddWithWeight(dst[cValueOfFace], vFaceWeights[i]);
│ │ │ │ -
950 }
│ │ │ │ -
951 }
│ │ │ │ -
952 if (vMask.GetNumEdgeWeights() > 0) {
│ │ │ │ -
953
│ │ │ │ -
954 parentFVar.getVertexEdgeValues(vert, vEdgeValues);
│ │ │ │ -
955
│ │ │ │ -
956 for (int i = 0; i < vEdges.size(); ++i) {
│ │ │ │ -
957 dst[cVertValue].AddWithWeight(src[vEdgeValues[i]], vEdgeWeights[i]);
│ │ │ │ -
958 }
│ │ │ │ -
959 }
│ │ │ │ -
960 dst[cVertValue].AddWithWeight(src[pVertValue], vVertWeight);
│ │ │ │ -
961 } else {
│ │ │ │ -
962 //
│ │ │ │ -
963 // Each FVar value associated with a vertex will be either a corner or a crease,
│ │ │ │ -
964 // or potentially in transition from corner to crease:
│ │ │ │ -
965 // - if the CHILD is a corner, there can be no transition so we have a corner
│ │ │ │ -
966 // - otherwise if the PARENT is a crease, both will be creases (no transition)
│ │ │ │ -
967 // - otherwise the parent must be a corner and the child a crease (transition)
│ │ │ │ -
968 //
│ │ │ │ -
969 Vtr::internal::FVarLevel::ConstValueTagArray pValueTags = parentFVar.getVertexValueTags(vert);
│ │ │ │ -
970 Vtr::internal::FVarLevel::ConstValueTagArray cValueTags = childFVar.getVertexValueTags(cVert);
│ │ │ │ -
971
│ │ │ │ -
972 for (int cSiblingIndex = 0; cSiblingIndex < cVertValues.size(); ++cSiblingIndex) {
│ │ │ │ -
973 int pSiblingIndex = refineFVar.getChildValueParentSource(cVert, cSiblingIndex);
│ │ │ │ -
974 assert(pSiblingIndex == cSiblingIndex);
│ │ │ │ -
975
│ │ │ │ -
976 typedef Vtr::internal::FVarLevel::Sibling SiblingIntType;
│ │ │ │ -
977
│ │ │ │ -
978 SiblingIntType cSibling = (SiblingIntType) cSiblingIndex;
│ │ │ │ -
979 SiblingIntType pSibling = (SiblingIntType) pSiblingIndex;
│ │ │ │ -
980
│ │ │ │ -
981 Vtr::Index pVertValue = pVertValues[pSibling];
│ │ │ │ -
982 Vtr::Index cVertValue = cVertValues[cSibling];
│ │ │ │ -
983
│ │ │ │ -
984 dst[cVertValue].Clear();
│ │ │ │ -
985 if (isLinearFVar || cValueTags[cSibling].isCorner()) {
│ │ │ │ -
986 dst[cVertValue].AddWithWeight(src[pVertValue], 1.0f);
│ │ │ │ -
987 } else {
│ │ │ │ -
988 //
│ │ │ │ -
989 // We have either a crease or a transition from corner to crease -- in
│ │ │ │ -
990 // either case, we need the end values for the full/fractional crease:
│ │ │ │ -
991 //
│ │ │ │ -
992 Index pEndValues[2];
│ │ │ │ -
993 parentFVar.getVertexCreaseEndValues(vert, pSibling, pEndValues);
│ │ │ │ -
994
│ │ │ │ -
995 Weight vWeight = 0.75f;
│ │ │ │ -
996 Weight eWeight = 0.125f;
│ │ │ │ -
997
│ │ │ │ -
998 //
│ │ │ │ -
999 // If semi-sharp we need to apply fractional weighting -- if made sharp because
│ │ │ │ -
1000 // of the other sibling (dependent-sharp) use the fractional weight from that
│ │ │ │ -
1001 // other sibling (should only occur when there are 2):
│ │ │ │ -
1002 //
│ │ │ │ -
1003 if (pValueTags[pSibling].isSemiSharp()) {
│ │ │ │ -
1004 Weight wCorner = pValueTags[pSibling].isDepSharp()
│ │ │ │ -
1005 ? refineFVar.getFractionalWeight(vert, !pSibling, cVert, !cSibling)
│ │ │ │ -
1006 : refineFVar.getFractionalWeight(vert, pSibling, cVert, cSibling);
│ │ │ │ -
1007 Weight wCrease = 1.0f - wCorner;
│ │ │ │ -
1008
│ │ │ │ -
1009 vWeight = wCrease * 0.75f + wCorner;
│ │ │ │ -
1010 eWeight = wCrease * 0.125f;
│ │ │ │ -
1011 }
│ │ │ │ -
1012 dst[cVertValue].AddWithWeight(src[pEndValues[0]], eWeight);
│ │ │ │ -
1013 dst[cVertValue].AddWithWeight(src[pEndValues[1]], eWeight);
│ │ │ │ -
1014 dst[cVertValue].AddWithWeight(src[pVertValue], vWeight);
│ │ │ │ -
1015 }
│ │ │ │ -
1016 }
│ │ │ │ -
1017 }
│ │ │ │ -
1018 }
│ │ │ │ -
1019}
│ │ │ │ -
1020
│ │ │ │ -
1021template <typename REAL>
│ │ │ │ -
1022template <Sdc::SchemeType SCHEME, class T, class U, class U1, class U2>
│ │ │ │ -
1023inline void
│ │ │ │ -
1024PrimvarRefinerReal<REAL>::limit(T const & src, U & dstPos, U1 * dstTan1Ptr, U2 * dstTan2Ptr) const {
│ │ │ │ -
1025
│ │ │ │ -
1026 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ -
1027
│ │ │ │ -
1028 Vtr::internal::Level const & level = _refiner.getLevel(_refiner.GetMaxLevel());
│ │ │ │ -
1029
│ │ │ │ -
1030 int maxWeightsPerMask = 1 + 2 * level.getMaxValence();
│ │ │ │ -
1031 bool hasTangents = (dstTan1Ptr && dstTan2Ptr);
│ │ │ │ -
1032 int numMasks = 1 + (hasTangents ? 2 : 0);
│ │ │ │ -
1033
│ │ │ │ -
1034 Vtr::internal::StackBuffer<Index,33> indexBuffer(maxWeightsPerMask);
│ │ │ │ -
1035 Vtr::internal::StackBuffer<Weight,99> weightBuffer(numMasks * maxWeightsPerMask);
│ │ │ │ -
1036
│ │ │ │ -
1037 Weight * vPosWeights = weightBuffer,
│ │ │ │ -
1038 * ePosWeights = vPosWeights + 1,
│ │ │ │ -
1039 * fPosWeights = ePosWeights + level.getMaxValence();
│ │ │ │ -
1040 Weight * vTan1Weights = vPosWeights + maxWeightsPerMask,
│ │ │ │ -
1041 * eTan1Weights = ePosWeights + maxWeightsPerMask,
│ │ │ │ -
1042 * fTan1Weights = fPosWeights + maxWeightsPerMask;
│ │ │ │ -
1043 Weight * vTan2Weights = vTan1Weights + maxWeightsPerMask,
│ │ │ │ -
1044 * eTan2Weights = eTan1Weights + maxWeightsPerMask,
│ │ │ │ -
1045 * fTan2Weights = fTan1Weights + maxWeightsPerMask;
│ │ │ │ -
1046
│ │ │ │ -
1047 Mask posMask( vPosWeights, ePosWeights, fPosWeights);
│ │ │ │ -
1048 Mask tan1Mask(vTan1Weights, eTan1Weights, fTan1Weights);
│ │ │ │ -
1049 Mask tan2Mask(vTan2Weights, eTan2Weights, fTan2Weights);
│ │ │ │ -
1050
│ │ │ │ -
1051 // This is a bit obscure -- assigning both parent and child as last level -- but
│ │ │ │ -
1052 // this mask type was intended for another purpose. Consider one for the limit:
│ │ │ │ -
1053 Vtr::internal::VertexInterface vHood(level, level);
│ │ │ │ -
1054
│ │ │ │ -
1055 for (int vert = 0; vert < level.getNumVertices(); ++vert) {
│ │ │ │ -
1056 ConstIndexArray vEdges = level.getVertexEdges(vert);
│ │ │ │ -
1057
│ │ │ │ -
1058 // Incomplete vertices (present in sparse refinement) do not have their full
│ │ │ │ -
1059 // topological neighborhood to determine a proper limit -- just leave the
│ │ │ │ -
1060 // vertex at the refined location and continue to the next:
│ │ │ │ -
1061 if (level.getVertexTag(vert)._incomplete || (vEdges.size() == 0)) {
│ │ │ │ -
1062 dstPos[vert].Clear();
│ │ │ │ -
1063 dstPos[vert].AddWithWeight(src[vert], 1.0);
│ │ │ │ -
1064 if (hasTangents) {
│ │ │ │ -
1065 (*dstTan1Ptr)[vert].Clear();
│ │ │ │ -
1066 (*dstTan2Ptr)[vert].Clear();
│ │ │ │ -
1067 }
│ │ │ │ -
1068 continue;
│ │ │ │ -
1069 }
│ │ │ │ -
1070
│ │ │ │ -
1071 //
│ │ │ │ -
1072 // Limit masks require the subdivision Rule for the vertex in order to deal
│ │ │ │ -
1073 // with infinitely sharp features correctly -- including boundaries and corners.
│ │ │ │ -
1074 // The vertex neighborhood is minimally defined with vertex and edge counts.
│ │ │ │ -
1075 //
│ │ │ │ -
1076 Sdc::Crease::Rule vRule = level.getVertexRule(vert);
│ │ │ │ -
1077
│ │ │ │ -
1078 // This is a bit obscure -- child vertex index will be ignored here
│ │ │ │ -
1079 vHood.SetIndex(vert, vert);
│ │ │ │ -
1080
│ │ │ │ -
1081 if (hasTangents) {
│ │ │ │ -
1082 scheme.ComputeVertexLimitMask(vHood, posMask, tan1Mask, tan2Mask, vRule);
│ │ │ │ -
1083 } else {
│ │ │ │ -
1084 scheme.ComputeVertexLimitMask(vHood, posMask, vRule);
│ │ │ │ -
1085 }
│ │ │ │ -
1086
│ │ │ │ -
1087 //
│ │ │ │ -
1088 // Gather the neighboring vertices of this vertex -- the vertices opposite its
│ │ │ │ -
1089 // incident edges, and the opposite vertices of its incident faces:
│ │ │ │ -
1090 //
│ │ │ │ -
1091 Index * eIndices = indexBuffer;
│ │ │ │ -
1092 Index * fIndices = indexBuffer + vEdges.size();
│ │ │ │ -
1093
│ │ │ │ -
1094 for (int i = 0; i < vEdges.size(); ++i) {
│ │ │ │ -
1095 ConstIndexArray eVerts = level.getEdgeVertices(vEdges[i]);
│ │ │ │ -
1096
│ │ │ │ -
1097 eIndices[i] = (eVerts[0] == vert) ? eVerts[1] : eVerts[0];
│ │ │ │ -
1098 }
│ │ │ │ -
1099 if (posMask.GetNumFaceWeights() || (hasTangents && tan1Mask.GetNumFaceWeights())) {
│ │ │ │ -
1100 ConstIndexArray vFaces = level.getVertexFaces(vert);
│ │ │ │ -
1101 ConstLocalIndexArray vInFace = level.getVertexFaceLocalIndices(vert);
│ │ │ │ -
1102
│ │ │ │ -
1103 for (int i = 0; i < vFaces.size(); ++i) {
│ │ │ │ -
1104 ConstIndexArray fVerts = level.getFaceVertices(vFaces[i]);
│ │ │ │ -
1105
│ │ │ │ -
1106 LocalIndex vOppInFace = (vInFace[i] + 2);
│ │ │ │ -
1107 if (vOppInFace >= fVerts.size()) vOppInFace -= (LocalIndex)fVerts.size();
│ │ │ │ -
1108
│ │ │ │ -
1109 fIndices[i] = level.getFaceVertices(vFaces[i])[vOppInFace];
│ │ │ │ -
1110 }
│ │ │ │ -
1111 }
│ │ │ │ -
1112
│ │ │ │ -
1113 //
│ │ │ │ -
1114 // Combine the weights and indices for position and tangents. As with applying
│ │ │ │ -
1115 // refinement masks to vertex data, in order to improve numerical precision, it's
│ │ │ │ -
1116 // better to apply smaller weights first, so begin with the face-weights followed
│ │ │ │ -
1117 // by the edge-weights and the vertex weight last.
│ │ │ │ -
1118 //
│ │ │ │ -
1119 dstPos[vert].Clear();
│ │ │ │ -
1120 for (int i = 0; i < posMask.GetNumFaceWeights(); ++i) {
│ │ │ │ -
1121 dstPos[vert].AddWithWeight(src[fIndices[i]], fPosWeights[i]);
│ │ │ │ -
1122 }
│ │ │ │ -
1123 for (int i = 0; i < posMask.GetNumEdgeWeights(); ++i) {
│ │ │ │ -
1124 dstPos[vert].AddWithWeight(src[eIndices[i]], ePosWeights[i]);
│ │ │ │ -
1125 }
│ │ │ │ -
1126 dstPos[vert].AddWithWeight(src[vert], vPosWeights[0]);
│ │ │ │ -
1127
│ │ │ │ -
1128 //
│ │ │ │ -
1129 // Apply the tangent masks -- both will have the same number of weights and
│ │ │ │ -
1130 // indices (one tangent may be "padded" to accommodate the other), but these
│ │ │ │ -
1131 // may differ from those of the position:
│ │ │ │ -
1132 //
│ │ │ │ -
1133 if (hasTangents) {
│ │ │ │ -
1134 assert(tan1Mask.GetNumFaceWeights() == tan2Mask.GetNumFaceWeights());
│ │ │ │ -
1135 assert(tan1Mask.GetNumEdgeWeights() == tan2Mask.GetNumEdgeWeights());
│ │ │ │ -
1136
│ │ │ │ -
1137 U1 & dstTan1 = *dstTan1Ptr;
│ │ │ │ -
1138 U2 & dstTan2 = *dstTan2Ptr;
│ │ │ │ -
1139
│ │ │ │ -
1140 dstTan1[vert].Clear();
│ │ │ │ -
1141 dstTan2[vert].Clear();
│ │ │ │ -
1142 for (int i = 0; i < tan1Mask.GetNumFaceWeights(); ++i) {
│ │ │ │ -
1143 dstTan1[vert].AddWithWeight(src[fIndices[i]], fTan1Weights[i]);
│ │ │ │ -
1144 dstTan2[vert].AddWithWeight(src[fIndices[i]], fTan2Weights[i]);
│ │ │ │ -
1145 }
│ │ │ │ -
1146 for (int i = 0; i < tan1Mask.GetNumEdgeWeights(); ++i) {
│ │ │ │ -
1147 dstTan1[vert].AddWithWeight(src[eIndices[i]], eTan1Weights[i]);
│ │ │ │ -
1148 dstTan2[vert].AddWithWeight(src[eIndices[i]], eTan2Weights[i]);
│ │ │ │ -
1149 }
│ │ │ │ -
1150 dstTan1[vert].AddWithWeight(src[vert], vTan1Weights[0]);
│ │ │ │ -
1151 dstTan2[vert].AddWithWeight(src[vert], vTan2Weights[0]);
│ │ │ │ -
1152 }
│ │ │ │ -
1153 }
│ │ │ │ -
1154}
│ │ │ │ -
1155
│ │ │ │ -
1156template <typename REAL>
│ │ │ │ -
1157template <Sdc::SchemeType SCHEME, class T, class U>
│ │ │ │ -
1158inline void
│ │ │ │ -
1159PrimvarRefinerReal<REAL>::limitFVar(T const & src, U & dst, int channel) const {
│ │ │ │ -
1160
│ │ │ │ -
1161 Sdc::Scheme<SCHEME> scheme(_refiner._subdivOptions);
│ │ │ │ -
1162
│ │ │ │ -
1163 Vtr::internal::Level const & level = _refiner.getLevel(_refiner.GetMaxLevel());
│ │ │ │ -
1164 Vtr::internal::FVarLevel const & fvarChannel = level.getFVarLevel(channel);
│ │ │ │ -
1165
│ │ │ │ -
1166 int maxWeightsPerMask = 1 + 2 * level.getMaxValence();
│ │ │ │ -
1167
│ │ │ │ -
1168 Vtr::internal::StackBuffer<Weight,33> weightBuffer(maxWeightsPerMask);
│ │ │ │ -
1169 Vtr::internal::StackBuffer<Index,16> vEdgeBuffer(level.getMaxValence());
│ │ │ │ -
1170
│ │ │ │ -
1171 // This is a bit obscure -- assign both parent and child as last level
│ │ │ │ -
1172 Vtr::internal::VertexInterface vHood(level, level);
│ │ │ │ -
1173
│ │ │ │ -
1174 for (int vert = 0; vert < level.getNumVertices(); ++vert) {
│ │ │ │ -
1175
│ │ │ │ -
1176 ConstIndexArray vEdges = level.getVertexEdges(vert);
│ │ │ │ -
1177 ConstIndexArray vValues = fvarChannel.getVertexValues(vert);
│ │ │ │ -
1178
│ │ │ │ -
1179 // Incomplete vertices (present in sparse refinement) do not have their full
│ │ │ │ -
1180 // topological neighborhood to determine a proper limit -- just leave the
│ │ │ │ -
1181 // values (perhaps more than one per vertex) at the refined location.
│ │ │ │ -
1182 //
│ │ │ │ -
1183 // The same can be done if the face-varying channel is purely linear.
│ │ │ │ -
1184 //
│ │ │ │ -
1185 bool isIncomplete = (level.getVertexTag(vert)._incomplete || (vEdges.size() == 0));
│ │ │ │ -
1186 if (isIncomplete || fvarChannel.isLinear()) {
│ │ │ │ -
1187 for (int i = 0; i < vValues.size(); ++i) {
│ │ │ │ -
1188 Vtr::Index vValue = vValues[i];
│ │ │ │ -
1189
│ │ │ │ -
1190 dst[vValue].Clear();
│ │ │ │ -
1191 dst[vValue].AddWithWeight(src[vValue], 1.0f);
│ │ │ │ -
1192 }
│ │ │ │ -
1193 continue;
│ │ │ │ -
1194 }
│ │ │ │ -
1195
│ │ │ │ -
1196 bool fvarVertMatchesVertex = fvarChannel.valueTopologyMatches(vValues[0]);
│ │ │ │ -
1197 if (fvarVertMatchesVertex) {
│ │ │ │ -
1198
│ │ │ │ -
1199 // Assign the mask weights to the common buffer and compute the mask:
│ │ │ │ -
1200 //
│ │ │ │ -
1201 Weight * vWeights = weightBuffer,
│ │ │ │ -
1202 * eWeights = vWeights + 1,
│ │ │ │ -
1203 * fWeights = eWeights + vEdges.size();
│ │ │ │ -
1204
│ │ │ │ -
1205 Mask vMask(vWeights, eWeights, fWeights);
│ │ │ │ -
1206
│ │ │ │ -
1207 vHood.SetIndex(vert, vert);
│ │ │ │ -
1208
│ │ │ │ -
1209 scheme.ComputeVertexLimitMask(vHood, vMask, level.getVertexRule(vert));
│ │ │ │ -
1210
│ │ │ │ -
1211 //
│ │ │ │ -
1212 // Apply mask to corresponding FVar values for neighboring vertices:
│ │ │ │ -
1213 //
│ │ │ │ -
1214 Vtr::Index vValue = vValues[0];
│ │ │ │ -
1215
│ │ │ │ -
1216 dst[vValue].Clear();
│ │ │ │ -
1217 if (vMask.GetNumFaceWeights() > 0) {
│ │ │ │ -
1218 assert(!vMask.AreFaceWeightsForFaceCenters());
│ │ │ │ -
1219
│ │ │ │ -
1220 ConstIndexArray vFaces = level.getVertexFaces(vert);
│ │ │ │ -
1221 ConstLocalIndexArray vInFace = level.getVertexFaceLocalIndices(vert);
│ │ │ │ -
1222
│ │ │ │ -
1223 for (int i = 0; i < vFaces.size(); ++i) {
│ │ │ │ -
1224 ConstIndexArray faceValues = fvarChannel.getFaceValues(vFaces[i]);
│ │ │ │ -
1225 LocalIndex vOppInFace = vInFace[i] + 2;
│ │ │ │ -
1226 if (vOppInFace >= faceValues.size()) vOppInFace -= faceValues.size();
│ │ │ │ -
1227
│ │ │ │ -
1228 Index vValueOppositeFace = faceValues[vOppInFace];
│ │ │ │ -
1229
│ │ │ │ -
1230 dst[vValue].AddWithWeight(src[vValueOppositeFace], fWeights[i]);
│ │ │ │ -
1231 }
│ │ │ │ -
1232 }
│ │ │ │ -
1233 if (vMask.GetNumEdgeWeights() > 0) {
│ │ │ │ -
1234 Index * vEdgeValues = vEdgeBuffer;
│ │ │ │ -
1235 fvarChannel.getVertexEdgeValues(vert, vEdgeValues);
│ │ │ │ -
1236
│ │ │ │ -
1237 for (int i = 0; i < vEdges.size(); ++i) {
│ │ │ │ -
1238 dst[vValue].AddWithWeight(src[vEdgeValues[i]], eWeights[i]);
│ │ │ │ -
1239 }
│ │ │ │ -
1240 }
│ │ │ │ -
1241 dst[vValue].AddWithWeight(src[vValue], vWeights[0]);
│ │ │ │ -
1242 } else {
│ │ │ │ -
1243 //
│ │ │ │ -
1244 // Sibling FVar values associated with a vertex will be either a corner or a crease:
│ │ │ │ -
1245 //
│ │ │ │ -
1246 for (int i = 0; i < vValues.size(); ++i) {
│ │ │ │ -
1247 Vtr::Index vValue = vValues[i];
│ │ │ │ -
1248
│ │ │ │ -
1249 dst[vValue].Clear();
│ │ │ │ -
1250 if (fvarChannel.getValueTag(vValue).isCorner()) {
│ │ │ │ -
1251 dst[vValue].AddWithWeight(src[vValue], 1.0f);
│ │ │ │ -
1252 } else {
│ │ │ │ -
1253 Index vEndValues[2];
│ │ │ │ -
1254 fvarChannel.getVertexCreaseEndValues(vert, i, vEndValues);
│ │ │ │ -
1255
│ │ │ │ -
1256 dst[vValue].AddWithWeight(src[vEndValues[0]], 1.0f/6.0f);
│ │ │ │ -
1257 dst[vValue].AddWithWeight(src[vEndValues[1]], 1.0f/6.0f);
│ │ │ │ -
1258 dst[vValue].AddWithWeight(src[vValue], 2.0f/3.0f);
│ │ │ │ -
1259 }
│ │ │ │ -
1260 }
│ │ │ │ -
1261 }
│ │ │ │ -
1262 }
│ │ │ │ -
1263}
│ │ │ │ -
1264
│ │ │ │ -
│ │ │ │ -
1265class PrimvarRefiner : public PrimvarRefinerReal<float> {
│ │ │ │ -
1266public:
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1268 : PrimvarRefinerReal<float>(refiner) { }
│ │ │ │ -
│ │ │ │ -
1269};
│ │ │ │ -
│ │ │ │ -
1270
│ │ │ │ -
1271} // end namespace Far
│ │ │ │ -
1272
│ │ │ │ -
1273} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
1274using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
1275} // end namespace OpenSubdiv
│ │ │ │ -
1276
│ │ │ │ -
1277#endif /* OPENSUBDIV3_FAR_PRIMVAR_REFINER_H */
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ -
void Error(ErrorType err, const char *format,...)
Sends an OSD error with a message (internal use only)
│ │ │ │ +
234
│ │ │ │ +
235#endif /* OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H */
│ │ │ │ + │ │ │ │
Vtr::ConstIndexArray ConstIndexArray
Definition types.h:47
│ │ │ │ -
Vtr::ConstLocalIndexArray ConstLocalIndexArray
Definition types.h:48
│ │ │ │ -
@ FAR_RUNTIME_ERROR
Issue a generic runtime error, but continue execution.
Definition error.h:40
│ │ │ │ - │ │ │ │ - │ │ │ │ -
bool IndexIsValid(Index index)
Definition types.h:58
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
Applies refinement operations to generic primvar data.
│ │ │ │ -
void Limit(T const &src, U &dstPos) const
Apply limit weights to a primvar buffer.
│ │ │ │ - │ │ │ │ -
void Limit(T const &src, U &dstPos, U1 &dstTan1, U2 &dstTan2) const
│ │ │ │ -
void InterpolateFaceUniform(int level, T const &src, U &dst) const
Refine uniform (per-face) primvar data between levels.
│ │ │ │ - │ │ │ │ -
void InterpolateVarying(int level, T const &src, U &dst) const
Apply only varying interpolation weights to a primvar buffer for a single level of refinement.
│ │ │ │ -
void Interpolate(int level, T const &src, U &dst) const
Apply vertex interpolation weights to a primvar buffer for a single level of refinement.
│ │ │ │ -
void InterpolateFaceVarying(int level, T const &src, U &dst, int channel=0) const
Apply face-varying interpolation weights to a primvar buffer associated with a particular face-varyin...
│ │ │ │ - │ │ │ │ -
void LimitFaceVarying(T const &src, U &dst, int channel=0) const
│ │ │ │ - │ │ │ │ - │ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
Scheme is a class template which provides all implementation for the subdivision schemes supported by...
Definition scheme.h:66
│ │ │ │ +
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ +
Factory for constructing a PatchTable from a TopologyRefiner.
│ │ │ │ + │ │ │ │ +
static PatchTable * Create(TopologyRefiner const &refiner, Options options=Options(), ConstIndexArray selectedFaces=ConstIndexArray())
Instantiates a PatchTable from a client-provided TopologyRefiner.
│ │ │ │ + │ │ │ │ +
unsigned int generateVaryingTables
Generate varying patch tables.
│ │ │ │ +
unsigned int generateLegacySharpCornerPatches
Generate sharp regular patches at smooth corners (legacy)
│ │ │ │ + │ │ │ │ +
TopologyRefiner::AdaptiveOptions GetRefineAdaptiveOptions() const
Determine adaptive refinement options to match assigned patch options.
│ │ │ │ +
unsigned int maxIsolationLevel
Cap adaptive feature isolation to the given level (max. 10)
│ │ │ │ + │ │ │ │ +
unsigned int generateFVarLegacyLinearPatches
Generate all linear face-varying patches (legacy)
│ │ │ │ +
void SetPatchPrecision()
Set precision of vertex patches.
│ │ │ │ +
unsigned int fvarPatchPrecisionDouble
Generate double-precision stencils for face-varying patches.
│ │ │ │ +
void SetMaxIsolationLevel(unsigned int level)
Set maximum isolation level.
│ │ │ │ + │ │ │ │ +
int const * fvarChannelIndices
List containing the indices of the channels selected for the factory.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
unsigned int generateVaryingLocalPoints
Generate local points with varying patches.
│ │ │ │ +
unsigned int includeFVarBaseLevelIndices
Include base level in face-varying patch point indices (Uniform mode only)
│ │ │ │ +
unsigned int generateAllLevels
Generate levels from 'firstLevel' to 'maxLevel' (Uniform mode only)
│ │ │ │ +
unsigned int patchPrecisionDouble
Generate double-precision stencils for vertex patches.
│ │ │ │ +
unsigned int generateFVarTables
Generate face-varying patch tables.
│ │ │ │ +
unsigned int includeBaseLevelIndices
Include base level in patch point indices (Uniform mode only)
│ │ │ │ +
void SetFVarPatchPrecision()
Set precision of face-varying patches.
│ │ │ │ +
int numFVarChannels
Number of channel indices and interpolation modes passed.
│ │ │ │ +
unsigned int triangulateQuads
Triangulate 'QUADS' primitives (Uniform mode only)
│ │ │ │ +
EndCapType
Choice for approximating irregular patches (end-caps)
│ │ │ │ +
@ ENDCAP_LEGACY_GREGORY
legacy option for 2.x style Gregory patches (Catmark only)
│ │ │ │ +
@ ENDCAP_GREGORY_BASIS
use Gregory patches (highest quality, recommended default)
│ │ │ │ + │ │ │ │ +
@ ENDCAP_BILINEAR_BASIS
use linear patches (simple quads or tris)
│ │ │ │ +
@ ENDCAP_BSPLINE_BASIS
use BSpline-like patches (same patch type as regular)
│ │ │ │ + │ │ │ │ +
Obsolete internal struct not intended for public use – due to be deprecated.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── encoding │ │ │ │ │ @@ -1 +1 @@ │ │ │ │ │ -us-ascii │ │ │ │ │ +utf-8 │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -primvarRefiner.h │ │ │ │ │ +patchTableFactory.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2015 DreamWorks Animation LLC. │ │ │ │ │ +2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -23,1388 +23,410 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_FAR_PRIMVAR_REFINER_H │ │ │ │ │ -25#define OPENSUBDIV3_FAR_PRIMVAR_REFINER_H │ │ │ │ │ -26 │ │ │ │ │ -27#include "../version.h" │ │ │ │ │ -28 │ │ │ │ │ -29#include "../sdc/types.h" │ │ │ │ │ -30#include "../sdc/options.h" │ │ │ │ │ -31#include "../sdc/bilinearScheme.h" │ │ │ │ │ -32#include "../sdc/catmarkScheme.h" │ │ │ │ │ -33#include "../sdc/loopScheme.h" │ │ │ │ │ -34#include "../vtr/level.h" │ │ │ │ │ -35#include "../vtr/fvarLevel.h" │ │ │ │ │ -36#include "../vtr/refinement.h" │ │ │ │ │ -37#include "../vtr/fvarRefinement.h" │ │ │ │ │ -38#include "../vtr/stackBuffer.h" │ │ │ │ │ -39#include "../vtr/componentInterfaces.h" │ │ │ │ │ -40#include "../far/types.h" │ │ │ │ │ -41#include "../far/error.h" │ │ │ │ │ -42#include "../far/topologyLevel.h" │ │ │ │ │ -43#include "../far/topologyRefiner.h" │ │ │ │ │ -44 │ │ │ │ │ -45#include │ │ │ │ │ +24 │ │ │ │ │ +25#ifndef OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H │ │ │ │ │ +26#define OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H │ │ │ │ │ +27 │ │ │ │ │ +28#include "../version.h" │ │ │ │ │ +29 │ │ │ │ │ +30#include "../far/topologyRefiner.h" │ │ │ │ │ +31#include "../far/patchTable.h" │ │ │ │ │ +32 │ │ │ │ │ +33namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +34namespace OPENSUBDIV_VERSION { │ │ │ │ │ +35 │ │ │ │ │ +36namespace Far { │ │ │ │ │ +37 │ │ │ │ │ +_4_0class _P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y { │ │ │ │ │ +41public: │ │ │ │ │ +42 │ │ │ │ │ +_4_5 struct _O_p_t_i_o_n_s { │ │ │ │ │ 46 │ │ │ │ │ -47namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -48namespace OPENSUBDIV_VERSION { │ │ │ │ │ -49 │ │ │ │ │ -50namespace Far { │ │ │ │ │ -51 │ │ │ │ │ -55template │ │ │ │ │ -_5_6class _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l { │ │ │ │ │ -57 │ │ │ │ │ -58public: │ │ │ │ │ -_5_9 _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l(_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner) : _refiner(refiner) { } │ │ │ │ │ -_6_0 _~_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l() { } │ │ │ │ │ -61 │ │ │ │ │ -_6_2 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & _G_e_t_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r() const { return _refiner; } │ │ │ │ │ -63 │ │ │ │ │ -65 │ │ │ │ │ -100 │ │ │ │ │ -_1_1_3 template void _I_n_t_e_r_p_o_l_a_t_e(int level, T const & src, U & │ │ │ │ │ -dst) const; │ │ │ │ │ +_5_5 enum _E_n_d_C_a_p_T_y_p_e { │ │ │ │ │ +_5_6 _E_N_D_C_A_P___N_O_N_E = 0, │ │ │ │ │ +_5_7 _E_N_D_C_A_P___B_I_L_I_N_E_A_R___B_A_S_I_S, │ │ │ │ │ +_5_8 _E_N_D_C_A_P___B_S_P_L_I_N_E___B_A_S_I_S, │ │ │ │ │ +_5_9 _E_N_D_C_A_P___G_R_E_G_O_R_Y___B_A_S_I_S, │ │ │ │ │ +60 _E_N_D_C_A_P___L_E_G_A_C_Y___G_R_E_G_O_R_Y │ │ │ │ │ +_6_1 }; │ │ │ │ │ +62 │ │ │ │ │ +_6_3 _O_p_t_i_o_n_s(unsigned int maxIsolation=10) : │ │ │ │ │ +64 _g_e_n_e_r_a_t_e_A_l_l_L_e_v_e_l_s(false), │ │ │ │ │ +65 _i_n_c_l_u_d_e_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s(true), │ │ │ │ │ +66 _i_n_c_l_u_d_e_F_V_a_r_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s(false), │ │ │ │ │ +67 _t_r_i_a_n_g_u_l_a_t_e_Q_u_a_d_s(false), │ │ │ │ │ +68 _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h(false), │ │ │ │ │ +69 _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h(false), │ │ │ │ │ +70 _m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l(maxIsolation & 0xf), │ │ │ │ │ +71 _e_n_d_C_a_p_T_y_p_e(_E_N_D_C_A_P___G_R_E_G_O_R_Y___B_A_S_I_S), │ │ │ │ │ +72 _s_h_a_r_e_E_n_d_C_a_p_P_a_t_c_h_P_o_i_n_t_s(true), │ │ │ │ │ +73 _g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_T_a_b_l_e_s(true), │ │ │ │ │ +74 _g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_L_o_c_a_l_P_o_i_n_t_s(true), │ │ │ │ │ +75 _g_e_n_e_r_a_t_e_F_V_a_r_T_a_b_l_e_s(false), │ │ │ │ │ +76 _p_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e(false), │ │ │ │ │ +77 _f_v_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e(false), │ │ │ │ │ +78 _g_e_n_e_r_a_t_e_F_V_a_r_L_e_g_a_c_y_L_i_n_e_a_r_P_a_t_c_h_e_s(true), │ │ │ │ │ +79 _g_e_n_e_r_a_t_e_L_e_g_a_c_y_S_h_a_r_p_C_o_r_n_e_r_P_a_t_c_h_e_s(true), │ │ │ │ │ +80 _n_u_m_F_V_a_r_C_h_a_n_n_e_l_s(-1), │ │ │ │ │ +81 _f_v_a_r_C_h_a_n_n_e_l_I_n_d_i_c_e_s(0) │ │ │ │ │ +82 { } │ │ │ │ │ +83 │ │ │ │ │ +_8_5 _E_n_d_C_a_p_T_y_p_e _G_e_t_E_n_d_C_a_p_T_y_p_e() const { return (_E_n_d_C_a_p_T_y_p_e)_e_n_d_C_a_p_T_y_p_e; } │ │ │ │ │ +86 │ │ │ │ │ +_8_8 void _S_e_t_E_n_d_C_a_p_T_y_p_e(_E_n_d_C_a_p_T_y_p_e e) { _e_n_d_C_a_p_T_y_p_e = e & 0x7; } │ │ │ │ │ +89 │ │ │ │ │ +_9_1 void _S_e_t_M_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l(unsigned int level) { _m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l = level & │ │ │ │ │ +0xf; } │ │ │ │ │ +92 │ │ │ │ │ +_9_4 template void _S_e_t_P_a_t_c_h_P_r_e_c_i_s_i_o_n(); │ │ │ │ │ +95 │ │ │ │ │ +_9_7 template void _S_e_t_F_V_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n(); │ │ │ │ │ +98 │ │ │ │ │ +_1_0_0 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s _G_e_t_R_e_f_i_n_e_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s() const { │ │ │ │ │ +101 _T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s adaptiveOptions(_m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l); │ │ │ │ │ +102 │ │ │ │ │ +103 adaptiveOptions._u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h = _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h; │ │ │ │ │ +104 adaptiveOptions._u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h = _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h; │ │ │ │ │ +105 adaptiveOptions._c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s = _g_e_n_e_r_a_t_e_F_V_a_r_T_a_b_l_e_s && │ │ │ │ │ +106 !_g_e_n_e_r_a_t_e_F_V_a_r_L_e_g_a_c_y_L_i_n_e_a_r_P_a_t_c_h_e_s; │ │ │ │ │ +107 return adaptiveOptions; │ │ │ │ │ +108 } │ │ │ │ │ +109 │ │ │ │ │ +_1_1_0 unsigned int _g_e_n_e_r_a_t_e_A_l_l_L_e_v_e_l_s : 1, │ │ │ │ │ +_1_1_1 _i_n_c_l_u_d_e_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s : 1, │ │ │ │ │ +_1_1_2 _i_n_c_l_u_d_e_F_V_a_r_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s : 1, │ │ │ │ │ +_1_1_3 _t_r_i_a_n_g_u_l_a_t_e_Q_u_a_d_s : 1, │ │ │ │ │ 114 │ │ │ │ │ -_1_3_0 template void _I_n_t_e_r_p_o_l_a_t_e_V_a_r_y_i_n_g(int level, T const & │ │ │ │ │ -src, U & dst) const; │ │ │ │ │ -131 │ │ │ │ │ -_1_4_8 template void _I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_U_n_i_f_o_r_m(int level, T const │ │ │ │ │ -& src, U & dst) const; │ │ │ │ │ -149 │ │ │ │ │ -_1_6_1 template void _I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_V_a_r_y_i_n_g(int level, T const │ │ │ │ │ -& src, U & dst, int channel = 0) const; │ │ │ │ │ -162 │ │ │ │ │ -163 │ │ │ │ │ -_1_7_5 template void _L_i_m_i_t(T const & src, U & dstPos) const; │ │ │ │ │ -176 │ │ │ │ │ -177 template │ │ │ │ │ -_1_7_8 void _L_i_m_i_t(T const & src, U & dstPos, U1 & dstTan1, U2 & dstTan2) const; │ │ │ │ │ -179 │ │ │ │ │ -_1_8_0 template void _L_i_m_i_t_F_a_c_e_V_a_r_y_i_n_g(T const & src, U & dst, │ │ │ │ │ -int channel = 0) const; │ │ │ │ │ -181 │ │ │ │ │ -183 │ │ │ │ │ -184private: │ │ │ │ │ -185 typedef REAL Weight; │ │ │ │ │ -186 │ │ │ │ │ -187 // Non-copyable: │ │ │ │ │ -188 _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l(_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l const & src) : _refiner(src._refiner) │ │ │ │ │ -{ } │ │ │ │ │ -189 _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l & operator=(_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l const &) { return *this; │ │ │ │ │ -} │ │ │ │ │ -190 │ │ │ │ │ -191 template void interpFromFaces │ │ │ │ │ -(int, T const &, U &) const; │ │ │ │ │ -192 template void interpFromEdges │ │ │ │ │ -(int, T const &, U &) const; │ │ │ │ │ -193 template void interpFromVerts │ │ │ │ │ -(int, T const &, U &) const; │ │ │ │ │ -194 │ │ │ │ │ -195 template void │ │ │ │ │ -interpFVarFromFaces(int, T const &, U &, int) const; │ │ │ │ │ -196 template void │ │ │ │ │ -interpFVarFromEdges(int, T const &, U &, int) const; │ │ │ │ │ -197 template void │ │ │ │ │ -interpFVarFromVerts(int, T const &, U &, int) const; │ │ │ │ │ -198 │ │ │ │ │ -199 template │ │ │ │ │ -200 void limit(T const & src, U & pos, U1 * tan1, U2 * tan2) const; │ │ │ │ │ -201 │ │ │ │ │ -202 template │ │ │ │ │ -203 void limitFVar(T const & src, U & dst, int channel) const; │ │ │ │ │ -204 │ │ │ │ │ -205private: │ │ │ │ │ -206 TopologyRefiner const & _refiner; │ │ │ │ │ -207 │ │ │ │ │ -208private: │ │ │ │ │ -209 // │ │ │ │ │ -210 // Local class to fulfill interface for in the Scheme mask │ │ │ │ │ -queries: │ │ │ │ │ -211 // │ │ │ │ │ -212 class Mask { │ │ │ │ │ -213 public: │ │ │ │ │ -214 typedef REAL Weight; // Also part of the expected interface │ │ │ │ │ -215 │ │ │ │ │ -216 public: │ │ │ │ │ -217 Mask(Weight* v, Weight* e, Weight* f) : │ │ │ │ │ -218 _vertWeights(v), _edgeWeights(e), _faceWeights(f), │ │ │ │ │ -219 _vertCount(0), _edgeCount(0), _faceCount(0), │ │ │ │ │ -220 _faceWeightsForFaceCenters(false) │ │ │ │ │ -221 { } │ │ │ │ │ -222 │ │ │ │ │ -223 ~Mask() { } │ │ │ │ │ -224 │ │ │ │ │ -225 public: // Generic interface expected of : │ │ │ │ │ -226 int GetNumVertexWeights() const { return _vertCount; } │ │ │ │ │ -227 int GetNumEdgeWeights() const { return _edgeCount; } │ │ │ │ │ -228 int GetNumFaceWeights() const { return _faceCount; } │ │ │ │ │ -229 │ │ │ │ │ -230 void SetNumVertexWeights(int count) { _vertCount = count; } │ │ │ │ │ -231 void SetNumEdgeWeights( int count) { _edgeCount = count; } │ │ │ │ │ -232 void SetNumFaceWeights( int count) { _faceCount = count; } │ │ │ │ │ +_1_1_5 _u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h : 1, │ │ │ │ │ +_1_1_6 _u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h : 1, │ │ │ │ │ +_1_1_7 _m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l : 4, │ │ │ │ │ +118 │ │ │ │ │ +119 // end-capping │ │ │ │ │ +_1_2_0 _e_n_d_C_a_p_T_y_p_e : 3, │ │ │ │ │ +_1_2_1 _s_h_a_r_e_E_n_d_C_a_p_P_a_t_c_h_P_o_i_n_t_s : 1, │ │ │ │ │ +123 │ │ │ │ │ +124 // varying │ │ │ │ │ +_1_2_5 _g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_T_a_b_l_e_s : 1, │ │ │ │ │ +_1_2_6 _g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_L_o_c_a_l_P_o_i_n_t_s : 1, │ │ │ │ │ +127 │ │ │ │ │ +128 // face-varying │ │ │ │ │ +_1_2_9 _g_e_n_e_r_a_t_e_F_V_a_r_T_a_b_l_e_s : 1, │ │ │ │ │ +130 │ │ │ │ │ +131 // precision │ │ │ │ │ +_1_3_2 _p_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e : 1, │ │ │ │ │ +_1_3_3 _f_v_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e : 1, │ │ │ │ │ +134 │ │ │ │ │ +135 // legacy behaviors (default to true) │ │ │ │ │ +_1_3_6 _g_e_n_e_r_a_t_e_F_V_a_r_L_e_g_a_c_y_L_i_n_e_a_r_P_a_t_c_h_e_s : 1, │ │ │ │ │ +_1_3_7 _g_e_n_e_r_a_t_e_L_e_g_a_c_y_S_h_a_r_p_C_o_r_n_e_r_P_a_t_c_h_e_s : 1; │ │ │ │ │ +138 │ │ │ │ │ +_1_3_9 int _n_u_m_F_V_a_r_C_h_a_n_n_e_l_s; │ │ │ │ │ +_1_4_0 int const * _f_v_a_r_C_h_a_n_n_e_l_I_n_d_i_c_e_s; │ │ │ │ │ +141 }; │ │ │ │ │ +142 │ │ │ │ │ +_1_7_5 static _P_a_t_c_h_T_a_b_l_e * _C_r_e_a_t_e(_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner, │ │ │ │ │ +176 _O_p_t_i_o_n_s options = _O_p_t_i_o_n_s(), │ │ │ │ │ +177 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y selectedFaces = _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y()); │ │ │ │ │ +178 │ │ │ │ │ +179public: │ │ │ │ │ +180 // PatchFaceTag │ │ │ │ │ +181 // │ │ │ │ │ +182 // This simple struct was previously used within the factory to take │ │ │ │ │ +inventory of │ │ │ │ │ +183 // various kinds of patches to fully allocate buffers prior to populating │ │ │ │ │ +them. It │ │ │ │ │ +184 // was not intended to be exposed as part of the public interface. │ │ │ │ │ +185 // │ │ │ │ │ +186 // It is no longer used internally and is being kept here to respect │ │ │ │ │ +preservation │ │ │ │ │ +187 // of the public interface, but it will be deprecated at the earliest │ │ │ │ │ +opportunity. │ │ │ │ │ +188 // │ │ │ │ │ +191 // │ │ │ │ │ +_1_9_2 struct _P_a_t_c_h_F_a_c_e_T_a_g { │ │ │ │ │ +193 public: │ │ │ │ │ +_1_9_4 unsigned int ___h_a_s_P_a_t_c_h : 1; │ │ │ │ │ +_1_9_5 unsigned int ___i_s_R_e_g_u_l_a_r : 1; │ │ │ │ │ +_1_9_6 unsigned int ___t_r_a_n_s_i_t_i_o_n_M_a_s_k : 4; │ │ │ │ │ +_1_9_7 unsigned int ___b_o_u_n_d_a_r_y_M_a_s_k : 4; │ │ │ │ │ +_1_9_8 unsigned int ___b_o_u_n_d_a_r_y_I_n_d_e_x : 2; │ │ │ │ │ +_1_9_9 unsigned int ___b_o_u_n_d_a_r_y_C_o_u_n_t : 3; │ │ │ │ │ +_2_0_0 unsigned int ___h_a_s_B_o_u_n_d_a_r_y_E_d_g_e : 3; │ │ │ │ │ +_2_0_1 unsigned int ___i_s_S_i_n_g_l_e_C_r_e_a_s_e : 1; │ │ │ │ │ +202 │ │ │ │ │ +_2_0_3 void _c_l_e_a_r(); │ │ │ │ │ +_2_0_4 void _a_s_s_i_g_n_B_o_u_n_d_a_r_y_P_r_o_p_e_r_t_i_e_s_F_r_o_m_E_d_g_e_M_a_s_k(int boundaryEdgeMask); │ │ │ │ │ +_2_0_5 void _a_s_s_i_g_n_B_o_u_n_d_a_r_y_P_r_o_p_e_r_t_i_e_s_F_r_o_m_V_e_r_t_e_x_M_a_s_k(int boundaryVertexMask); │ │ │ │ │ +_2_0_6 void _a_s_s_i_g_n_T_r_a_n_s_i_t_i_o_n_P_r_o_p_e_r_t_i_e_s_F_r_o_m_E_d_g_e_M_a_s_k(int boundaryVertexMask); │ │ │ │ │ +207 }; │ │ │ │ │ +_2_0_8 typedef std::vector _P_a_t_c_h_T_a_g_V_e_c_t_o_r; │ │ │ │ │ +209}; │ │ │ │ │ +210 │ │ │ │ │ +211 │ │ │ │ │ +_2_1_2template <> inline void PatchTableFactory::Options::SetPatchPrecision │ │ │ │ │ +() { │ │ │ │ │ +213 _p_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e = false; │ │ │ │ │ +214} │ │ │ │ │ +_2_1_5template <> inline void PatchTableFactory::Options:: │ │ │ │ │ +SetFVarPatchPrecision() { │ │ │ │ │ +216 fvarPatchPrecisionDouble = false; │ │ │ │ │ +217} │ │ │ │ │ +218 │ │ │ │ │ +219template <> inline void PatchTableFactory::Options:: │ │ │ │ │ +SetPatchPrecision() { │ │ │ │ │ +220 patchPrecisionDouble = true; │ │ │ │ │ +221} │ │ │ │ │ +222template <> inline void PatchTableFactory::Options:: │ │ │ │ │ +SetFVarPatchPrecision() { │ │ │ │ │ +223 fvarPatchPrecisionDouble = true; │ │ │ │ │ +224} │ │ │ │ │ +225 │ │ │ │ │ +226 │ │ │ │ │ +227} // end namespace Far │ │ │ │ │ +228 │ │ │ │ │ +229} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +230using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +231 │ │ │ │ │ +232} // end namespace OpenSubdiv │ │ │ │ │ 233 │ │ │ │ │ -234 Weight const& VertexWeight(int index) const { return _vertWeights[index]; } │ │ │ │ │ -235 Weight const& EdgeWeight( int index) const { return _edgeWeights[index]; } │ │ │ │ │ -236 Weight const& FaceWeight( int index) const { return _faceWeights[index]; } │ │ │ │ │ -237 │ │ │ │ │ -238 Weight& VertexWeight(int index) { return _vertWeights[index]; } │ │ │ │ │ -239 Weight& EdgeWeight( int index) { return _edgeWeights[index]; } │ │ │ │ │ -240 Weight& FaceWeight( int index) { return _faceWeights[index]; } │ │ │ │ │ -241 │ │ │ │ │ -242 bool AreFaceWeightsForFaceCenters() const { return │ │ │ │ │ -_faceWeightsForFaceCenters; } │ │ │ │ │ -243 void SetFaceWeightsForFaceCenters(bool on) { _faceWeightsForFaceCenters = │ │ │ │ │ -on; } │ │ │ │ │ -244 │ │ │ │ │ -245 private: │ │ │ │ │ -246 Weight* _vertWeights; │ │ │ │ │ -247 Weight* _edgeWeights; │ │ │ │ │ -248 Weight* _faceWeights; │ │ │ │ │ -249 │ │ │ │ │ -250 int _vertCount; │ │ │ │ │ -251 int _edgeCount; │ │ │ │ │ -252 int _faceCount; │ │ │ │ │ -253 │ │ │ │ │ -254 bool _faceWeightsForFaceCenters; │ │ │ │ │ -255 }; │ │ │ │ │ -256}; │ │ │ │ │ -257 │ │ │ │ │ -258 │ │ │ │ │ -259// │ │ │ │ │ -260// Public entry points to the methods. Queries of the scheme type and its │ │ │ │ │ -261// use as a template parameter in subsequent implementation will be factored │ │ │ │ │ -262// out of a later release: │ │ │ │ │ -263// │ │ │ │ │ -264template │ │ │ │ │ -265template │ │ │ │ │ -266inline void │ │ │ │ │ -_2_6_7_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_I_n_t_e_r_p_o_l_a_t_e(int level, T const & src, U & dst) │ │ │ │ │ -const { │ │ │ │ │ -268 │ │ │ │ │ -269 assert(level>0 && level<=(int)_refiner._refinements.size()); │ │ │ │ │ -270 │ │ │ │ │ -271 switch (_refiner._subdivType) { │ │ │ │ │ -272 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ -273 interpFromFaces(level, src, dst); │ │ │ │ │ -274 interpFromEdges(level, src, dst); │ │ │ │ │ -275 interpFromVerts(level, src, dst); │ │ │ │ │ -276 break; │ │ │ │ │ -277 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ -278 interpFromFaces(level, src, dst); │ │ │ │ │ -279 interpFromEdges(level, src, dst); │ │ │ │ │ -280 interpFromVerts(level, src, dst); │ │ │ │ │ -281 break; │ │ │ │ │ -282 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ -283 interpFromFaces(level, src, dst); │ │ │ │ │ -284 interpFromEdges(level, src, dst); │ │ │ │ │ -285 interpFromVerts(level, src, dst); │ │ │ │ │ -286 break; │ │ │ │ │ -287 } │ │ │ │ │ -288} │ │ │ │ │ -289 │ │ │ │ │ -290template │ │ │ │ │ -291template │ │ │ │ │ -292inline void │ │ │ │ │ -_2_9_3_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_V_a_r_y_i_n_g(int level, T const & src, U │ │ │ │ │ -& dst, int channel) const { │ │ │ │ │ -294 │ │ │ │ │ -295 assert(level>0 && level<=(int)_refiner._refinements.size()); │ │ │ │ │ -296 │ │ │ │ │ -297 switch (_refiner._subdivType) { │ │ │ │ │ -298 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ -299 interpFVarFromFaces(level, src, dst, channel); │ │ │ │ │ -300 interpFVarFromEdges(level, src, dst, channel); │ │ │ │ │ -301 interpFVarFromVerts(level, src, dst, channel); │ │ │ │ │ -302 break; │ │ │ │ │ -303 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ -304 interpFVarFromFaces(level, src, dst, channel); │ │ │ │ │ -305 interpFVarFromEdges(level, src, dst, channel); │ │ │ │ │ -306 interpFVarFromVerts(level, src, dst, channel); │ │ │ │ │ -307 break; │ │ │ │ │ -308 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ -309 interpFVarFromFaces(level, src, dst, channel); │ │ │ │ │ -310 interpFVarFromEdges(level, src, dst, channel); │ │ │ │ │ -311 interpFVarFromVerts(level, src, dst, channel); │ │ │ │ │ -312 break; │ │ │ │ │ -313 } │ │ │ │ │ -314} │ │ │ │ │ -315 │ │ │ │ │ -316template │ │ │ │ │ -317template │ │ │ │ │ -318inline void │ │ │ │ │ -_3_1_9_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_L_i_m_i_t(T const & src, U & dst) const { │ │ │ │ │ -320 │ │ │ │ │ -321 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == │ │ │ │ │ -0) { │ │ │ │ │ -322 _E_r_r_o_r(_F_A_R___R_U_N_T_I_M_E___E_R_R_O_R, │ │ │ │ │ -323 "Failure in PrimvarRefiner::Limit() -- " │ │ │ │ │ -324 "last level of refinement does not include full topology."); │ │ │ │ │ -325 return; │ │ │ │ │ -326 } │ │ │ │ │ -327 │ │ │ │ │ -328 switch (_refiner._subdivType) { │ │ │ │ │ -329 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ -330 limit(src, dst, (U*)0, (U*)0); │ │ │ │ │ -331 break; │ │ │ │ │ -332 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ -333 limit(src, dst, (U*)0, (U*)0); │ │ │ │ │ -334 break; │ │ │ │ │ -335 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ -336 limit(src, dst, (U*)0, (U*)0); │ │ │ │ │ -337 break; │ │ │ │ │ -338 } │ │ │ │ │ -339} │ │ │ │ │ -340 │ │ │ │ │ -341template │ │ │ │ │ -342template │ │ │ │ │ -343inline void │ │ │ │ │ -_3_4_4_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_L_i_m_i_t(T const & src, U & dstPos, U1 & dstTan1, U2 │ │ │ │ │ -& dstTan2) const { │ │ │ │ │ -345 │ │ │ │ │ -346 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == │ │ │ │ │ -0) { │ │ │ │ │ -347 _E_r_r_o_r(_F_A_R___R_U_N_T_I_M_E___E_R_R_O_R, │ │ │ │ │ -348 "Failure in PrimvarRefiner::Limit() -- " │ │ │ │ │ -349 "last level of refinement does not include full topology."); │ │ │ │ │ -350 return; │ │ │ │ │ -351 } │ │ │ │ │ -352 │ │ │ │ │ -353 switch (_refiner._subdivType) { │ │ │ │ │ -354 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ -355 limit(src, dstPos, &dstTan1, &dstTan2); │ │ │ │ │ -356 break; │ │ │ │ │ -357 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ -358 limit(src, dstPos, &dstTan1, &dstTan2); │ │ │ │ │ -359 break; │ │ │ │ │ -360 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ -361 limit(src, dstPos, &dstTan1, &dstTan2); │ │ │ │ │ -362 break; │ │ │ │ │ -363 } │ │ │ │ │ -364} │ │ │ │ │ -365 │ │ │ │ │ -366template │ │ │ │ │ -367template │ │ │ │ │ -368inline void │ │ │ │ │ -_3_6_9_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_L_i_m_i_t_F_a_c_e_V_a_r_y_i_n_g(T const & src, U & dst, int │ │ │ │ │ -channel) const { │ │ │ │ │ -370 │ │ │ │ │ -371 if (_refiner.getLevel(_refiner.GetMaxLevel()).getNumVertexEdgesTotal() == │ │ │ │ │ -0) { │ │ │ │ │ -372 _E_r_r_o_r(_F_A_R___R_U_N_T_I_M_E___E_R_R_O_R, │ │ │ │ │ -373 "Failure in PrimvarRefiner::LimitFaceVarying() -- " │ │ │ │ │ -374 "last level of refinement does not include full topology."); │ │ │ │ │ -375 return; │ │ │ │ │ -376 } │ │ │ │ │ -377 │ │ │ │ │ -378 switch (_refiner._subdivType) { │ │ │ │ │ -379 case _S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K: │ │ │ │ │ -380 limitFVar(src, dst, channel); │ │ │ │ │ -381 break; │ │ │ │ │ -382 case _S_d_c_:_:_S_C_H_E_M_E___L_O_O_P: │ │ │ │ │ -383 limitFVar(src, dst, channel); │ │ │ │ │ -384 break; │ │ │ │ │ -385 case _S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R: │ │ │ │ │ -386 limitFVar(src, dst, channel); │ │ │ │ │ -387 break; │ │ │ │ │ -388 } │ │ │ │ │ -389} │ │ │ │ │ -390 │ │ │ │ │ -391template │ │ │ │ │ -392template │ │ │ │ │ -393inline void │ │ │ │ │ -_3_9_4_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_U_n_i_f_o_r_m(int level, T const & src, U │ │ │ │ │ -& dst) const { │ │ │ │ │ -395 │ │ │ │ │ -396 assert(level>0 && level<=(int)_refiner._refinements.size()); │ │ │ │ │ -397 │ │ │ │ │ -398 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ -(level-1); │ │ │ │ │ -399 Vtr::internal::Level const & child = refinement.child(); │ │ │ │ │ -400 │ │ │ │ │ -401 for (int cFace = 0; cFace < child.getNumFaces(); ++cFace) { │ │ │ │ │ -402 │ │ │ │ │ -403 _V_t_r_:_:_I_n_d_e_x pFace = refinement.getChildFaceParentFace(cFace); │ │ │ │ │ -404 │ │ │ │ │ -405 dst[cFace] = src[pFace]; │ │ │ │ │ -406 } │ │ │ │ │ -407} │ │ │ │ │ -408 │ │ │ │ │ -409template │ │ │ │ │ -410template │ │ │ │ │ -411inline void │ │ │ │ │ -_4_1_2_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_I_n_t_e_r_p_o_l_a_t_e_V_a_r_y_i_n_g(int level, T const & src, U & │ │ │ │ │ -dst) const { │ │ │ │ │ -413 │ │ │ │ │ -414 assert(level>0 && level<=(int)_refiner._refinements.size()); │ │ │ │ │ -415 │ │ │ │ │ -416 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ -(level-1); │ │ │ │ │ -417 Vtr::internal::Level const & parent = refinement.parent(); │ │ │ │ │ -418 │ │ │ │ │ -419 // │ │ │ │ │ -420 // Group values to interpolate based on origin -- note that there may │ │ │ │ │ -421 // be none originating from faces: │ │ │ │ │ -422 // │ │ │ │ │ -423 if (refinement.getNumChildVerticesFromFaces() > 0) { │ │ │ │ │ -424 │ │ │ │ │ -425 for (int face = 0; face < parent.getNumFaces(); ++face) { │ │ │ │ │ -426 │ │ │ │ │ -427 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getFaceChildVertex(face); │ │ │ │ │ -428 if (_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) { │ │ │ │ │ -429 │ │ │ │ │ -430 // Apply the weights to the parent face's vertices: │ │ │ │ │ -431 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y fVerts = parent.getFaceVertices(face); │ │ │ │ │ -432 │ │ │ │ │ -433 Weight fVaryingWeight = 1.0f / (Weight) fVerts._s_i_z_e(); │ │ │ │ │ -434 │ │ │ │ │ -435 dst[cVert].Clear(); │ │ │ │ │ -436 for (int i = 0; i < fVerts._s_i_z_e(); ++i) { │ │ │ │ │ -437 dst[cVert].AddWithWeight(src[fVerts[i]], fVaryingWeight); │ │ │ │ │ -438 } │ │ │ │ │ -439 } │ │ │ │ │ -440 } │ │ │ │ │ -441 } │ │ │ │ │ -442 for (int edge = 0; edge < parent.getNumEdges(); ++edge) { │ │ │ │ │ -443 │ │ │ │ │ -444 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getEdgeChildVertex(edge); │ │ │ │ │ -445 if (_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) { │ │ │ │ │ -446 │ │ │ │ │ -447 // Apply the weights to the parent edges's vertices │ │ │ │ │ -448 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eVerts = parent.getEdgeVertices(edge); │ │ │ │ │ -449 │ │ │ │ │ -450 dst[cVert].Clear(); │ │ │ │ │ -451 dst[cVert].AddWithWeight(src[eVerts[0]], 0.5f); │ │ │ │ │ -452 dst[cVert].AddWithWeight(src[eVerts[1]], 0.5f); │ │ │ │ │ -453 } │ │ │ │ │ -454 } │ │ │ │ │ -455 for (int vert = 0; vert < parent.getNumVertices(); ++vert) { │ │ │ │ │ -456 │ │ │ │ │ -457 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getVertexChildVertex(vert); │ │ │ │ │ -458 if (_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) { │ │ │ │ │ -459 │ │ │ │ │ -460 // Essentially copy the parent vertex: │ │ │ │ │ -461 dst[cVert].Clear(); │ │ │ │ │ -462 dst[cVert].AddWithWeight(src[vert], 1.0f); │ │ │ │ │ -463 } │ │ │ │ │ -464 } │ │ │ │ │ -465} │ │ │ │ │ -466 │ │ │ │ │ -467 │ │ │ │ │ -468// │ │ │ │ │ -469// Internal implementation methods -- grouping vertices to be interpolated │ │ │ │ │ -470// based on the type of parent component from which they originated: │ │ │ │ │ -471// │ │ │ │ │ -472template │ │ │ │ │ -473template │ │ │ │ │ -474inline void │ │ │ │ │ -475_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_<_R_E_A_L_>_:_:_i_n_t_e_r_p_F_r_o_m_F_a_c_e_s(int level, T const & src, U & dst) │ │ │ │ │ -const { │ │ │ │ │ -476 │ │ │ │ │ -477 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ -(level-1); │ │ │ │ │ -478 Vtr::internal::Level const & parent = refinement.parent(); │ │ │ │ │ -479 │ │ │ │ │ -480 if (refinement.getNumChildVerticesFromFaces() == 0) return; │ │ │ │ │ -481 │ │ │ │ │ -482 _S_d_c_:_:_S_c_h_e_m_e_<_S_C_H_E_M_E_> scheme(_refiner._subdivOptions); │ │ │ │ │ -483 │ │ │ │ │ -484 Vtr::internal::StackBuffer fVertWeights(parent.getMaxValence()); │ │ │ │ │ -485 │ │ │ │ │ -486 for (int face = 0; face < parent.getNumFaces(); ++face) { │ │ │ │ │ -487 │ │ │ │ │ -488 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getFaceChildVertex(face); │ │ │ │ │ -489 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ -490 continue; │ │ │ │ │ -491 │ │ │ │ │ -492 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ -face: │ │ │ │ │ -493 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y fVerts = parent.getFaceVertices(face); │ │ │ │ │ -494 │ │ │ │ │ -495 Mask fMask(fVertWeights, 0, 0); │ │ │ │ │ -496 Vtr::internal::FaceInterface fHood(fVerts._s_i_z_e()); │ │ │ │ │ -497 │ │ │ │ │ -498 scheme.ComputeFaceVertexMask(fHood, fMask); │ │ │ │ │ -499 │ │ │ │ │ -500 // Apply the weights to the parent face's vertices: │ │ │ │ │ -501 dst[cVert].Clear(); │ │ │ │ │ -502 │ │ │ │ │ -503 for (int i = 0; i < fVerts._s_i_z_e(); ++i) { │ │ │ │ │ -504 │ │ │ │ │ -505 dst[cVert].AddWithWeight(src[fVerts[i]], fVertWeights[i]); │ │ │ │ │ -506 } │ │ │ │ │ -507 } │ │ │ │ │ -508} │ │ │ │ │ -509 │ │ │ │ │ -510template │ │ │ │ │ -511template │ │ │ │ │ -512inline void │ │ │ │ │ -513PrimvarRefinerReal::interpFromEdges(int level, T const & src, U & dst) │ │ │ │ │ -const { │ │ │ │ │ -514 │ │ │ │ │ -515 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ -(level-1); │ │ │ │ │ -516 Vtr::internal::Level const & parent = refinement.parent(); │ │ │ │ │ -517 Vtr::internal::Level const & child = refinement.child(); │ │ │ │ │ -518 │ │ │ │ │ -519 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ -520 │ │ │ │ │ -521 Vtr::internal::EdgeInterface eHood(parent); │ │ │ │ │ -522 │ │ │ │ │ -523 Weight eVertWeights[2]; │ │ │ │ │ -524 Vtr::internal::StackBuffer eFaceWeights(parent.getMaxEdgeFaces │ │ │ │ │ -()); │ │ │ │ │ -525 │ │ │ │ │ -526 for (int edge = 0; edge < parent.getNumEdges(); ++edge) { │ │ │ │ │ -527 │ │ │ │ │ -528 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getEdgeChildVertex(edge); │ │ │ │ │ -529 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ -530 continue; │ │ │ │ │ -531 │ │ │ │ │ -532 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ -edge: │ │ │ │ │ -533 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eVerts = parent.getEdgeVertices(edge), │ │ │ │ │ -534 eFaces = parent.getEdgeFaces(edge); │ │ │ │ │ -535 │ │ │ │ │ -536 Mask eMask(eVertWeights, 0, eFaceWeights); │ │ │ │ │ -537 │ │ │ │ │ -538 eHood.SetIndex(edge); │ │ │ │ │ -539 │ │ │ │ │ -540 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e pRule = (parent.getEdgeSharpness(edge) > 0.0f) ? _S_d_c_:_: │ │ │ │ │ -_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E : Sdc::Crease::RULE_SMOOTH; │ │ │ │ │ -541 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e cRule = child.getVertexRule(cVert); │ │ │ │ │ -542 │ │ │ │ │ -543 scheme.ComputeEdgeVertexMask(eHood, eMask, pRule, cRule); │ │ │ │ │ -544 │ │ │ │ │ -545 // Apply the weights to the parent edges's vertices and (if applicable) to │ │ │ │ │ -546 // the child vertices of its incident faces: │ │ │ │ │ -547 dst[cVert].Clear(); │ │ │ │ │ -548 dst[cVert].AddWithWeight(src[eVerts[0]], eVertWeights[0]); │ │ │ │ │ -549 dst[cVert].AddWithWeight(src[eVerts[1]], eVertWeights[1]); │ │ │ │ │ -550 │ │ │ │ │ -551 if (eMask.GetNumFaceWeights() > 0) { │ │ │ │ │ -552 │ │ │ │ │ -553 for (int i = 0; i < eFaces.size(); ++i) { │ │ │ │ │ -554 │ │ │ │ │ -555 if (eMask.AreFaceWeightsForFaceCenters()) { │ │ │ │ │ -556 assert(refinement.getNumChildVerticesFromFaces() > 0); │ │ │ │ │ -557 _V_t_r_:_:_I_n_d_e_x cVertOfFace = refinement.getFaceChildVertex(eFaces[i]); │ │ │ │ │ -558 │ │ │ │ │ -559 assert(_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVertOfFace)); │ │ │ │ │ -560 dst[cVert].AddWithWeight(dst[cVertOfFace], eFaceWeights[i]); │ │ │ │ │ -561 } else { │ │ │ │ │ -562 _V_t_r_:_:_I_n_d_e_x pFace = eFaces[i]; │ │ │ │ │ -563 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y pFaceEdges = parent.getFaceEdges(pFace), │ │ │ │ │ -564 pFaceVerts = parent.getFaceVertices(pFace); │ │ │ │ │ -565 │ │ │ │ │ -566 int eInFace = 0; │ │ │ │ │ -567 for ( ; pFaceEdges[eInFace] != edge; ++eInFace ) ; │ │ │ │ │ -568 │ │ │ │ │ -569 int vInFace = eInFace + 2; │ │ │ │ │ -570 if (vInFace >= pFaceVerts.size()) vInFace -= pFaceVerts._s_i_z_e(); │ │ │ │ │ -571 │ │ │ │ │ -572 _V_t_r_:_:_I_n_d_e_x pVertNext = pFaceVerts[vInFace]; │ │ │ │ │ -573 dst[cVert].AddWithWeight(src[pVertNext], eFaceWeights[i]); │ │ │ │ │ -574 } │ │ │ │ │ -575 } │ │ │ │ │ -576 } │ │ │ │ │ -577 } │ │ │ │ │ -578} │ │ │ │ │ -579 │ │ │ │ │ -580template │ │ │ │ │ -581template │ │ │ │ │ -582inline void │ │ │ │ │ -583PrimvarRefinerReal::interpFromVerts(int level, T const & src, U & dst) │ │ │ │ │ -const { │ │ │ │ │ -584 │ │ │ │ │ -585 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ -(level-1); │ │ │ │ │ -586 Vtr::internal::Level const & parent = refinement.parent(); │ │ │ │ │ -587 Vtr::internal::Level const & child = refinement.child(); │ │ │ │ │ -588 │ │ │ │ │ -589 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ -590 │ │ │ │ │ -591 Vtr::internal::VertexInterface vHood(parent, child); │ │ │ │ │ -592 │ │ │ │ │ -593 Vtr::internal::StackBuffer weightBuffer(2*parent.getMaxValence │ │ │ │ │ -()); │ │ │ │ │ -594 │ │ │ │ │ -595 for (int vert = 0; vert < parent.getNumVertices(); ++vert) { │ │ │ │ │ -596 │ │ │ │ │ -597 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getVertexChildVertex(vert); │ │ │ │ │ -598 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ -599 continue; │ │ │ │ │ -600 │ │ │ │ │ -601 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ -edge: │ │ │ │ │ -602 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vEdges = parent.getVertexEdges(vert), │ │ │ │ │ -603 vFaces = parent.getVertexFaces(vert); │ │ │ │ │ -604 │ │ │ │ │ -605 Weight vVertWeight, │ │ │ │ │ -606 * vEdgeWeights = weightBuffer, │ │ │ │ │ -607 * vFaceWeights = vEdgeWeights + vEdges._s_i_z_e(); │ │ │ │ │ -608 │ │ │ │ │ -609 Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights); │ │ │ │ │ -610 │ │ │ │ │ -611 vHood.SetIndex(vert, cVert); │ │ │ │ │ -612 │ │ │ │ │ -613 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e pRule = parent.getVertexRule(vert); │ │ │ │ │ -614 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e cRule = child.getVertexRule(cVert); │ │ │ │ │ -615 │ │ │ │ │ -616 scheme.ComputeVertexVertexMask(vHood, vMask, pRule, cRule); │ │ │ │ │ -617 │ │ │ │ │ -618 // Apply the weights to the parent vertex, the vertices opposite its │ │ │ │ │ -incident │ │ │ │ │ -619 // edges, and the child vertices of its incident faces: │ │ │ │ │ -620 // │ │ │ │ │ -621 // In order to improve numerical precision, it's better to apply smaller │ │ │ │ │ -weights │ │ │ │ │ -622 // first, so begin with the face-weights followed by the edge-weights and │ │ │ │ │ -the │ │ │ │ │ -623 // vertex weight last. │ │ │ │ │ -624 dst[cVert].Clear(); │ │ │ │ │ -625 │ │ │ │ │ -626 if (vMask.GetNumFaceWeights() > 0) { │ │ │ │ │ -627 assert(vMask.AreFaceWeightsForFaceCenters()); │ │ │ │ │ -628 │ │ │ │ │ -629 for (int i = 0; i < vFaces.size(); ++i) { │ │ │ │ │ -630 │ │ │ │ │ -631 _V_t_r_:_:_I_n_d_e_x cVertOfFace = refinement.getFaceChildVertex(vFaces[i]); │ │ │ │ │ -632 assert(_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVertOfFace)); │ │ │ │ │ -633 dst[cVert].AddWithWeight(dst[cVertOfFace], vFaceWeights[i]); │ │ │ │ │ -634 } │ │ │ │ │ -635 } │ │ │ │ │ -636 if (vMask.GetNumEdgeWeights() > 0) { │ │ │ │ │ -637 │ │ │ │ │ -638 for (int i = 0; i < vEdges.size(); ++i) { │ │ │ │ │ -639 │ │ │ │ │ -640 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eVerts = parent.getEdgeVertices(vEdges[i]); │ │ │ │ │ -641 _V_t_r_:_:_I_n_d_e_x pVertOppositeEdge = (eVerts[0] == vert) ? eVerts[1] : eVerts[0]; │ │ │ │ │ -642 │ │ │ │ │ -643 dst[cVert].AddWithWeight(src[pVertOppositeEdge], vEdgeWeights[i]); │ │ │ │ │ -644 } │ │ │ │ │ -645 } │ │ │ │ │ -646 dst[cVert].AddWithWeight(src[vert], vVertWeight); │ │ │ │ │ -647 } │ │ │ │ │ -648} │ │ │ │ │ -649 │ │ │ │ │ -650 │ │ │ │ │ -651// │ │ │ │ │ -652// Internal face-varying implementation details: │ │ │ │ │ -653// │ │ │ │ │ -654template │ │ │ │ │ -655template │ │ │ │ │ -656inline void │ │ │ │ │ -657PrimvarRefinerReal::interpFVarFromFaces(int level, T const & src, U & │ │ │ │ │ -dst, int channel) const { │ │ │ │ │ -658 │ │ │ │ │ -659 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ -(level-1); │ │ │ │ │ -660 │ │ │ │ │ -661 if (refinement.getNumChildVerticesFromFaces() == 0) return; │ │ │ │ │ -662 │ │ │ │ │ -663 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ -664 │ │ │ │ │ -665 Vtr::internal::Level const & parentLevel = refinement.parent(); │ │ │ │ │ -666 Vtr::internal::Level const & childLevel = refinement.child(); │ │ │ │ │ -667 │ │ │ │ │ -668 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel │ │ │ │ │ -(channel); │ │ │ │ │ -669 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel │ │ │ │ │ -(channel); │ │ │ │ │ -670 │ │ │ │ │ -671 Vtr::internal::StackBuffer fValueWeights │ │ │ │ │ -(parentLevel.getMaxValence()); │ │ │ │ │ -672 │ │ │ │ │ -673 for (int face = 0; face < parentLevel.getNumFaces(); ++face) { │ │ │ │ │ -674 │ │ │ │ │ -675 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getFaceChildVertex(face); │ │ │ │ │ -676 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ -677 continue; │ │ │ │ │ -678 │ │ │ │ │ -679 _V_t_r_:_:_I_n_d_e_x cVertValue = childFVar.getVertexValueOffset(cVert); │ │ │ │ │ -680 │ │ │ │ │ -681 // The only difference for face-varying here is that we get the values │ │ │ │ │ -associated │ │ │ │ │ -682 // with each face-vertex directly from the FVarLevel, rather than using the │ │ │ │ │ -parent │ │ │ │ │ -683 // face-vertices directly. If any face-vertex has any sibling values, then │ │ │ │ │ -we may │ │ │ │ │ -684 // get the wrong one using the face-vertex index directly. │ │ │ │ │ -685 │ │ │ │ │ -686 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ -face: │ │ │ │ │ -687 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y fValues = parentFVar.getFaceValues(face); │ │ │ │ │ -688 │ │ │ │ │ -689 Mask fMask(fValueWeights, 0, 0); │ │ │ │ │ -690 Vtr::internal::FaceInterface fHood(fValues.size()); │ │ │ │ │ -691 │ │ │ │ │ -692 scheme.ComputeFaceVertexMask(fHood, fMask); │ │ │ │ │ -693 │ │ │ │ │ -694 // Apply the weights to the parent face's vertices: │ │ │ │ │ -695 dst[cVertValue].Clear(); │ │ │ │ │ -696 │ │ │ │ │ -697 for (int i = 0; i < fValues.size(); ++i) { │ │ │ │ │ -698 dst[cVertValue].AddWithWeight(src[fValues[i]], fValueWeights[i]); │ │ │ │ │ -699 } │ │ │ │ │ -700 } │ │ │ │ │ -701} │ │ │ │ │ -702 │ │ │ │ │ -703template │ │ │ │ │ -704template │ │ │ │ │ -705inline void │ │ │ │ │ -706PrimvarRefinerReal::interpFVarFromEdges(int level, T const & src, U & │ │ │ │ │ -dst, int channel) const { │ │ │ │ │ -707 │ │ │ │ │ -708 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ -(level-1); │ │ │ │ │ -709 │ │ │ │ │ -710 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ -711 │ │ │ │ │ -712 Vtr::internal::Level const & parentLevel = refinement.parent(); │ │ │ │ │ -713 Vtr::internal::Level const & childLevel = refinement.child(); │ │ │ │ │ -714 │ │ │ │ │ -715 Vtr::internal::FVarRefinement const & refineFVar = │ │ │ │ │ -refinement.getFVarRefinement(channel); │ │ │ │ │ -716 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel │ │ │ │ │ -(channel); │ │ │ │ │ -717 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel │ │ │ │ │ -(channel); │ │ │ │ │ -718 │ │ │ │ │ -719 // │ │ │ │ │ -720 // Allocate and initialize (if linearly interpolated) interpolation weights │ │ │ │ │ -for │ │ │ │ │ -721 // the edge mask: │ │ │ │ │ -722 // │ │ │ │ │ -723 Weight eVertWeights[2]; │ │ │ │ │ -724 Vtr::internal::StackBuffer eFaceWeights │ │ │ │ │ -(parentLevel.getMaxEdgeFaces()); │ │ │ │ │ -725 │ │ │ │ │ -726 Mask eMask(eVertWeights, 0, eFaceWeights); │ │ │ │ │ -727 │ │ │ │ │ -728 bool isLinearFVar = parentFVar.isLinear() || (_refiner._subdivType == _S_d_c_:_: │ │ │ │ │ -_S_C_H_E_M_E___B_I_L_I_N_E_A_R); │ │ │ │ │ -729 if (isLinearFVar) { │ │ │ │ │ -730 eMask.SetNumVertexWeights(2); │ │ │ │ │ -731 eMask.SetNumEdgeWeights(0); │ │ │ │ │ -732 eMask.SetNumFaceWeights(0); │ │ │ │ │ -733 │ │ │ │ │ -734 eVertWeights[0] = 0.5f; │ │ │ │ │ -735 eVertWeights[1] = 0.5f; │ │ │ │ │ -736 } │ │ │ │ │ -737 │ │ │ │ │ -738 Vtr::internal::EdgeInterface eHood(parentLevel); │ │ │ │ │ -739 │ │ │ │ │ -740 for (int edge = 0; edge < parentLevel.getNumEdges(); ++edge) { │ │ │ │ │ -741 │ │ │ │ │ -742 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getEdgeChildVertex(edge); │ │ │ │ │ -743 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ -744 continue; │ │ │ │ │ -745 │ │ │ │ │ -746 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y cVertValues = childFVar.getVertexValues(cVert); │ │ │ │ │ -747 │ │ │ │ │ -748 bool fvarEdgeVertMatchesVertex = childFVar.valueTopologyMatches(cVertValues │ │ │ │ │ -[0]); │ │ │ │ │ -749 if (fvarEdgeVertMatchesVertex) { │ │ │ │ │ -750 // │ │ │ │ │ -751 // If smoothly interpolated, compute new weights for the edge mask: │ │ │ │ │ -752 // │ │ │ │ │ -753 if (!isLinearFVar) { │ │ │ │ │ -754 eHood.SetIndex(edge); │ │ │ │ │ -755 │ │ │ │ │ -756 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e pRule = (parentLevel.getEdgeSharpness(edge) > 0.0f) │ │ │ │ │ -757 ? _S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E : Sdc::Crease::RULE_SMOOTH; │ │ │ │ │ -758 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e cRule = childLevel.getVertexRule(cVert); │ │ │ │ │ -759 │ │ │ │ │ -760 scheme.ComputeEdgeVertexMask(eHood, eMask, pRule, cRule); │ │ │ │ │ -761 } │ │ │ │ │ -762 │ │ │ │ │ -763 // Apply the weights to the parent edge's vertices and (if applicable) to │ │ │ │ │ -764 // the child vertices of its incident faces: │ │ │ │ │ -765 // │ │ │ │ │ -766 // Even though the face-varying topology matches the vertex topology, we │ │ │ │ │ -need │ │ │ │ │ -767 // to be careful here when getting values corresponding to the two end- │ │ │ │ │ -vertices. │ │ │ │ │ -768 // While the edge may be continuous, the vertices at their ends may have │ │ │ │ │ -769 // discontinuities elsewhere in their neighborhood (i.e. on the "other │ │ │ │ │ -side" │ │ │ │ │ -770 // of the end-vertex) and so have sibling values associated with them. In │ │ │ │ │ -most │ │ │ │ │ -771 // cases the topology for an end-vertex will match and we can use it │ │ │ │ │ -directly, │ │ │ │ │ -772 // but we must still check and retrieve as needed. │ │ │ │ │ -773 // │ │ │ │ │ -774 // Indices for values corresponding to face-vertices are guaranteed to │ │ │ │ │ -match, │ │ │ │ │ -775 // so we can use the child-vertex indices directly. │ │ │ │ │ -776 // │ │ │ │ │ -777 // And by "directly", we always use getVertexValue(vertexIndex) to │ │ │ │ │ -reference │ │ │ │ │ -778 // values in the "src" to account for the possible indirection that may │ │ │ │ │ -exist at │ │ │ │ │ -779 // level 0 -- where there may be fewer values than vertices and an │ │ │ │ │ -additional │ │ │ │ │ -780 // indirection is necessary. We can use a vertex index directly for "dst" │ │ │ │ │ -when │ │ │ │ │ -781 // it matches. │ │ │ │ │ -782 // │ │ │ │ │ -783 _V_t_r_:_:_I_n_d_e_x eVertValues[2]; │ │ │ │ │ -784 │ │ │ │ │ -785 parentFVar.getEdgeFaceValues(edge, 0, eVertValues); │ │ │ │ │ -786 │ │ │ │ │ -787 _I_n_d_e_x cVertValue = cVertValues[0]; │ │ │ │ │ -788 │ │ │ │ │ -789 dst[cVertValue].Clear(); │ │ │ │ │ -790 dst[cVertValue].AddWithWeight(src[eVertValues[0]], eVertWeights[0]); │ │ │ │ │ -791 dst[cVertValue].AddWithWeight(src[eVertValues[1]], eVertWeights[1]); │ │ │ │ │ -792 │ │ │ │ │ -793 if (eMask.GetNumFaceWeights() > 0) { │ │ │ │ │ -794 │ │ │ │ │ -795 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eFaces = parentLevel.getEdgeFaces(edge); │ │ │ │ │ -796 │ │ │ │ │ -797 for (int i = 0; i < eFaces.size(); ++i) { │ │ │ │ │ -798 if (eMask.AreFaceWeightsForFaceCenters()) { │ │ │ │ │ -799 │ │ │ │ │ -800 _V_t_r_:_:_I_n_d_e_x cVertOfFace = refinement.getFaceChildVertex(eFaces[i]); │ │ │ │ │ -801 assert(_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVertOfFace)); │ │ │ │ │ -802 │ │ │ │ │ -803 _V_t_r_:_:_I_n_d_e_x cValueOfFace = childFVar.getVertexValueOffset(cVertOfFace); │ │ │ │ │ -804 dst[cVertValue].AddWithWeight(dst[cValueOfFace], eFaceWeights[i]); │ │ │ │ │ -805 } else { │ │ │ │ │ -806 _V_t_r_:_:_I_n_d_e_x pFace = eFaces[i]; │ │ │ │ │ -807 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y pFaceEdges = parentLevel.getFaceEdges(pFace), │ │ │ │ │ -808 pFaceVerts = parentLevel.getFaceVertices(pFace); │ │ │ │ │ -809 │ │ │ │ │ -810 int eInFace = 0; │ │ │ │ │ -811 for ( ; pFaceEdges[eInFace] != edge; ++eInFace ) ; │ │ │ │ │ -812 │ │ │ │ │ -813 // Edge "i" spans vertices [i,i+1] so we want i+2... │ │ │ │ │ -814 int vInFace = eInFace + 2; │ │ │ │ │ -815 if (vInFace >= pFaceVerts.size()) vInFace -= pFaceVerts._s_i_z_e(); │ │ │ │ │ -816 │ │ │ │ │ -817 _V_t_r_:_:_I_n_d_e_x pValueNext = parentFVar.getFaceValues(pFace)[vInFace]; │ │ │ │ │ -818 dst[cVertValue].AddWithWeight(src[pValueNext], eFaceWeights[i]); │ │ │ │ │ -819 } │ │ │ │ │ -820 } │ │ │ │ │ -821 } │ │ │ │ │ -822 } else { │ │ │ │ │ -823 // │ │ │ │ │ -824 // Mismatched edge-verts should just be linearly interpolated between the │ │ │ │ │ -pairs of │ │ │ │ │ -825 // values for each sibling of the child edge-vertex -- the question is: │ │ │ │ │ -which face │ │ │ │ │ -826 // holds that pair of values for a given sibling? │ │ │ │ │ -827 // │ │ │ │ │ -828 // In the manifold case, the sibling and edge-face indices will correspond. │ │ │ │ │ -We │ │ │ │ │ -829 // will eventually need to update this to account for > 3 incident faces. │ │ │ │ │ -830 // │ │ │ │ │ -831 for (int i = 0; i < cVertValues.size(); ++i) { │ │ │ │ │ -832 _V_t_r_:_:_I_n_d_e_x eVertValues[2]; │ │ │ │ │ -833 int eFaceIndex = refineFVar.getChildValueParentSource(cVert, i); │ │ │ │ │ -834 assert(eFaceIndex == i); │ │ │ │ │ -835 │ │ │ │ │ -836 parentFVar.getEdgeFaceValues(edge, eFaceIndex, eVertValues); │ │ │ │ │ -837 │ │ │ │ │ -838 _I_n_d_e_x cVertValue = cVertValues[i]; │ │ │ │ │ -839 │ │ │ │ │ -840 dst[cVertValue].Clear(); │ │ │ │ │ -841 dst[cVertValue].AddWithWeight(src[eVertValues[0]], 0.5); │ │ │ │ │ -842 dst[cVertValue].AddWithWeight(src[eVertValues[1]], 0.5); │ │ │ │ │ -843 } │ │ │ │ │ -844 } │ │ │ │ │ -845 } │ │ │ │ │ -846} │ │ │ │ │ -847 │ │ │ │ │ -848template │ │ │ │ │ -849template │ │ │ │ │ -850inline void │ │ │ │ │ -851PrimvarRefinerReal::interpFVarFromVerts(int level, T const & src, U & │ │ │ │ │ -dst, int channel) const { │ │ │ │ │ -852 │ │ │ │ │ -853 Vtr::internal::Refinement const & refinement = _refiner.getRefinement │ │ │ │ │ -(level-1); │ │ │ │ │ -854 │ │ │ │ │ -855 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ -856 │ │ │ │ │ -857 Vtr::internal::Level const & parentLevel = refinement.parent(); │ │ │ │ │ -858 Vtr::internal::Level const & childLevel = refinement.child(); │ │ │ │ │ -859 │ │ │ │ │ -860 Vtr::internal::FVarRefinement const & refineFVar = │ │ │ │ │ -refinement.getFVarRefinement(channel); │ │ │ │ │ -861 Vtr::internal::FVarLevel const & parentFVar = parentLevel.getFVarLevel │ │ │ │ │ -(channel); │ │ │ │ │ -862 Vtr::internal::FVarLevel const & childFVar = childLevel.getFVarLevel │ │ │ │ │ -(channel); │ │ │ │ │ -863 │ │ │ │ │ -864 bool isLinearFVar = parentFVar.isLinear() || (_refiner._subdivType == _S_d_c_:_: │ │ │ │ │ -_S_C_H_E_M_E___B_I_L_I_N_E_A_R); │ │ │ │ │ -865 │ │ │ │ │ -866 Vtr::internal::StackBuffer weightBuffer │ │ │ │ │ -(2*parentLevel.getMaxValence()); │ │ │ │ │ -867 │ │ │ │ │ -868 Vtr::internal::StackBuffer vEdgeValues │ │ │ │ │ -(parentLevel.getMaxValence()); │ │ │ │ │ -869 │ │ │ │ │ -870 Vtr::internal::VertexInterface vHood(parentLevel, childLevel); │ │ │ │ │ -871 │ │ │ │ │ -872 for (int vert = 0; vert < parentLevel.getNumVertices(); ++vert) { │ │ │ │ │ -873 │ │ │ │ │ -874 _V_t_r_:_:_I_n_d_e_x cVert = refinement.getVertexChildVertex(vert); │ │ │ │ │ -875 if (!_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVert)) │ │ │ │ │ -876 continue; │ │ │ │ │ -877 │ │ │ │ │ -878 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y pVertValues = parentFVar.getVertexValues(vert), │ │ │ │ │ -879 cVertValues = childFVar.getVertexValues(cVert); │ │ │ │ │ -880 │ │ │ │ │ -881 bool fvarVertVertMatchesVertex = childFVar.valueTopologyMatches(cVertValues │ │ │ │ │ -[0]); │ │ │ │ │ -882 if (isLinearFVar && fvarVertVertMatchesVertex) { │ │ │ │ │ -883 dst[cVertValues[0]].Clear(); │ │ │ │ │ -884 dst[cVertValues[0]].AddWithWeight(src[pVertValues[0]], 1.0f); │ │ │ │ │ -885 continue; │ │ │ │ │ -886 } │ │ │ │ │ -887 │ │ │ │ │ -888 if (fvarVertVertMatchesVertex) { │ │ │ │ │ -889 // │ │ │ │ │ -890 // Declare and compute mask weights for this vertex relative to its parent │ │ │ │ │ -edge: │ │ │ │ │ -891 // │ │ │ │ │ -892 // (We really need to encapsulate this somewhere else for use here and in │ │ │ │ │ -the │ │ │ │ │ -893 // general case) │ │ │ │ │ -894 // │ │ │ │ │ -895 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vEdges = parentLevel.getVertexEdges(vert); │ │ │ │ │ -896 │ │ │ │ │ -897 Weight vVertWeight; │ │ │ │ │ -898 Weight * vEdgeWeights = weightBuffer; │ │ │ │ │ -899 Weight * vFaceWeights = vEdgeWeights + vEdges._s_i_z_e(); │ │ │ │ │ -900 │ │ │ │ │ -901 Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights); │ │ │ │ │ -902 │ │ │ │ │ -903 vHood.SetIndex(vert, cVert); │ │ │ │ │ -904 │ │ │ │ │ -905 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e pRule = parentLevel.getVertexRule(vert); │ │ │ │ │ -906 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e cRule = childLevel.getVertexRule(cVert); │ │ │ │ │ -907 │ │ │ │ │ -908 scheme.ComputeVertexVertexMask(vHood, vMask, pRule, cRule); │ │ │ │ │ -909 │ │ │ │ │ -910 // Apply the weights to the parent vertex, the vertices opposite its │ │ │ │ │ -incident │ │ │ │ │ -911 // edges, and the child vertices of its incident faces: │ │ │ │ │ -912 // │ │ │ │ │ -913 // Even though the face-varying topology matches the vertex topology, we │ │ │ │ │ -need │ │ │ │ │ -914 // to be careful here when getting values corresponding to vertices at the │ │ │ │ │ -915 // ends of edges. While the edge may be continuous, the end vertex may have │ │ │ │ │ -916 // discontinuities elsewhere in their neighborhood (i.e. on the "other │ │ │ │ │ -side" │ │ │ │ │ -917 // of the end-vertex) and so have sibling values associated with them. In │ │ │ │ │ -most │ │ │ │ │ -918 // cases the topology for an end-vertex will match and we can use it │ │ │ │ │ -directly, │ │ │ │ │ -919 // but we must still check and retrieve as needed. │ │ │ │ │ -920 // │ │ │ │ │ -921 // Indices for values corresponding to face-vertices are guaranteed to │ │ │ │ │ -match, │ │ │ │ │ -922 // so we can use the child-vertex indices directly. │ │ │ │ │ -923 // │ │ │ │ │ -924 // And by "directly", we always use getVertexValue(vertexIndex) to │ │ │ │ │ -reference │ │ │ │ │ -925 // values in the "src" to account for the possible indirection that may │ │ │ │ │ -exist at │ │ │ │ │ -926 // level 0 -- where there may be fewer values than vertices and an │ │ │ │ │ -additional │ │ │ │ │ -927 // indirection is necessary. We can use a vertex index directly for "dst" │ │ │ │ │ -when │ │ │ │ │ -928 // it matches. │ │ │ │ │ -929 // │ │ │ │ │ -930 // As with applying the mask to vertex data, in order to improve numerical │ │ │ │ │ -931 // precision, it's better to apply smaller weights first, so begin with the │ │ │ │ │ -932 // face-weights followed by the edge-weights and the vertex weight last. │ │ │ │ │ -933 // │ │ │ │ │ -934 _V_t_r_:_:_I_n_d_e_x pVertValue = pVertValues[0]; │ │ │ │ │ -935 _V_t_r_:_:_I_n_d_e_x cVertValue = cVertValues[0]; │ │ │ │ │ -936 │ │ │ │ │ -937 dst[cVertValue].Clear(); │ │ │ │ │ -938 if (vMask.GetNumFaceWeights() > 0) { │ │ │ │ │ -939 assert(vMask.AreFaceWeightsForFaceCenters()); │ │ │ │ │ -940 │ │ │ │ │ -941 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vFaces = parentLevel.getVertexFaces(vert); │ │ │ │ │ -942 │ │ │ │ │ -943 for (int i = 0; i < vFaces.size(); ++i) { │ │ │ │ │ -944 │ │ │ │ │ -945 _V_t_r_:_:_I_n_d_e_x cVertOfFace = refinement.getFaceChildVertex(vFaces[i]); │ │ │ │ │ -946 assert(_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d(cVertOfFace)); │ │ │ │ │ -947 │ │ │ │ │ -948 _V_t_r_:_:_I_n_d_e_x cValueOfFace = childFVar.getVertexValueOffset(cVertOfFace); │ │ │ │ │ -949 dst[cVertValue].AddWithWeight(dst[cValueOfFace], vFaceWeights[i]); │ │ │ │ │ -950 } │ │ │ │ │ -951 } │ │ │ │ │ -952 if (vMask.GetNumEdgeWeights() > 0) { │ │ │ │ │ -953 │ │ │ │ │ -954 parentFVar.getVertexEdgeValues(vert, vEdgeValues); │ │ │ │ │ -955 │ │ │ │ │ -956 for (int i = 0; i < vEdges.size(); ++i) { │ │ │ │ │ -957 dst[cVertValue].AddWithWeight(src[vEdgeValues[i]], vEdgeWeights[i]); │ │ │ │ │ -958 } │ │ │ │ │ -959 } │ │ │ │ │ -960 dst[cVertValue].AddWithWeight(src[pVertValue], vVertWeight); │ │ │ │ │ -961 } else { │ │ │ │ │ -962 // │ │ │ │ │ -963 // Each FVar value associated with a vertex will be either a corner or a │ │ │ │ │ -crease, │ │ │ │ │ -964 // or potentially in transition from corner to crease: │ │ │ │ │ -965 // - if the CHILD is a corner, there can be no transition so we have a │ │ │ │ │ -corner │ │ │ │ │ -966 // - otherwise if the PARENT is a crease, both will be creases (no │ │ │ │ │ -transition) │ │ │ │ │ -967 // - otherwise the parent must be a corner and the child a crease │ │ │ │ │ -(transition) │ │ │ │ │ -968 // │ │ │ │ │ -969 Vtr::internal::FVarLevel::ConstValueTagArray pValueTags = │ │ │ │ │ -parentFVar.getVertexValueTags(vert); │ │ │ │ │ -970 Vtr::internal::FVarLevel::ConstValueTagArray cValueTags = │ │ │ │ │ -childFVar.getVertexValueTags(cVert); │ │ │ │ │ -971 │ │ │ │ │ -972 for (int cSiblingIndex = 0; cSiblingIndex < cVertValues.size(); │ │ │ │ │ -++cSiblingIndex) { │ │ │ │ │ -973 int pSiblingIndex = refineFVar.getChildValueParentSource(cVert, │ │ │ │ │ -cSiblingIndex); │ │ │ │ │ -974 assert(pSiblingIndex == cSiblingIndex); │ │ │ │ │ -975 │ │ │ │ │ -976 typedef Vtr::internal::FVarLevel::Sibling SiblingIntType; │ │ │ │ │ -977 │ │ │ │ │ -978 SiblingIntType cSibling = (SiblingIntType) cSiblingIndex; │ │ │ │ │ -979 SiblingIntType pSibling = (SiblingIntType) pSiblingIndex; │ │ │ │ │ -980 │ │ │ │ │ -981 _V_t_r_:_:_I_n_d_e_x pVertValue = pVertValues[pSibling]; │ │ │ │ │ -982 _V_t_r_:_:_I_n_d_e_x cVertValue = cVertValues[cSibling]; │ │ │ │ │ -983 │ │ │ │ │ -984 dst[cVertValue].Clear(); │ │ │ │ │ -985 if (isLinearFVar || cValueTags[cSibling].isCorner()) { │ │ │ │ │ -986 dst[cVertValue].AddWithWeight(src[pVertValue], 1.0f); │ │ │ │ │ -987 } else { │ │ │ │ │ -988 // │ │ │ │ │ -989 // We have either a crease or a transition from corner to crease -- in │ │ │ │ │ -990 // either case, we need the end values for the full/fractional crease: │ │ │ │ │ -991 // │ │ │ │ │ -992 _I_n_d_e_x pEndValues[2]; │ │ │ │ │ -993 parentFVar.getVertexCreaseEndValues(vert, pSibling, pEndValues); │ │ │ │ │ -994 │ │ │ │ │ -995 Weight vWeight = 0.75f; │ │ │ │ │ -996 Weight eWeight = 0.125f; │ │ │ │ │ -997 │ │ │ │ │ -998 // │ │ │ │ │ -999 // If semi-sharp we need to apply fractional weighting -- if made sharp │ │ │ │ │ -because │ │ │ │ │ -1000 // of the other sibling (dependent-sharp) use the fractional weight from │ │ │ │ │ -that │ │ │ │ │ -1001 // other sibling (should only occur when there are 2): │ │ │ │ │ -1002 // │ │ │ │ │ -1003 if (pValueTags[pSibling].isSemiSharp()) { │ │ │ │ │ -1004 Weight wCorner = pValueTags[pSibling].isDepSharp() │ │ │ │ │ -1005 ? refineFVar.getFractionalWeight(vert, !pSibling, cVert, !cSibling) │ │ │ │ │ -1006 : refineFVar.getFractionalWeight(vert, pSibling, cVert, cSibling); │ │ │ │ │ -1007 Weight wCrease = 1.0f - wCorner; │ │ │ │ │ -1008 │ │ │ │ │ -1009 vWeight = wCrease * 0.75f + wCorner; │ │ │ │ │ -1010 eWeight = wCrease * 0.125f; │ │ │ │ │ -1011 } │ │ │ │ │ -1012 dst[cVertValue].AddWithWeight(src[pEndValues[0]], eWeight); │ │ │ │ │ -1013 dst[cVertValue].AddWithWeight(src[pEndValues[1]], eWeight); │ │ │ │ │ -1014 dst[cVertValue].AddWithWeight(src[pVertValue], vWeight); │ │ │ │ │ -1015 } │ │ │ │ │ -1016 } │ │ │ │ │ -1017 } │ │ │ │ │ -1018 } │ │ │ │ │ -1019} │ │ │ │ │ -1020 │ │ │ │ │ -1021template │ │ │ │ │ -1022template │ │ │ │ │ -1023inline void │ │ │ │ │ -1024PrimvarRefinerReal::limit(T const & src, U & dstPos, U1 * dstTan1Ptr, │ │ │ │ │ -U2 * dstTan2Ptr) const { │ │ │ │ │ -1025 │ │ │ │ │ -1026 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ -1027 │ │ │ │ │ -1028 Vtr::internal::Level const & level = _refiner.getLevel │ │ │ │ │ -(_refiner.GetMaxLevel()); │ │ │ │ │ -1029 │ │ │ │ │ -1030 int maxWeightsPerMask = 1 + 2 * level.getMaxValence(); │ │ │ │ │ -1031 bool hasTangents = (dstTan1Ptr && dstTan2Ptr); │ │ │ │ │ -1032 int numMasks = 1 + (hasTangents ? 2 : 0); │ │ │ │ │ -1033 │ │ │ │ │ -1034 Vtr::internal::StackBuffer indexBuffer(maxWeightsPerMask); │ │ │ │ │ -1035 Vtr::internal::StackBuffer weightBuffer(numMasks * │ │ │ │ │ -maxWeightsPerMask); │ │ │ │ │ -1036 │ │ │ │ │ -1037 Weight * vPosWeights = weightBuffer, │ │ │ │ │ -1038 * ePosWeights = vPosWeights + 1, │ │ │ │ │ -1039 * fPosWeights = ePosWeights + level.getMaxValence(); │ │ │ │ │ -1040 Weight * vTan1Weights = vPosWeights + maxWeightsPerMask, │ │ │ │ │ -1041 * eTan1Weights = ePosWeights + maxWeightsPerMask, │ │ │ │ │ -1042 * fTan1Weights = fPosWeights + maxWeightsPerMask; │ │ │ │ │ -1043 Weight * vTan2Weights = vTan1Weights + maxWeightsPerMask, │ │ │ │ │ -1044 * eTan2Weights = eTan1Weights + maxWeightsPerMask, │ │ │ │ │ -1045 * fTan2Weights = fTan1Weights + maxWeightsPerMask; │ │ │ │ │ -1046 │ │ │ │ │ -1047 Mask posMask( vPosWeights, ePosWeights, fPosWeights); │ │ │ │ │ -1048 Mask tan1Mask(vTan1Weights, eTan1Weights, fTan1Weights); │ │ │ │ │ -1049 Mask tan2Mask(vTan2Weights, eTan2Weights, fTan2Weights); │ │ │ │ │ -1050 │ │ │ │ │ -1051 // This is a bit obscure -- assigning both parent and child as last level │ │ │ │ │ --- but │ │ │ │ │ -1052 // this mask type was intended for another purpose. Consider one for the │ │ │ │ │ -limit: │ │ │ │ │ -1053 Vtr::internal::VertexInterface vHood(level, level); │ │ │ │ │ -1054 │ │ │ │ │ -1055 for (int vert = 0; vert < level.getNumVertices(); ++vert) { │ │ │ │ │ -1056 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vEdges = level.getVertexEdges(vert); │ │ │ │ │ -1057 │ │ │ │ │ -1058 // Incomplete vertices (present in sparse refinement) do not have their │ │ │ │ │ -full │ │ │ │ │ -1059 // topological neighborhood to determine a proper limit -- just leave the │ │ │ │ │ -1060 // vertex at the refined location and continue to the next: │ │ │ │ │ -1061 if (level.getVertexTag(vert)._incomplete || (vEdges.size() == 0)) { │ │ │ │ │ -1062 dstPos[vert].Clear(); │ │ │ │ │ -1063 dstPos[vert].AddWithWeight(src[vert], 1.0); │ │ │ │ │ -1064 if (hasTangents) { │ │ │ │ │ -1065 (*dstTan1Ptr)[vert].Clear(); │ │ │ │ │ -1066 (*dstTan2Ptr)[vert].Clear(); │ │ │ │ │ -1067 } │ │ │ │ │ -1068 continue; │ │ │ │ │ -1069 } │ │ │ │ │ -1070 │ │ │ │ │ -1071 // │ │ │ │ │ -1072 // Limit masks require the subdivision Rule for the vertex in order to │ │ │ │ │ -deal │ │ │ │ │ -1073 // with infinitely sharp features correctly -- including boundaries and │ │ │ │ │ -corners. │ │ │ │ │ -1074 // The vertex neighborhood is minimally defined with vertex and edge │ │ │ │ │ -counts. │ │ │ │ │ -1075 // │ │ │ │ │ -1076 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e vRule = level.getVertexRule(vert); │ │ │ │ │ -1077 │ │ │ │ │ -1078 // This is a bit obscure -- child vertex index will be ignored here │ │ │ │ │ -1079 vHood.SetIndex(vert, vert); │ │ │ │ │ -1080 │ │ │ │ │ -1081 if (hasTangents) { │ │ │ │ │ -1082 scheme.ComputeVertexLimitMask(vHood, posMask, tan1Mask, tan2Mask, vRule); │ │ │ │ │ -1083 } else { │ │ │ │ │ -1084 scheme.ComputeVertexLimitMask(vHood, posMask, vRule); │ │ │ │ │ -1085 } │ │ │ │ │ -1086 │ │ │ │ │ -1087 // │ │ │ │ │ -1088 // Gather the neighboring vertices of this vertex -- the vertices opposite │ │ │ │ │ -its │ │ │ │ │ -1089 // incident edges, and the opposite vertices of its incident faces: │ │ │ │ │ -1090 // │ │ │ │ │ -1091 _I_n_d_e_x * eIndices = indexBuffer; │ │ │ │ │ -1092 _I_n_d_e_x * fIndices = indexBuffer + vEdges._s_i_z_e(); │ │ │ │ │ -1093 │ │ │ │ │ -1094 for (int i = 0; i < vEdges.size(); ++i) { │ │ │ │ │ -1095 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y eVerts = level.getEdgeVertices(vEdges[i]); │ │ │ │ │ -1096 │ │ │ │ │ -1097 eIndices[i] = (eVerts[0] == vert) ? eVerts[1] : eVerts[0]; │ │ │ │ │ -1098 } │ │ │ │ │ -1099 if (posMask.GetNumFaceWeights() || (hasTangents && │ │ │ │ │ -tan1Mask.GetNumFaceWeights())) { │ │ │ │ │ -1100 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vFaces = level.getVertexFaces(vert); │ │ │ │ │ -1101 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y vInFace = level.getVertexFaceLocalIndices(vert); │ │ │ │ │ -1102 │ │ │ │ │ -1103 for (int i = 0; i < vFaces.size(); ++i) { │ │ │ │ │ -1104 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y fVerts = level.getFaceVertices(vFaces[i]); │ │ │ │ │ -1105 │ │ │ │ │ -1106 _L_o_c_a_l_I_n_d_e_x vOppInFace = (vInFace[i] + 2); │ │ │ │ │ -1107 if (vOppInFace >= fVerts.size()) vOppInFace -= (_L_o_c_a_l_I_n_d_e_x)fVerts._s_i_z_e(); │ │ │ │ │ -1108 │ │ │ │ │ -1109 fIndices[i] = level.getFaceVertices(vFaces[i])[vOppInFace]; │ │ │ │ │ -1110 } │ │ │ │ │ -1111 } │ │ │ │ │ -1112 │ │ │ │ │ -1113 // │ │ │ │ │ -1114 // Combine the weights and indices for position and tangents. As with │ │ │ │ │ -applying │ │ │ │ │ -1115 // refinement masks to vertex data, in order to improve numerical │ │ │ │ │ -precision, it's │ │ │ │ │ -1116 // better to apply smaller weights first, so begin with the face-weights │ │ │ │ │ -followed │ │ │ │ │ -1117 // by the edge-weights and the vertex weight last. │ │ │ │ │ -1118 // │ │ │ │ │ -1119 dstPos[vert].Clear(); │ │ │ │ │ -1120 for (int i = 0; i < posMask.GetNumFaceWeights(); ++i) { │ │ │ │ │ -1121 dstPos[vert].AddWithWeight(src[fIndices[i]], fPosWeights[i]); │ │ │ │ │ -1122 } │ │ │ │ │ -1123 for (int i = 0; i < posMask.GetNumEdgeWeights(); ++i) { │ │ │ │ │ -1124 dstPos[vert].AddWithWeight(src[eIndices[i]], ePosWeights[i]); │ │ │ │ │ -1125 } │ │ │ │ │ -1126 dstPos[vert].AddWithWeight(src[vert], vPosWeights[0]); │ │ │ │ │ -1127 │ │ │ │ │ -1128 // │ │ │ │ │ -1129 // Apply the tangent masks -- both will have the same number of weights │ │ │ │ │ -and │ │ │ │ │ -1130 // indices (one tangent may be "padded" to accommodate the other), but │ │ │ │ │ -these │ │ │ │ │ -1131 // may differ from those of the position: │ │ │ │ │ -1132 // │ │ │ │ │ -1133 if (hasTangents) { │ │ │ │ │ -1134 assert(tan1Mask.GetNumFaceWeights() == tan2Mask.GetNumFaceWeights()); │ │ │ │ │ -1135 assert(tan1Mask.GetNumEdgeWeights() == tan2Mask.GetNumEdgeWeights()); │ │ │ │ │ -1136 │ │ │ │ │ -1137 U1 & dstTan1 = *dstTan1Ptr; │ │ │ │ │ -1138 U2 & dstTan2 = *dstTan2Ptr; │ │ │ │ │ -1139 │ │ │ │ │ -1140 dstTan1[vert].Clear(); │ │ │ │ │ -1141 dstTan2[vert].Clear(); │ │ │ │ │ -1142 for (int i = 0; i < tan1Mask.GetNumFaceWeights(); ++i) { │ │ │ │ │ -1143 dstTan1[vert].AddWithWeight(src[fIndices[i]], fTan1Weights[i]); │ │ │ │ │ -1144 dstTan2[vert].AddWithWeight(src[fIndices[i]], fTan2Weights[i]); │ │ │ │ │ -1145 } │ │ │ │ │ -1146 for (int i = 0; i < tan1Mask.GetNumEdgeWeights(); ++i) { │ │ │ │ │ -1147 dstTan1[vert].AddWithWeight(src[eIndices[i]], eTan1Weights[i]); │ │ │ │ │ -1148 dstTan2[vert].AddWithWeight(src[eIndices[i]], eTan2Weights[i]); │ │ │ │ │ -1149 } │ │ │ │ │ -1150 dstTan1[vert].AddWithWeight(src[vert], vTan1Weights[0]); │ │ │ │ │ -1151 dstTan2[vert].AddWithWeight(src[vert], vTan2Weights[0]); │ │ │ │ │ -1152 } │ │ │ │ │ -1153 } │ │ │ │ │ -1154} │ │ │ │ │ -1155 │ │ │ │ │ -1156template │ │ │ │ │ -1157template │ │ │ │ │ -1158inline void │ │ │ │ │ -1159PrimvarRefinerReal::limitFVar(T const & src, U & dst, int channel) │ │ │ │ │ -const { │ │ │ │ │ -1160 │ │ │ │ │ -1161 Sdc::Scheme scheme(_refiner._subdivOptions); │ │ │ │ │ -1162 │ │ │ │ │ -1163 Vtr::internal::Level const & level = _refiner.getLevel │ │ │ │ │ -(_refiner.GetMaxLevel()); │ │ │ │ │ -1164 Vtr::internal::FVarLevel const & fvarChannel = level.getFVarLevel │ │ │ │ │ -(channel); │ │ │ │ │ -1165 │ │ │ │ │ -1166 int maxWeightsPerMask = 1 + 2 * level.getMaxValence(); │ │ │ │ │ -1167 │ │ │ │ │ -1168 Vtr::internal::StackBuffer weightBuffer(maxWeightsPerMask); │ │ │ │ │ -1169 Vtr::internal::StackBuffer vEdgeBuffer(level.getMaxValence()); │ │ │ │ │ -1170 │ │ │ │ │ -1171 // This is a bit obscure -- assign both parent and child as last level │ │ │ │ │ -1172 Vtr::internal::VertexInterface vHood(level, level); │ │ │ │ │ -1173 │ │ │ │ │ -1174 for (int vert = 0; vert < level.getNumVertices(); ++vert) { │ │ │ │ │ -1175 │ │ │ │ │ -1176 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vEdges = level.getVertexEdges(vert); │ │ │ │ │ -1177 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vValues = fvarChannel.getVertexValues(vert); │ │ │ │ │ -1178 │ │ │ │ │ -1179 // Incomplete vertices (present in sparse refinement) do not have their │ │ │ │ │ -full │ │ │ │ │ -1180 // topological neighborhood to determine a proper limit -- just leave the │ │ │ │ │ -1181 // values (perhaps more than one per vertex) at the refined location. │ │ │ │ │ -1182 // │ │ │ │ │ -1183 // The same can be done if the face-varying channel is purely linear. │ │ │ │ │ -1184 // │ │ │ │ │ -1185 bool isIncomplete = (level.getVertexTag(vert)._incomplete || (vEdges.size │ │ │ │ │ -() == 0)); │ │ │ │ │ -1186 if (isIncomplete || fvarChannel.isLinear()) { │ │ │ │ │ -1187 for (int i = 0; i < vValues.size(); ++i) { │ │ │ │ │ -1188 _V_t_r_:_:_I_n_d_e_x vValue = vValues[i]; │ │ │ │ │ -1189 │ │ │ │ │ -1190 dst[vValue].Clear(); │ │ │ │ │ -1191 dst[vValue].AddWithWeight(src[vValue], 1.0f); │ │ │ │ │ -1192 } │ │ │ │ │ -1193 continue; │ │ │ │ │ -1194 } │ │ │ │ │ -1195 │ │ │ │ │ -1196 bool fvarVertMatchesVertex = fvarChannel.valueTopologyMatches(vValues[0]); │ │ │ │ │ -1197 if (fvarVertMatchesVertex) { │ │ │ │ │ -1198 │ │ │ │ │ -1199 // Assign the mask weights to the common buffer and compute the mask: │ │ │ │ │ -1200 // │ │ │ │ │ -1201 Weight * vWeights = weightBuffer, │ │ │ │ │ -1202 * eWeights = vWeights + 1, │ │ │ │ │ -1203 * fWeights = eWeights + vEdges._s_i_z_e(); │ │ │ │ │ -1204 │ │ │ │ │ -1205 Mask vMask(vWeights, eWeights, fWeights); │ │ │ │ │ -1206 │ │ │ │ │ -1207 vHood.SetIndex(vert, vert); │ │ │ │ │ -1208 │ │ │ │ │ -1209 scheme.ComputeVertexLimitMask(vHood, vMask, level.getVertexRule(vert)); │ │ │ │ │ -1210 │ │ │ │ │ -1211 // │ │ │ │ │ -1212 // Apply mask to corresponding FVar values for neighboring vertices: │ │ │ │ │ -1213 // │ │ │ │ │ -1214 _V_t_r_:_:_I_n_d_e_x vValue = vValues[0]; │ │ │ │ │ -1215 │ │ │ │ │ -1216 dst[vValue].Clear(); │ │ │ │ │ -1217 if (vMask.GetNumFaceWeights() > 0) { │ │ │ │ │ -1218 assert(!vMask.AreFaceWeightsForFaceCenters()); │ │ │ │ │ -1219 │ │ │ │ │ -1220 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y vFaces = level.getVertexFaces(vert); │ │ │ │ │ -1221 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y vInFace = level.getVertexFaceLocalIndices(vert); │ │ │ │ │ -1222 │ │ │ │ │ -1223 for (int i = 0; i < vFaces.size(); ++i) { │ │ │ │ │ -1224 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y faceValues = fvarChannel.getFaceValues(vFaces[i]); │ │ │ │ │ -1225 _L_o_c_a_l_I_n_d_e_x vOppInFace = vInFace[i] + 2; │ │ │ │ │ -1226 if (vOppInFace >= faceValues.size()) vOppInFace -= faceValues._s_i_z_e(); │ │ │ │ │ -1227 │ │ │ │ │ -1228 _I_n_d_e_x vValueOppositeFace = faceValues[vOppInFace]; │ │ │ │ │ -1229 │ │ │ │ │ -1230 dst[vValue].AddWithWeight(src[vValueOppositeFace], fWeights[i]); │ │ │ │ │ -1231 } │ │ │ │ │ -1232 } │ │ │ │ │ -1233 if (vMask.GetNumEdgeWeights() > 0) { │ │ │ │ │ -1234 _I_n_d_e_x * vEdgeValues = vEdgeBuffer; │ │ │ │ │ -1235 fvarChannel.getVertexEdgeValues(vert, vEdgeValues); │ │ │ │ │ -1236 │ │ │ │ │ -1237 for (int i = 0; i < vEdges.size(); ++i) { │ │ │ │ │ -1238 dst[vValue].AddWithWeight(src[vEdgeValues[i]], eWeights[i]); │ │ │ │ │ -1239 } │ │ │ │ │ -1240 } │ │ │ │ │ -1241 dst[vValue].AddWithWeight(src[vValue], vWeights[0]); │ │ │ │ │ -1242 } else { │ │ │ │ │ -1243 // │ │ │ │ │ -1244 // Sibling FVar values associated with a vertex will be either a corner or │ │ │ │ │ -a crease: │ │ │ │ │ -1245 // │ │ │ │ │ -1246 for (int i = 0; i < vValues.size(); ++i) { │ │ │ │ │ -1247 _V_t_r_:_:_I_n_d_e_x vValue = vValues[i]; │ │ │ │ │ -1248 │ │ │ │ │ -1249 dst[vValue].Clear(); │ │ │ │ │ -1250 if (fvarChannel.getValueTag(vValue).isCorner()) { │ │ │ │ │ -1251 dst[vValue].AddWithWeight(src[vValue], 1.0f); │ │ │ │ │ -1252 } else { │ │ │ │ │ -1253 _I_n_d_e_x vEndValues[2]; │ │ │ │ │ -1254 fvarChannel.getVertexCreaseEndValues(vert, i, vEndValues); │ │ │ │ │ -1255 │ │ │ │ │ -1256 dst[vValue].AddWithWeight(src[vEndValues[0]], 1.0f/6.0f); │ │ │ │ │ -1257 dst[vValue].AddWithWeight(src[vEndValues[1]], 1.0f/6.0f); │ │ │ │ │ -1258 dst[vValue].AddWithWeight(src[vValue], 2.0f/3.0f); │ │ │ │ │ -1259 } │ │ │ │ │ -1260 } │ │ │ │ │ -1261 } │ │ │ │ │ -1262 } │ │ │ │ │ -1263} │ │ │ │ │ -1264 │ │ │ │ │ -_1_2_6_5class _P_r_i_m_v_a_r_R_e_f_i_n_e_r : public _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l { │ │ │ │ │ -1266public: │ │ │ │ │ -_1_2_6_7 _P_r_i_m_v_a_r_R_e_f_i_n_e_r(_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r const & refiner) │ │ │ │ │ -1268 : _P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l(refiner) { } │ │ │ │ │ -1269}; │ │ │ │ │ -1270 │ │ │ │ │ -1271} // end namespace Far │ │ │ │ │ -1272 │ │ │ │ │ -1273} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -1274using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -1275} // end namespace OpenSubdiv │ │ │ │ │ -1276 │ │ │ │ │ -1277#endif /* OPENSUBDIV3_FAR_PRIMVAR_REFINER_H */ │ │ │ │ │ +234 │ │ │ │ │ +235#endif /* OPENSUBDIV3_FAR_PATCH_TABLE_FACTORY_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_o_c_a_l_I_n_d_e_x │ │ │ │ │ -Vtr::LocalIndex LocalIndex │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_E_r_r_o_r │ │ │ │ │ -void Error(ErrorType err, const char *format,...) │ │ │ │ │ -Sends an OSD error with a message (internal use only) │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ Vtr::ConstIndexArray ConstIndexArray │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -Vtr::ConstLocalIndexArray ConstLocalIndexArray │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_F_A_R___R_U_N_T_I_M_E___E_R_R_O_R │ │ │ │ │ -@ FAR_RUNTIME_ERROR │ │ │ │ │ -Issue a generic runtime error, but continue execution. │ │ │ │ │ -DDeeffiinniittiioonn _e_r_r_o_r_._h_:_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_I_n_d_e_x │ │ │ │ │ -Vtr::Index Index │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x │ │ │ │ │ -int Index │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_5_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x_I_s_V_a_l_i_d │ │ │ │ │ -bool IndexIsValid(Index index) │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_5_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_C_H_E_M_E___B_I_L_I_N_E_A_R │ │ │ │ │ -@ SCHEME_BILINEAR │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_3_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_C_H_E_M_E___C_A_T_M_A_R_K │ │ │ │ │ -@ SCHEME_CATMARK │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_3_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_C_H_E_M_E___L_O_O_P │ │ │ │ │ -@ SCHEME_LOOP │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l │ │ │ │ │ -Applies refinement operations to generic primvar data. │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_L_i_m_i_t │ │ │ │ │ -void Limit(T const &src, U &dstPos) const │ │ │ │ │ -Apply limit weights to a primvar buffer. │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_3_1_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l │ │ │ │ │ -PrimvarRefinerReal(TopologyRefiner const &refiner) │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_5_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_L_i_m_i_t │ │ │ │ │ -void Limit(T const &src, U &dstPos, U1 &dstTan1, U2 &dstTan2) const │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_3_4_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_U_n_i_f_o_r_m │ │ │ │ │ -void InterpolateFaceUniform(int level, T const &src, U &dst) const │ │ │ │ │ -Refine uniform (per-face) primvar data between levels. │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_3_9_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_G_e_t_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ -TopologyRefiner const & GetTopologyRefiner() const │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_I_n_t_e_r_p_o_l_a_t_e_V_a_r_y_i_n_g │ │ │ │ │ -void InterpolateVarying(int level, T const &src, U &dst) const │ │ │ │ │ -Apply only varying interpolation weights to a primvar buffer for a single level │ │ │ │ │ -of refinement. │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_4_1_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_I_n_t_e_r_p_o_l_a_t_e │ │ │ │ │ -void Interpolate(int level, T const &src, U &dst) const │ │ │ │ │ -Apply vertex interpolation weights to a primvar buffer for a single level of │ │ │ │ │ -refinement. │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_2_6_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_I_n_t_e_r_p_o_l_a_t_e_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -void InterpolateFaceVarying(int level, T const &src, U &dst, int channel=0) │ │ │ │ │ -const │ │ │ │ │ -Apply face-varying interpolation weights to a primvar buffer associated with a │ │ │ │ │ -particular face-varyin... │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_2_9_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_~_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l │ │ │ │ │ -~PrimvarRefinerReal() │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_6_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_R_e_a_l_:_:_L_i_m_i_t_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -void LimitFaceVarying(T const &src, U &dst, int channel=0) const │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_3_6_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_1_2_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r_:_:_P_r_i_m_v_a_r_R_e_f_i_n_e_r │ │ │ │ │ -PrimvarRefiner(TopologyRefiner const &refiner) │ │ │ │ │ -DDeeffiinniittiioonn _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h_:_1_2_6_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +Container for arrays of parametric patches. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_._h_:_5_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y │ │ │ │ │ +Factory for constructing a PatchTable from a TopologyRefiner. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_T_a_g_V_e_c_t_o_r │ │ │ │ │ +std::vector< PatchFaceTag > PatchTagVector │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_C_r_e_a_t_e │ │ │ │ │ +static PatchTable * Create(TopologyRefiner const &refiner, Options │ │ │ │ │ +options=Options(), ConstIndexArray selectedFaces=ConstIndexArray()) │ │ │ │ │ +Instantiates a PatchTable from a client-provided TopologyRefiner. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s │ │ │ │ │ +Public options for the PatchTable factory. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_4_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_T_a_b_l_e_s │ │ │ │ │ +unsigned int generateVaryingTables │ │ │ │ │ +Generate varying patch tables. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_L_e_g_a_c_y_S_h_a_r_p_C_o_r_n_e_r_P_a_t_c_h_e_s │ │ │ │ │ +unsigned int generateLegacySharpCornerPatches │ │ │ │ │ +Generate sharp regular patches at smooth corners (legacy) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_s_h_a_r_e_E_n_d_C_a_p_P_a_t_c_h_P_o_i_n_t_s │ │ │ │ │ +unsigned int shareEndCapPatchPoints │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_G_e_t_R_e_f_i_n_e_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ +TopologyRefiner::AdaptiveOptions GetRefineAdaptiveOptions() const │ │ │ │ │ +Determine adaptive refinement options to match assigned patch options. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_m_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l │ │ │ │ │ +unsigned int maxIsolationLevel │ │ │ │ │ +Cap adaptive feature isolation to the given level (max. 10) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_G_e_t_E_n_d_C_a_p_T_y_p_e │ │ │ │ │ +EndCapType GetEndCapType() const │ │ │ │ │ +Get endcap basis type. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_8_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_F_V_a_r_L_e_g_a_c_y_L_i_n_e_a_r_P_a_t_c_h_e_s │ │ │ │ │ +unsigned int generateFVarLegacyLinearPatches │ │ │ │ │ +Generate all linear face-varying patches (legacy) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_S_e_t_P_a_t_c_h_P_r_e_c_i_s_i_o_n │ │ │ │ │ +void SetPatchPrecision() │ │ │ │ │ +Set precision of vertex patches. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_f_v_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e │ │ │ │ │ +unsigned int fvarPatchPrecisionDouble │ │ │ │ │ +Generate double-precision stencils for face-varying patches. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_S_e_t_M_a_x_I_s_o_l_a_t_i_o_n_L_e_v_e_l │ │ │ │ │ +void SetMaxIsolationLevel(unsigned int level) │ │ │ │ │ +Set maximum isolation level. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_9_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_e_n_d_C_a_p_T_y_p_e │ │ │ │ │ +unsigned int endCapType │ │ │ │ │ +EndCapType. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_f_v_a_r_C_h_a_n_n_e_l_I_n_d_i_c_e_s │ │ │ │ │ +int const * fvarChannelIndices │ │ │ │ │ +List containing the indices of the channels selected for the factory. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h │ │ │ │ │ +unsigned int useSingleCreasePatch │ │ │ │ │ +Use single crease patch. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h │ │ │ │ │ +unsigned int useInfSharpPatch │ │ │ │ │ +Use infinitely-sharp patch. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_S_e_t_E_n_d_C_a_p_T_y_p_e │ │ │ │ │ +void SetEndCapType(EndCapType e) │ │ │ │ │ +Set endcap basis type. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_8_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_V_a_r_y_i_n_g_L_o_c_a_l_P_o_i_n_t_s │ │ │ │ │ +unsigned int generateVaryingLocalPoints │ │ │ │ │ +Generate local points with varying patches. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_i_n_c_l_u_d_e_F_V_a_r_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s │ │ │ │ │ +unsigned int includeFVarBaseLevelIndices │ │ │ │ │ +Include base level in face-varying patch point indices (Uniform mode only) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_A_l_l_L_e_v_e_l_s │ │ │ │ │ +unsigned int generateAllLevels │ │ │ │ │ +Generate levels from 'firstLevel' to 'maxLevel' (Uniform mode only) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_p_a_t_c_h_P_r_e_c_i_s_i_o_n_D_o_u_b_l_e │ │ │ │ │ +unsigned int patchPrecisionDouble │ │ │ │ │ +Generate double-precision stencils for vertex patches. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_g_e_n_e_r_a_t_e_F_V_a_r_T_a_b_l_e_s │ │ │ │ │ +unsigned int generateFVarTables │ │ │ │ │ +Generate face-varying patch tables. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_2_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_i_n_c_l_u_d_e_B_a_s_e_L_e_v_e_l_I_n_d_i_c_e_s │ │ │ │ │ +unsigned int includeBaseLevelIndices │ │ │ │ │ +Include base level in patch point indices (Uniform mode only) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_S_e_t_F_V_a_r_P_a_t_c_h_P_r_e_c_i_s_i_o_n │ │ │ │ │ +void SetFVarPatchPrecision() │ │ │ │ │ +Set precision of face-varying patches. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_n_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ +int numFVarChannels │ │ │ │ │ +Number of channel indices and interpolation modes passed. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_3_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_t_r_i_a_n_g_u_l_a_t_e_Q_u_a_d_s │ │ │ │ │ +unsigned int triangulateQuads │ │ │ │ │ +Triangulate 'QUADS' primitives (Uniform mode only) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_1_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_E_n_d_C_a_p_T_y_p_e │ │ │ │ │ +EndCapType │ │ │ │ │ +Choice for approximating irregular patches (end-caps) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_E_N_D_C_A_P___L_E_G_A_C_Y___G_R_E_G_O_R_Y │ │ │ │ │ +@ ENDCAP_LEGACY_GREGORY │ │ │ │ │ +legacy option for 2.x style Gregory patches (Catmark only) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_6_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_E_N_D_C_A_P___G_R_E_G_O_R_Y___B_A_S_I_S │ │ │ │ │ +@ ENDCAP_GREGORY_BASIS │ │ │ │ │ +use Gregory patches (highest quality, recommended default) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_E_N_D_C_A_P___N_O_N_E │ │ │ │ │ +@ ENDCAP_NONE │ │ │ │ │ +unspecified │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_E_N_D_C_A_P___B_I_L_I_N_E_A_R___B_A_S_I_S │ │ │ │ │ +@ ENDCAP_BILINEAR_BASIS │ │ │ │ │ +use linear patches (simple quads or tris) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_E_N_D_C_A_P___B_S_P_L_I_N_E___B_A_S_I_S │ │ │ │ │ +@ ENDCAP_BSPLINE_BASIS │ │ │ │ │ +use BSpline-like patches (same patch type as regular) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_5_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_O_p_t_i_o_n_s_:_:_O_p_t_i_o_n_s │ │ │ │ │ +Options(unsigned int maxIsolation=10) │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_6_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g │ │ │ │ │ +Obsolete internal struct not intended for public use – due to be deprecated. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +___i_s_S_i_n_g_l_e_C_r_e_a_s_e │ │ │ │ │ +unsigned int _isSingleCrease │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +___i_s_R_e_g_u_l_a_r │ │ │ │ │ +unsigned int _isRegular │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +___b_o_u_n_d_a_r_y_I_n_d_e_x │ │ │ │ │ +unsigned int _boundaryIndex │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +_a_s_s_i_g_n_B_o_u_n_d_a_r_y_P_r_o_p_e_r_t_i_e_s_F_r_o_m_V_e_r_t_e_x_M_a_s_k │ │ │ │ │ +void assignBoundaryPropertiesFromVertexMask(int boundaryVertexMask) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +___t_r_a_n_s_i_t_i_o_n_M_a_s_k │ │ │ │ │ +unsigned int _transitionMask │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +___h_a_s_B_o_u_n_d_a_r_y_E_d_g_e │ │ │ │ │ +unsigned int _hasBoundaryEdge │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_2_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +___b_o_u_n_d_a_r_y_M_a_s_k │ │ │ │ │ +unsigned int _boundaryMask │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_:___h_a_s_P_a_t_c_h │ │ │ │ │ +unsigned int _hasPatch │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +_a_s_s_i_g_n_T_r_a_n_s_i_t_i_o_n_P_r_o_p_e_r_t_i_e_s_F_r_o_m_E_d_g_e_M_a_s_k │ │ │ │ │ +void assignTransitionPropertiesFromEdgeMask(int boundaryVertexMask) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_:_c_l_e_a_r │ │ │ │ │ +void clear() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +_a_s_s_i_g_n_B_o_u_n_d_a_r_y_P_r_o_p_e_r_t_i_e_s_F_r_o_m_E_d_g_e_M_a_s_k │ │ │ │ │ +void assignBoundaryPropertiesFromEdgeMask(int boundaryEdgeMask) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_:_:_P_a_t_c_h_F_a_c_e_T_a_g_:_: │ │ │ │ │ +___b_o_u_n_d_a_r_y_C_o_u_n_t │ │ │ │ │ +unsigned int _boundaryCount │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h_:_1_9_9 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r │ │ │ │ │ Stores topology data for a specified set of refinement options. │ │ │ │ │ DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ -Rule │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E │ │ │ │ │ -@ RULE_CREASE │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e │ │ │ │ │ -Scheme is a class template which provides all implementation for the │ │ │ │ │ -subdivision schemes supported by... │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s │ │ │ │ │ +Adaptive refinement options. │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_u_s_e_S_i_n_g_l_e_C_r_e_a_s_e_P_a_t_c_h │ │ │ │ │ +unsigned int useSingleCreasePatch │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_u_s_e_I_n_f_S_h_a_r_p_P_a_t_c_h │ │ │ │ │ +unsigned int useInfSharpPatch │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_T_o_p_o_l_o_g_y_R_e_f_i_n_e_r_:_:_A_d_a_p_t_i_v_e_O_p_t_i_o_n_s_:_: │ │ │ │ │ +_c_o_n_s_i_d_e_r_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ +unsigned int considerFVarChannels │ │ │ │ │ +DDeeffiinniittiioonn _t_o_p_o_l_o_g_y_R_e_f_i_n_e_r_._h_:_1_8_0 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y │ │ │ │ │ DDeeffiinniittiioonn _a_r_r_a_y_._h_:_5_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_A_r_r_a_y_:_:_s_i_z_e │ │ │ │ │ -size_type size() const │ │ │ │ │ -DDeeffiinniittiioonn _a_r_r_a_y_._h_:_7_2 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _f_a_r │ │ │ │ │ - * _p_r_i_m_v_a_r_R_e_f_i_n_e_r_._h │ │ │ │ │ + * _p_a_t_c_h_T_a_b_l_e_F_a_c_t_o_r_y_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00731.html │ │ │ │ @@ -96,16 +96,16 @@ │ │ │ │ Namespaces │ │ │ │
patchTable.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include "../far/patchDescriptor.h"
│ │ │ │ #include "../far/patchParam.h"
│ │ │ │ -#include "../far/stencilTable.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ +#include "../far/stencilTable.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │ #include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00731_source.html │ │ │ │ @@ -804,15 +804,15 @@ │ │ │ │
903
│ │ │ │
904} // end namespace OPENSUBDIV_VERSION
│ │ │ │
905using namespace OPENSUBDIV_VERSION;
│ │ │ │
906
│ │ │ │
907} // end namespace OpenSubdiv
│ │ │ │
908
│ │ │ │
909#endif /* OPENSUBDIV3_FAR_PATCH_TABLE */
│ │ │ │ - │ │ │ │ + │ │ │ │
Vtr::ConstIndexArray ConstIndexArray
Definition types.h:47
│ │ │ │
std::vector< PatchParam > PatchParamTable
Definition patchParam.h:243
│ │ │ │ │ │ │ │ │ │ │ │
Vtr::Array< PatchParam > PatchParamArray
Definition patchParam.h:245
│ │ │ │
std::vector< PatchArray > PatchArrayVector
Definition types.h:132
│ │ │ │ │ │ │ │ @@ -894,17 +894,17 @@ │ │ │ │
bool LocalPointStencilPrecisionMatchesType() const
Tests if the precision of the stencil table to compute local point vertex values matches the given fl...
│ │ │ │
StencilTableReal< REAL > const * GetLocalPointVaryingStencilTable() const
Returns the stencil table to compute local point varying values.
│ │ │ │
int GetNumLocalPointsFaceVarying(int channel=0) const
Returns the number of local face-varying points for channel.
│ │ │ │
Handle that can be used as unique patch identifier within PatchTable.
Definition patchTable.h:60
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ - │ │ │ │ + │ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Namespaces
│ │ │ │ -
sparseSelector.h File Reference
│ │ │ │ +
level.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ +#include "../sdc/types.h"
│ │ │ │ +#include "../sdc/crease.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │ #include "../vtr/types.h"
│ │ │ │ -#include "../vtr/refinement.h"
│ │ │ │ +#include <algorithm>
│ │ │ │ #include <vector>
│ │ │ │ +#include <cassert>
│ │ │ │ +#include <cstring>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  PatchTable
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -113,13 +118,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,22 +1,27 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -sparseSelector.h File Reference │ │ │ │ │ +level.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ +#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_c_r_e_a_s_e_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ #include "_._._/_v_t_r_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_r_e_f_i_n_e_m_e_n_t_._h" │ │ │ │ │ +#include │ │ │ │ │ #include │ │ │ │ │ +#include │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _v_t_r │ │ │ │ │ - * _s_p_a_r_s_e_S_e_l_e_c_t_o_r_._h │ │ │ │ │ + * _l_e_v_e_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00749_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/vtr/sparseSelector.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/vtr/level.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
sparseSelector.h
│ │ │ │ +
level.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2014 DreamWorks Animation LLC.
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -118,98 +118,882 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24#ifndef OPENSUBDIV3_VTR_SPARSE_SELECTOR_H
│ │ │ │ -
25#define OPENSUBDIV3_VTR_SPARSE_SELECTOR_H
│ │ │ │ +
24#ifndef OPENSUBDIV3_VTR_LEVEL_H
│ │ │ │ +
25#define OPENSUBDIV3_VTR_LEVEL_H
│ │ │ │
26
│ │ │ │
27#include "../version.h"
│ │ │ │
28
│ │ │ │ -
29#include "../vtr/types.h"
│ │ │ │ -
30#include "../vtr/refinement.h"
│ │ │ │ -
31
│ │ │ │ -
32#include <vector>
│ │ │ │ +
29#include "../sdc/types.h"
│ │ │ │ +
30#include "../sdc/crease.h"
│ │ │ │ +
31#include "../sdc/options.h"
│ │ │ │ +
32#include "../vtr/types.h"
│ │ │ │
33
│ │ │ │ -
34namespace OpenSubdiv {
│ │ │ │ -
35namespace OPENSUBDIV_VERSION {
│ │ │ │ -
36
│ │ │ │ -
37namespace Vtr {
│ │ │ │ -
38namespace internal {
│ │ │ │ +
34#include <algorithm>
│ │ │ │ +
35#include <vector>
│ │ │ │ +
36#include <cassert>
│ │ │ │ +
37#include <cstring>
│ │ │ │ +
38
│ │ │ │
39
│ │ │ │ -
40//
│ │ │ │ -
41// SparseSelector:
│ │ │ │ -
42// Class supporting "selection" of components in a Level for sparse Refinement.
│ │ │ │ -
43// The term "selection" here implies interest in the limit for that component, i.e.
│ │ │ │ -
44// the limit point for a selected vertex, the limit patch for a face, etc. So this
│ │ │ │ -
45// class is responsible for ensuring that all neighboring components required to
│ │ │ │ -
46// support the limit of those selected are included in the refinement.
│ │ │ │ -
47//
│ │ │ │ -
48// This class is associated with (and constructed given) a Refinement and its role
│ │ │ │ -
49// is to initialize that Refinement instance for eventual sparse refinement. So it
│ │ │ │ -
50// is a friend of and expected to modify the Refinement as part of the selection.
│ │ │ │ -
51// Given its simplicity and scope it may be worth nesting it in Vtr::Refinement.
│ │ │ │ +
40namespace OpenSubdiv {
│ │ │ │ +
41namespace OPENSUBDIV_VERSION {
│ │ │ │ +
42
│ │ │ │ +
43namespace Vtr {
│ │ │ │ +
44namespace internal {
│ │ │ │ +
45
│ │ │ │ +
46class Refinement;
│ │ │ │ +
47class TriRefinement;
│ │ │ │ +
48class QuadRefinement;
│ │ │ │ +
49class FVarRefinement;
│ │ │ │ +
50class FVarLevel;
│ │ │ │ +
51
│ │ │ │
52//
│ │ │ │ -
53// While all three component types -- vertices, edges and faces -- can be selected,
│ │ │ │ -
54// only selection of faces is currently used and actively supported as part of the
│ │ │ │ -
55// feature-adaptive refinement.
│ │ │ │ -
56//
│ │ │ │ -
57class SparseSelector {
│ │ │ │ -
58
│ │ │ │ -
59public:
│ │ │ │ -
60 SparseSelector(Refinement& refine) : _refine(&refine), _selected(false) { }
│ │ │ │ -
61 ~SparseSelector() { }
│ │ │ │ -
62
│ │ │ │ -
63 void setRefinement(Refinement& refine) { _refine = &refine; }
│ │ │ │ -
64 Refinement& getRefinement() const { return *_refine; }
│ │ │ │ -
65
│ │ │ │ -
66 bool isSelectionEmpty() const { return !_selected; }
│ │ │ │ -
67
│ │ │ │ -
68 //
│ │ │ │ -
69 // Methods for selecting (and marking) components for refinement. All component indices
│ │ │ │ -
70 // refer to components in the parent:
│ │ │ │ -
71 //
│ │ │ │ -
72 void selectVertex(Index pVertex);
│ │ │ │ -
73 void selectEdge( Index pEdge);
│ │ │ │ -
74 void selectFace( Index pFace);
│ │ │ │ -
75
│ │ │ │ -
76private:
│ │ │ │ -
77 SparseSelector() : _refine(0), _selected(false) { }
│ │ │ │ -
78
│ │ │ │ -
79 bool wasVertexSelected(Index pVertex) const { return _refine->getParentVertexSparseTag(pVertex)._selected; }
│ │ │ │ -
80 bool wasEdgeSelected( Index pEdge) const { return _refine->getParentEdgeSparseTag(pEdge)._selected; }
│ │ │ │ -
81 bool wasFaceSelected( Index pFace) const { return _refine->getParentFaceSparseTag(pFace)._selected; }
│ │ │ │ +
53// Level:
│ │ │ │ +
54// A refinement level includes a vectorized representation of the topology
│ │ │ │ +
55// for a particular subdivision level. The topology is "complete" in that any
│ │ │ │ +
56// level can be used as the base level of another subdivision hierarchy and can
│ │ │ │ +
57// be considered a complete mesh independent of its ancestors. It currently
│ │ │ │ +
58// does contain a "depth" member -- as some inferences can then be made about
│ │ │ │ +
59// the topology (i.e. all quads or all tris if not level 0).
│ │ │ │ +
60//
│ │ │ │ +
61// This class is intended for private use within the library. There are still
│ │ │ │ +
62// opportunities to specialize levels -- e.g. those supporting N-sided faces vs
│ │ │ │ +
63// those that are purely quads or tris -- so we prefer to insulate it from public
│ │ │ │ +
64// access.
│ │ │ │ +
65//
│ │ │ │ +
66// The representation of topology here is to store six topological relationships
│ │ │ │ +
67// in tables of integers. Each is stored in its own array(s) so the result is
│ │ │ │ +
68// a SOA representation of the topology. The six relations are:
│ │ │ │ +
69//
│ │ │ │ +
70// - face-verts: vertices incident/comprising a face
│ │ │ │ +
71// - face-edges: edges incident a face
│ │ │ │ +
72// - edge-verts: vertices incident/comprising an edge
│ │ │ │ +
73// - edge-faces: faces incident an edge
│ │ │ │ +
74// - vert-faces: faces incident a vertex
│ │ │ │ +
75// - vert-edges: edges incident a vertex
│ │ │ │ +
76//
│ │ │ │ +
77// There is some redundancy here but the intent is not that this be a minimal
│ │ │ │ +
78// representation, the intent is that it be amenable to refinement. Classes in
│ │ │ │ +
79// the Far layer essentially store 5 of these 6 in a permuted form -- we add
│ │ │ │ +
80// the face-edges here to simplify refinement.
│ │ │ │ +
81//
│ │ │ │
82
│ │ │ │ -
83 void markVertexSelected(Index pVertex) const { _refine->getParentVertexSparseTag(pVertex)._selected = true; }
│ │ │ │ -
84 void markEdgeSelected( Index pEdge) const { _refine->getParentEdgeSparseTag(pEdge)._selected = true; }
│ │ │ │ -
85 void markFaceSelected( Index pFace) const { _refine->getParentFaceSparseTag(pFace)._selected = true; }
│ │ │ │ -
86
│ │ │ │ -
87 void initializeSelection();
│ │ │ │ -
88
│ │ │ │ -
89private:
│ │ │ │ -
90 Refinement* _refine;
│ │ │ │ -
91 bool _selected;
│ │ │ │ -
92};
│ │ │ │ -
93
│ │ │ │ -
94} // end namespace internal
│ │ │ │ -
95} // end namespace Vtr
│ │ │ │ -
96
│ │ │ │ -
97} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
98using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
99} // end namespace OpenSubdiv
│ │ │ │ -
100
│ │ │ │ -
101#endif /* OPENSUBDIV3_VTR_SPARSE_SELECTOR_H */
│ │ │ │ - │ │ │ │ +
83class Level {
│ │ │ │ +
84
│ │ │ │ +
85public:
│ │ │ │ +
86 //
│ │ │ │ +
87 // Simple nested types to hold the tags for each component type -- some of
│ │ │ │ +
88 // which are user-specified features (e.g. whether a face is a hole or not)
│ │ │ │ +
89 // while others indicate the topological nature of the component, how it
│ │ │ │ +
90 // is affected by creasing in its neighborhood, etc.
│ │ │ │ +
91 //
│ │ │ │ +
92 // Most of these properties are passed down to child components during
│ │ │ │ +
93 // refinement, but some -- notably the designation of a component as semi-
│ │ │ │ +
94 // sharp -- require re-determination as sharpness values are reduced at each
│ │ │ │ +
95 // level.
│ │ │ │ +
96 //
│ │ │ │ +
97 struct VTag {
│ │ │ │ +
98 VTag() { }
│ │ │ │ +
99
│ │ │ │ +
100 // When cleared, the VTag ALMOST represents a smooth, regular, interior
│ │ │ │ +
101 // vertex -- the Type enum requires a bit be explicitly set for Smooth,
│ │ │ │ +
102 // so that must be done explicitly if desired on initialization.
│ │ │ │ +
103 void clear() { std::memset((void*) this, 0, sizeof(VTag)); }
│ │ │ │ +
104
│ │ │ │ +
105 typedef unsigned short VTagSize;
│ │ │ │ +
106
│ │ │ │ +
107 VTagSize _nonManifold : 1; // fixed
│ │ │ │ +
108 VTagSize _xordinary : 1; // fixed
│ │ │ │ +
109 VTagSize _boundary : 1; // fixed
│ │ │ │ +
110 VTagSize _corner : 1; // fixed
│ │ │ │ +
111 VTagSize _infSharp : 1; // fixed
│ │ │ │ +
112 VTagSize _semiSharp : 1; // variable
│ │ │ │ +
113 VTagSize _semiSharpEdges : 1; // variable
│ │ │ │ +
114 VTagSize _rule : 4; // variable when _semiSharp
│ │ │ │ +
115
│ │ │ │ +
116 // These next to tags are complementary -- the "incomplete" tag is only
│ │ │ │ +
117 // relevant for refined levels while the "incident an irregular face" tag
│ │ │ │ +
118 // is only relevant for the base level. They could be combined as both
│ │ │ │ +
119 // indicate "no full regular ring" around a vertex
│ │ │ │ +
120 VTagSize _incomplete : 1; // variable only set in refined levels
│ │ │ │ +
121 VTagSize _incidIrregFace : 1; // variable only set in base level
│ │ │ │ +
122
│ │ │ │ +
123 // Tags indicating incident infinitely-sharp (permanent) features
│ │ │ │ +
124 VTagSize _infSharpEdges : 1; // fixed
│ │ │ │ +
125 VTagSize _infSharpCrease : 1; // fixed
│ │ │ │ +
126 VTagSize _infIrregular : 1; // fixed
│ │ │ │ +
127
│ │ │ │ +
128 // Alternate constructor and accessor for dealing with integer bits directly:
│ │ │ │ +
129 explicit VTag(VTagSize bits) {
│ │ │ │ +
130 std::memcpy(this, &bits, sizeof(bits));
│ │ │ │ +
131 }
│ │ │ │ +
132 VTagSize getBits() const {
│ │ │ │ +
133 VTagSize bits;
│ │ │ │ +
134 std::memcpy(&bits, this, sizeof(bits));
│ │ │ │ +
135 return bits;
│ │ │ │ +
136 }
│ │ │ │ +
137
│ │ │ │ +
138 static VTag BitwiseOr(VTag const vTags[], int size = 4);
│ │ │ │ +
139 };
│ │ │ │ +
140 struct ETag {
│ │ │ │ +
141 ETag() { }
│ │ │ │ +
142
│ │ │ │ +
143 // When cleared, the ETag represents a smooth, manifold, interior edge
│ │ │ │ +
144 void clear() { std::memset((void*) this, 0, sizeof(ETag)); }
│ │ │ │ +
145
│ │ │ │ +
146 typedef unsigned char ETagSize;
│ │ │ │ +
147
│ │ │ │ +
148 ETagSize _nonManifold : 1; // fixed
│ │ │ │ +
149 ETagSize _boundary : 1; // fixed
│ │ │ │ +
150 ETagSize _infSharp : 1; // fixed
│ │ │ │ +
151 ETagSize _semiSharp : 1; // variable
│ │ │ │ +
152
│ │ │ │ +
153 // Alternate constructor and accessor for dealing with integer bits directly:
│ │ │ │ +
154 explicit ETag(ETagSize bits) {
│ │ │ │ +
155 std::memcpy(this, &bits, sizeof(bits));
│ │ │ │ +
156 }
│ │ │ │ +
157 ETagSize getBits() const {
│ │ │ │ +
158 ETagSize bits;
│ │ │ │ +
159 std::memcpy(&bits, this, sizeof(bits));
│ │ │ │ +
160 return bits;
│ │ │ │ +
161 }
│ │ │ │ +
162
│ │ │ │ +
163 static ETag BitwiseOr(ETag const eTags[], int size = 4);
│ │ │ │ +
164 };
│ │ │ │ +
165 struct FTag {
│ │ │ │ +
166 FTag() { }
│ │ │ │ +
167
│ │ │ │ +
168 void clear() { std::memset((void*) this, 0, sizeof(FTag)); }
│ │ │ │ +
169
│ │ │ │ +
170 typedef unsigned char FTagSize;
│ │ │ │ +
171
│ │ │ │ +
172 FTagSize _hole : 1; // fixed
│ │ │ │ +
173
│ │ │ │ +
174 // On deck -- coming soon...
│ │ │ │ +
175 //FTagSize _hasEdits : 1; // variable
│ │ │ │ +
176 };
│ │ │ │ +
177
│ │ │ │ +
178 // Additional simple struct to identify a "span" around a vertex, i.e. a
│ │ │ │ +
179 // subset of the faces around a vertex delimited by some property (e.g. a
│ │ │ │ +
180 // face-varying discontinuity, an inf-sharp edge, etc.)
│ │ │ │ +
181 //
│ │ │ │ +
182 // The span requires an "origin" and a "size" to fully define its extent.
│ │ │ │ +
183 // Use of the size is required over a leading/trailing pair as the valence
│ │ │ │ +
184 // around a non-manifold vertex cannot be trivially determined from two
│ │ │ │ +
185 // extremeties. Similarly a start face is chosen over an edge as starting
│ │ │ │ +
186 // with a manifold edge is ambiguous. Additional tags also support
│ │ │ │ +
187 // non-manifold cases, e.g. periodic spans at the apex of a double cone.
│ │ │ │ +
188 //
│ │ │ │ +
189 // Currently setting the size to 0 or leaving the span "unassigned" is an
│ │ │ │ +
190 // indication to use the full neighborhood rather than a subset -- prefer
│ │ │ │ +
191 // use of the const method here to direct inspection of the member.
│ │ │ │ +
192 //
│ │ │ │ +
193 struct VSpan {
│ │ │ │ +
194 VSpan() { std::memset((void*) this, 0, sizeof(VSpan)); }
│ │ │ │ +
195
│ │ │ │ +
196 void clear() { std::memset((void*) this, 0, sizeof(VSpan)); }
│ │ │ │ +
197 bool isAssigned() const { return _numFaces > 0; }
│ │ │ │ +
198
│ │ │ │ +
199 LocalIndex _numFaces;
│ │ │ │ +
200 LocalIndex _startFace;
│ │ │ │ +
201 LocalIndex _cornerInSpan;
│ │ │ │ +
202
│ │ │ │ +
203 unsigned short _periodic : 1;
│ │ │ │ +
204 unsigned short _sharp : 1;
│ │ │ │ +
205 };
│ │ │ │ +
206
│ │ │ │ +
207public:
│ │ │ │ +
208 Level();
│ │ │ │ +
209 ~Level();
│ │ │ │ +
210
│ │ │ │ +
211 // Simple accessors:
│ │ │ │ +
212 int getDepth() const { return _depth; }
│ │ │ │ +
213
│ │ │ │ +
214 int getNumVertices() const { return _vertCount; }
│ │ │ │ +
215 int getNumFaces() const { return _faceCount; }
│ │ │ │ +
216 int getNumEdges() const { return _edgeCount; }
│ │ │ │ +
217
│ │ │ │ +
218 // More global sizes may prove useful...
│ │ │ │ +
219 int getNumFaceVerticesTotal() const { return (int) _faceVertIndices.size(); }
│ │ │ │ +
220 int getNumFaceEdgesTotal() const { return (int) _faceEdgeIndices.size(); }
│ │ │ │ +
221 int getNumEdgeVerticesTotal() const { return (int) _edgeVertIndices.size(); }
│ │ │ │ +
222 int getNumEdgeFacesTotal() const { return (int) _edgeFaceIndices.size(); }
│ │ │ │ +
223 int getNumVertexFacesTotal() const { return (int) _vertFaceIndices.size(); }
│ │ │ │ +
224 int getNumVertexEdgesTotal() const { return (int) _vertEdgeIndices.size(); }
│ │ │ │ +
225
│ │ │ │ +
226 int getMaxValence() const { return _maxValence; }
│ │ │ │ +
227 int getMaxEdgeFaces() const { return _maxEdgeFaces; }
│ │ │ │ +
228
│ │ │ │ +
229 // Methods to access the relation tables/indices -- note that for some relations
│ │ │ │ +
230 // (i.e. those where a component is "contained by" a neighbor, or more generally
│ │ │ │ +
231 // when the neighbor is a simplex of higher dimension) we store an additional
│ │ │ │ +
232 // "local index", e.g. for the case of vert-faces if one of the faces F[i] is
│ │ │ │ +
233 // incident a vertex V, then L[i] is the "local index" in F[i] of vertex V.
│ │ │ │ +
234 // Once have only quads (or tris), this local index need only occupy two bits
│ │ │ │ +
235 // and could conceivably be packed into the same integer as the face index, but
│ │ │ │ +
236 // for now, given the need to support faces of potentially high valence we'll
│ │ │ │ +
237 // use an 8- or 16-bit integer.
│ │ │ │ +
238 //
│ │ │ │ +
239 // Methods to access the six topological relations:
│ │ │ │ +
240 ConstIndexArray getFaceVertices(Index faceIndex) const;
│ │ │ │ +
241 ConstIndexArray getFaceEdges(Index faceIndex) const;
│ │ │ │ +
242 ConstIndexArray getEdgeVertices(Index edgeIndex) const;
│ │ │ │ +
243 ConstIndexArray getEdgeFaces(Index edgeIndex) const;
│ │ │ │ +
244 ConstIndexArray getVertexFaces(Index vertIndex) const;
│ │ │ │ +
245 ConstIndexArray getVertexEdges(Index vertIndex) const;
│ │ │ │ +
246
│ │ │ │ +
247 ConstLocalIndexArray getEdgeFaceLocalIndices(Index edgeIndex) const;
│ │ │ │ +
248 ConstLocalIndexArray getVertexFaceLocalIndices(Index vertIndex) const;
│ │ │ │ +
249 ConstLocalIndexArray getVertexEdgeLocalIndices(Index vertIndex) const;
│ │ │ │ +
250
│ │ │ │ +
251 // Replace these with access to sharpness buffers/arrays rather than elements:
│ │ │ │ +
252 float getEdgeSharpness(Index edgeIndex) const;
│ │ │ │ +
253 float getVertexSharpness(Index vertIndex) const;
│ │ │ │ +
254 Sdc::Crease::Rule getVertexRule(Index vertIndex) const;
│ │ │ │ +
255
│ │ │ │ +
256 Index findEdge(Index v0Index, Index v1Index) const;
│ │ │ │ +
257
│ │ │ │ +
258 // Holes
│ │ │ │ +
259 void setFaceHole(Index faceIndex, bool b);
│ │ │ │ +
260 bool isFaceHole(Index faceIndex) const;
│ │ │ │ +
261
│ │ │ │ +
262 // Face-varying
│ │ │ │ +
263 Sdc::Options getFVarOptions(int channel) const;
│ │ │ │ +
264 int getNumFVarChannels() const { return (int) _fvarChannels.size(); }
│ │ │ │ +
265 int getNumFVarValues(int channel) const;
│ │ │ │ +
266 ConstIndexArray getFaceFVarValues(Index faceIndex, int channel) const;
│ │ │ │ +
267
│ │ │ │ +
268 FVarLevel & getFVarLevel(int channel) { return *_fvarChannels[channel]; }
│ │ │ │ +
269 FVarLevel const & getFVarLevel(int channel) const { return *_fvarChannels[channel]; }
│ │ │ │ +
270
│ │ │ │ +
271 // Manifold/non-manifold tags:
│ │ │ │ +
272 void setEdgeNonManifold(Index edgeIndex, bool b);
│ │ │ │ +
273 bool isEdgeNonManifold(Index edgeIndex) const;
│ │ │ │ +
274
│ │ │ │ +
275 void setVertexNonManifold(Index vertIndex, bool b);
│ │ │ │ +
276 bool isVertexNonManifold(Index vertIndex) const;
│ │ │ │ +
277
│ │ │ │ +
278 // General access to all component tags:
│ │ │ │ +
279 VTag const & getVertexTag(Index vertIndex) const { return _vertTags[vertIndex]; }
│ │ │ │ +
280 ETag const & getEdgeTag(Index edgeIndex) const { return _edgeTags[edgeIndex]; }
│ │ │ │ +
281 FTag const & getFaceTag(Index faceIndex) const { return _faceTags[faceIndex]; }
│ │ │ │ +
282
│ │ │ │ +
283 VTag & getVertexTag(Index vertIndex) { return _vertTags[vertIndex]; }
│ │ │ │ +
284 ETag & getEdgeTag(Index edgeIndex) { return _edgeTags[edgeIndex]; }
│ │ │ │ +
285 FTag & getFaceTag(Index faceIndex) { return _faceTags[faceIndex]; }
│ │ │ │ +
286
│ │ │ │ +
287public:
│ │ │ │ +
288
│ │ │ │ +
289 // Debugging aides:
│ │ │ │ +
290 enum TopologyError {
│ │ │ │ +
291 TOPOLOGY_MISSING_EDGE_FACES=0,
│ │ │ │ +
292 TOPOLOGY_MISSING_EDGE_VERTS,
│ │ │ │ +
293 TOPOLOGY_MISSING_FACE_EDGES,
│ │ │ │ +
294 TOPOLOGY_MISSING_FACE_VERTS,
│ │ │ │ +
295 TOPOLOGY_MISSING_VERT_FACES,
│ │ │ │ +
296 TOPOLOGY_MISSING_VERT_EDGES,
│ │ │ │ +
297
│ │ │ │ +
298 TOPOLOGY_FAILED_CORRELATION_EDGE_FACE,
│ │ │ │ +
299 TOPOLOGY_FAILED_CORRELATION_FACE_VERT,
│ │ │ │ +
300 TOPOLOGY_FAILED_CORRELATION_FACE_EDGE,
│ │ │ │ +
301
│ │ │ │ +
302 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_EDGE,
│ │ │ │ +
303 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_FACE,
│ │ │ │ +
304 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_FACES_EDGES,
│ │ │ │ +
305
│ │ │ │ +
306 TOPOLOGY_DEGENERATE_EDGE,
│ │ │ │ +
307 TOPOLOGY_NON_MANIFOLD_EDGE,
│ │ │ │ +
308
│ │ │ │ +
309 TOPOLOGY_INVALID_CREASE_EDGE,
│ │ │ │ +
310 TOPOLOGY_INVALID_CREASE_VERT
│ │ │ │ +
311 };
│ │ │ │ +
312
│ │ │ │ +
313 static char const * getTopologyErrorString(TopologyError errCode);
│ │ │ │ +
314
│ │ │ │ +
315 typedef void (* ValidationCallback)(TopologyError errCode, char const * msg, void const * clientData);
│ │ │ │ +
316
│ │ │ │ +
317 bool validateTopology(ValidationCallback callback=0, void const * clientData=0) const;
│ │ │ │ +
318
│ │ │ │ +
319 void print(const Refinement* parentRefinement = 0) const;
│ │ │ │ +
320
│ │ │ │ +
321public:
│ │ │ │ +
322 // High-level topology queries -- these may be moved elsewhere:
│ │ │ │ +
323
│ │ │ │ +
324 bool isSingleCreasePatch(Index face, float* sharpnessOut=NULL, int* rotationOut=NULL) const;
│ │ │ │ +
325
│ │ │ │ +
326 //
│ │ │ │ +
327 // When inspecting topology, the component tags -- particularly VTag and ETag -- are most
│ │ │ │ +
328 // often inspected in groups for the face to which they belong. They are designed to be
│ │ │ │ +
329 // bitwise OR'd (the result then referred to as a "composite" tag) to make quick decisions
│ │ │ │ +
330 // about the face as a whole to avoid tedious topological inspection.
│ │ │ │ +
331 //
│ │ │ │ +
332 // The same logic can be applied to topology in a FVar channel when tags specific to that
│ │ │ │ +
333 // channel are used. Note that the VTags apply to the FVar values assigned to the corners
│ │ │ │ +
334 // of the face and not the vertex as a whole. The "composite" face-varying VTag for a
│ │ │ │ +
335 // vertex is the union of VTags of all distinct FVar values for that vertex.
│ │ │ │ +
336 //
│ │ │ │ +
337 bool doesVertexFVarTopologyMatch(Index vIndex, int fvarChannel) const;
│ │ │ │ +
338 bool doesFaceFVarTopologyMatch( Index fIndex, int fvarChannel) const;
│ │ │ │ +
339 bool doesEdgeFVarTopologyMatch( Index eIndex, int fvarChannel) const;
│ │ │ │ +
340
│ │ │ │ +
341 void getFaceVTags(Index fIndex, VTag vTags[], int fvarChannel = -1) const;
│ │ │ │ +
342 void getFaceETags(Index fIndex, ETag eTags[], int fvarChannel = -1) const;
│ │ │ │ +
343
│ │ │ │ +
344 VTag getFaceCompositeVTag(Index fIndex, int fvarChannel = -1) const;
│ │ │ │ +
345 VTag getFaceCompositeVTag(ConstIndexArray & fVerts) const;
│ │ │ │ +
346
│ │ │ │ +
347 VTag getVertexCompositeFVarVTag(Index vIndex, int fvarChannel) const;
│ │ │ │ +
348
│ │ │ │ +
349 //
│ │ │ │ +
350 // When gathering "patch points" we may want the indices of the vertices or the corresponding
│ │ │ │ +
351 // FVar values for a particular channel. Both are represented and equally accessible within
│ │ │ │ +
352 // the faces, so we allow all to be returned through these methods. Setting the optional FVar
│ │ │ │ +
353 // channel to -1 will retrieve indices of vertices instead of FVar values:
│ │ │ │ +
354 //
│ │ │ │ +
355 int gatherQuadLinearPatchPoints(Index fIndex, Index patchPoints[], int rotation = 0,
│ │ │ │ +
356 int fvarChannel = -1) const;
│ │ │ │ +
357
│ │ │ │ +
358 int gatherQuadRegularInteriorPatchPoints(Index fIndex, Index patchPoints[], int rotation = 0,
│ │ │ │ +
359 int fvarChannel = -1) const;
│ │ │ │ +
360 int gatherQuadRegularBoundaryPatchPoints(Index fIndex, Index patchPoints[], int boundaryEdgeInFace,
│ │ │ │ +
361 int fvarChannel = -1) const;
│ │ │ │ +
362 int gatherQuadRegularCornerPatchPoints( Index fIndex, Index patchPoints[], int cornerVertInFace,
│ │ │ │ +
363 int fvarChannel = -1) const;
│ │ │ │ +
364
│ │ │ │ +
365 int gatherQuadRegularRingAroundVertex(Index vIndex, Index ringPoints[],
│ │ │ │ +
366 int fvarChannel = -1) const;
│ │ │ │ +
367 int gatherQuadRegularPartialRingAroundVertex(Index vIndex, VSpan const & span, Index ringPoints[],
│ │ │ │ +
368 int fvarChannel = -1) const;
│ │ │ │ +
369
│ │ │ │ +
370 // WIP -- for future use, need to extend for face-varying...
│ │ │ │ +
371 int gatherTriRegularInteriorPatchPoints( Index fIndex, Index patchVerts[], int rotation = 0) const;
│ │ │ │ +
372 int gatherTriRegularBoundaryVertexPatchPoints(Index fIndex, Index patchVerts[], int boundaryVertInFace) const;
│ │ │ │ +
373 int gatherTriRegularBoundaryEdgePatchPoints( Index fIndex, Index patchVerts[], int boundaryEdgeInFace) const;
│ │ │ │ +
374 int gatherTriRegularCornerVertexPatchPoints( Index fIndex, Index patchVerts[], int cornerVertInFace) const;
│ │ │ │ +
375 int gatherTriRegularCornerEdgePatchPoints( Index fIndex, Index patchVerts[], int cornerEdgeInFace) const;
│ │ │ │ +
376
│ │ │ │ +
377public:
│ │ │ │ +
378 // Sizing methods used to construct a level to populate:
│ │ │ │ +
379 void resizeFaces( int numFaces);
│ │ │ │ +
380 void resizeFaceVertices(int numFaceVertsTotal);
│ │ │ │ +
381 void resizeFaceEdges( int numFaceEdgesTotal);
│ │ │ │ +
382
│ │ │ │ +
383 void resizeEdges( int numEdges);
│ │ │ │ +
384 void resizeEdgeVertices(); // always 2*edgeCount
│ │ │ │ +
385 void resizeEdgeFaces(int numEdgeFacesTotal);
│ │ │ │ +
386
│ │ │ │ +
387 void resizeVertices( int numVertices);
│ │ │ │ +
388 void resizeVertexFaces(int numVertexFacesTotal);
│ │ │ │ +
389 void resizeVertexEdges(int numVertexEdgesTotal);
│ │ │ │ +
390
│ │ │ │ +
391 void setMaxValence(int maxValence);
│ │ │ │ +
392
│ │ │ │ +
393 // Modifiers to populate the relations for each component:
│ │ │ │ +
394 IndexArray getFaceVertices(Index faceIndex);
│ │ │ │ +
395 IndexArray getFaceEdges(Index faceIndex);
│ │ │ │ +
396 IndexArray getEdgeVertices(Index edgeIndex);
│ │ │ │ +
397 IndexArray getEdgeFaces(Index edgeIndex);
│ │ │ │ +
398 IndexArray getVertexFaces(Index vertIndex);
│ │ │ │ +
399 IndexArray getVertexEdges(Index vertIndex);
│ │ │ │ +
400
│ │ │ │ +
401 LocalIndexArray getEdgeFaceLocalIndices(Index edgeIndex);
│ │ │ │ +
402 LocalIndexArray getVertexFaceLocalIndices(Index vertIndex);
│ │ │ │ +
403 LocalIndexArray getVertexEdgeLocalIndices(Index vertIndex);
│ │ │ │ +
404
│ │ │ │ +
405 // Replace these with access to sharpness buffers/arrays rather than elements:
│ │ │ │ +
406 float& getEdgeSharpness(Index edgeIndex);
│ │ │ │ +
407 float& getVertexSharpness(Index vertIndex);
│ │ │ │ +
408
│ │ │ │ +
409 // Create, destroy and populate face-varying channels:
│ │ │ │ +
410 int createFVarChannel(int fvarValueCount, Sdc::Options const& options);
│ │ │ │ +
411 void destroyFVarChannel(int channel);
│ │ │ │ +
412
│ │ │ │ +
413 IndexArray getFaceFVarValues(Index faceIndex, int channel);
│ │ │ │ +
414
│ │ │ │ +
415 void completeFVarChannelTopology(int channel, int regBoundaryValence);
│ │ │ │ +
416
│ │ │ │ +
417 // Counts and offsets for all relation types:
│ │ │ │ +
418 // - these may be unwarranted if we let Refinement access members directly...
│ │ │ │ +
419 int getNumFaceVertices( Index faceIndex) const { return _faceVertCountsAndOffsets[2*faceIndex]; }
│ │ │ │ +
420 int getOffsetOfFaceVertices(Index faceIndex) const { return _faceVertCountsAndOffsets[2*faceIndex + 1]; }
│ │ │ │ +
421
│ │ │ │ +
422 int getNumFaceEdges( Index faceIndex) const { return getNumFaceVertices(faceIndex); }
│ │ │ │ +
423 int getOffsetOfFaceEdges(Index faceIndex) const { return getOffsetOfFaceVertices(faceIndex); }
│ │ │ │ +
424
│ │ │ │ +
425 int getNumEdgeVertices( Index ) const { return 2; }
│ │ │ │ +
426 int getOffsetOfEdgeVertices(Index edgeIndex) const { return 2 * edgeIndex; }
│ │ │ │ +
427
│ │ │ │ +
428 int getNumEdgeFaces( Index edgeIndex) const { return _edgeFaceCountsAndOffsets[2*edgeIndex]; }
│ │ │ │ +
429 int getOffsetOfEdgeFaces(Index edgeIndex) const { return _edgeFaceCountsAndOffsets[2*edgeIndex + 1]; }
│ │ │ │ +
430
│ │ │ │ +
431 int getNumVertexFaces( Index vertIndex) const { return _vertFaceCountsAndOffsets[2*vertIndex]; }
│ │ │ │ +
432 int getOffsetOfVertexFaces(Index vertIndex) const { return _vertFaceCountsAndOffsets[2*vertIndex + 1]; }
│ │ │ │ +
433
│ │ │ │ +
434 int getNumVertexEdges( Index vertIndex) const { return _vertEdgeCountsAndOffsets[2*vertIndex]; }
│ │ │ │ +
435 int getOffsetOfVertexEdges(Index vertIndex) const { return _vertEdgeCountsAndOffsets[2*vertIndex + 1]; }
│ │ │ │ +
436
│ │ │ │ +
437 ConstIndexArray getFaceVertices() const;
│ │ │ │ +
438
│ │ │ │ +
439 //
│ │ │ │ +
440 // Note that for some relations, the size of the relations for a child component
│ │ │ │ +
441 // can vary radically from its parent due to the sparsity of the refinement. So
│ │ │ │ +
442 // in these cases a few additional utilities are provided to help define the set
│ │ │ │ +
443 // of incident components. Assuming adequate memory has been allocated, the
│ │ │ │ +
444 // "resize" methods here initialize the set of incident components by setting
│ │ │ │ +
445 // both the size and the appropriate offset, while "trim" is use to quickly lower
│ │ │ │ +
446 // the size from an upper bound and nothing else.
│ │ │ │ +
447 //
│ │ │ │ +
448 void resizeFaceVertices(Index FaceIndex, int count);
│ │ │ │ +
449
│ │ │ │ +
450 void resizeEdgeFaces(Index edgeIndex, int count);
│ │ │ │ +
451 void trimEdgeFaces( Index edgeIndex, int count);
│ │ │ │ +
452
│ │ │ │ +
453 void resizeVertexFaces(Index vertIndex, int count);
│ │ │ │ +
454 void trimVertexFaces( Index vertIndex, int count);
│ │ │ │ +
455
│ │ │ │ +
456 void resizeVertexEdges(Index vertIndex, int count);
│ │ │ │ +
457 void trimVertexEdges( Index vertIndex, int count);
│ │ │ │ +
458
│ │ │ │ +
459public:
│ │ │ │ +
460 //
│ │ │ │ +
461 // Initial plans were to have a few specific classes properly construct the
│ │ │ │ +
462 // topology from scratch, e.g. the Refinement class and a Factory class for
│ │ │ │ +
463 // the base level, by populating all topological relations. The need to have
│ │ │ │ +
464 // a class construct full topology given only a simple face-vertex list, made
│ │ │ │ +
465 // it necessary to write code to define and orient all relations -- and most
│ │ │ │ +
466 // of that seemed best placed here.
│ │ │ │ +
467 //
│ │ │ │ +
468 bool completeTopologyFromFaceVertices();
│ │ │ │ +
469 Index findEdge(Index v0, Index v1, ConstIndexArray v0Edges) const;
│ │ │ │ +
470
│ │ │ │ +
471 // Methods supporting the above:
│ │ │ │ +
472 void orientIncidentComponents();
│ │ │ │ +
473 bool orderVertexFacesAndEdges(Index vIndex, Index* vFaces, Index* vEdges) const;
│ │ │ │ +
474 bool orderVertexFacesAndEdges(Index vIndex);
│ │ │ │ +
475 void populateLocalIndices();
│ │ │ │ +
476
│ │ │ │ +
477 IndexArray shareFaceVertCountsAndOffsets() const;
│ │ │ │ +
478
│ │ │ │ +
479private:
│ │ │ │ +
480 // Refinement classes (including all subclasses) build a Level:
│ │ │ │ +
481 friend class Refinement;
│ │ │ │ +
482 friend class TriRefinement;
│ │ │ │ +
483 friend class QuadRefinement;
│ │ │ │ +
484
│ │ │ │ +
485 //
│ │ │ │ +
486 // A Level is independent of subdivision scheme or options. While it may have been
│ │ │ │ +
487 // affected by them in its construction, they are not associated with it -- a Level
│ │ │ │ +
488 // is pure topology and any subdivision parameters are external.
│ │ │ │ +
489 //
│ │ │ │ +
490
│ │ │ │ +
491 // Simple members for inventory, etc.
│ │ │ │ +
492 int _faceCount;
│ │ │ │ +
493 int _edgeCount;
│ │ │ │ +
494 int _vertCount;
│ │ │ │ +
495
│ │ │ │ +
496 // The "depth" member is clearly useful in both the topological splitting and the
│ │ │ │ +
497 // stencil queries, but arguably it ties the Level to a hierarchy which counters
│ │ │ │ +
498 // the idea of it being independent.
│ │ │ │ +
499 int _depth;
│ │ │ │ +
500
│ │ │ │ +
501 // Maxima to help clients manage sizing of data buffers. Given "max valence",
│ │ │ │ +
502 // the "max edge faces" is strictly redundant as it will always be less, but
│ │ │ │ +
503 // since it will typically be so much less (i.e. 2) it is kept for now.
│ │ │ │ +
504 int _maxEdgeFaces;
│ │ │ │ +
505 int _maxValence;
│ │ │ │ +
506
│ │ │ │ +
507 //
│ │ │ │ +
508 // Topology vectors:
│ │ │ │ +
509 // Note that of all of these, only data for the face-edge relation is not
│ │ │ │ +
510 // stored in the osd::FarTables in any form. The FarTable vectors combine
│ │ │ │ +
511 // the edge-vert and edge-face relations. The eventual goal is that this
│ │ │ │ +
512 // data be part of the osd::Far classes and be a superset of the FarTable
│ │ │ │ +
513 // vectors, i.e. no data duplication or conversion. The fact that FarTable
│ │ │ │ +
514 // already stores 5 of the 6 possible relations should make the topology
│ │ │ │ +
515 // storage as a whole a non-issue.
│ │ │ │ +
516 //
│ │ │ │ +
517 // The vert-face-child and vert-edge-child indices are also arguably not
│ │ │ │ +
518 // a topology relation but more one for parent/child relations. But it is
│ │ │ │ +
519 // a topological relationship, and if named differently would not likely
│ │ │ │ +
520 // raise this. It has been named with "child" in the name as it does play
│ │ │ │ +
521 // a more significant role during subdivision in mapping between parent
│ │ │ │ +
522 // and child components, and so has been named to reflect that more clearly.
│ │ │ │ +
523 //
│ │ │ │ +
524
│ │ │ │ +
525 // Per-face:
│ │ │ │ +
526 std::vector<Index> _faceVertCountsAndOffsets; // 2 per face, redundant after level 0
│ │ │ │ +
527 std::vector<Index> _faceVertIndices; // 3 or 4 per face, variable at level 0
│ │ │ │ +
528 std::vector<Index> _faceEdgeIndices; // matches face-vert indices
│ │ │ │ +
529 std::vector<FTag> _faceTags; // 1 per face: includes "hole" tag
│ │ │ │ +
530
│ │ │ │ +
531 // Per-edge:
│ │ │ │ +
532 std::vector<Index> _edgeVertIndices; // 2 per edge
│ │ │ │ +
533 std::vector<Index> _edgeFaceCountsAndOffsets; // 2 per edge
│ │ │ │ +
534 std::vector<Index> _edgeFaceIndices; // varies with faces per edge
│ │ │ │ +
535 std::vector<LocalIndex> _edgeFaceLocalIndices; // varies with faces per edge
│ │ │ │ +
536
│ │ │ │ +
537 std::vector<float> _edgeSharpness; // 1 per edge
│ │ │ │ +
538 std::vector<ETag> _edgeTags; // 1 per edge: manifold, boundary, etc.
│ │ │ │ +
539
│ │ │ │ +
540 // Per-vertex:
│ │ │ │ +
541 std::vector<Index> _vertFaceCountsAndOffsets; // 2 per vertex
│ │ │ │ +
542 std::vector<Index> _vertFaceIndices; // varies with valence
│ │ │ │ +
543 std::vector<LocalIndex> _vertFaceLocalIndices; // varies with valence, 8-bit for now
│ │ │ │ +
544
│ │ │ │ +
545 std::vector<Index> _vertEdgeCountsAndOffsets; // 2 per vertex
│ │ │ │ +
546 std::vector<Index> _vertEdgeIndices; // varies with valence
│ │ │ │ +
547 std::vector<LocalIndex> _vertEdgeLocalIndices; // varies with valence, 8-bit for now
│ │ │ │ +
548
│ │ │ │ +
549 std::vector<float> _vertSharpness; // 1 per vertex
│ │ │ │ +
550 std::vector<VTag> _vertTags; // 1 per vertex: manifold, Sdc::Rule, etc.
│ │ │ │ +
551
│ │ │ │ +
552 // Face-varying channels:
│ │ │ │ +
553 std::vector<FVarLevel*> _fvarChannels;
│ │ │ │ +
554};
│ │ │ │ +
555
│ │ │ │ +
556//
│ │ │ │ +
557// Access/modify the vertices incident a given face:
│ │ │ │ +
558//
│ │ │ │ +
559inline ConstIndexArray
│ │ │ │ +
560Level::getFaceVertices(Index faceIndex) const {
│ │ │ │ +
561 return ConstIndexArray(&_faceVertIndices[_faceVertCountsAndOffsets[faceIndex*2+1]],
│ │ │ │ +
562 _faceVertCountsAndOffsets[faceIndex*2]);
│ │ │ │ +
563}
│ │ │ │ +
564inline IndexArray
│ │ │ │ +
565Level::getFaceVertices(Index faceIndex) {
│ │ │ │ +
566 return IndexArray(&_faceVertIndices[_faceVertCountsAndOffsets[faceIndex*2+1]],
│ │ │ │ +
567 _faceVertCountsAndOffsets[faceIndex*2]);
│ │ │ │ +
568}
│ │ │ │ +
569
│ │ │ │ +
570inline void
│ │ │ │ +
571Level::resizeFaceVertices(Index faceIndex, int count) {
│ │ │ │ +
572
│ │ │ │ +
573 int* countOffsetPair = &_faceVertCountsAndOffsets[faceIndex*2];
│ │ │ │ +
574
│ │ │ │ +
575 countOffsetPair[0] = count;
│ │ │ │ +
576 countOffsetPair[1] = (faceIndex == 0) ? 0 : (countOffsetPair[-2] + countOffsetPair[-1]);
│ │ │ │ +
577
│ │ │ │ +
578 _maxValence = std::max(_maxValence, count);
│ │ │ │ +
579}
│ │ │ │ +
580
│ │ │ │ +
581inline ConstIndexArray
│ │ │ │ +
582Level::getFaceVertices() const {
│ │ │ │ +
583 return ConstIndexArray(&_faceVertIndices[0], (int)_faceVertIndices.size());
│ │ │ │ +
584}
│ │ │ │ +
585
│ │ │ │ +
586//
│ │ │ │ +
587// Access/modify the edges incident a given face:
│ │ │ │ +
588//
│ │ │ │ +
589inline ConstIndexArray
│ │ │ │ +
590Level::getFaceEdges(Index faceIndex) const {
│ │ │ │ +
591 return ConstIndexArray(&_faceEdgeIndices[_faceVertCountsAndOffsets[faceIndex*2+1]],
│ │ │ │ +
592 _faceVertCountsAndOffsets[faceIndex*2]);
│ │ │ │ +
593}
│ │ │ │ +
594inline IndexArray
│ │ │ │ +
595Level::getFaceEdges(Index faceIndex) {
│ │ │ │ +
596 return IndexArray(&_faceEdgeIndices[_faceVertCountsAndOffsets[faceIndex*2+1]],
│ │ │ │ +
597 _faceVertCountsAndOffsets[faceIndex*2]);
│ │ │ │ +
598}
│ │ │ │ +
599
│ │ │ │ +
600//
│ │ │ │ +
601// Access/modify the faces incident a given vertex:
│ │ │ │ +
602//
│ │ │ │ +
603inline ConstIndexArray
│ │ │ │ +
604Level::getVertexFaces(Index vertIndex) const {
│ │ │ │ +
605 return ConstIndexArray( (&_vertFaceIndices[0]) + _vertFaceCountsAndOffsets[vertIndex*2+1],
│ │ │ │ +
606 _vertFaceCountsAndOffsets[vertIndex*2]);
│ │ │ │ +
607}
│ │ │ │ +
608inline IndexArray
│ │ │ │ +
609Level::getVertexFaces(Index vertIndex) {
│ │ │ │ +
610 return IndexArray( (&_vertFaceIndices[0]) + _vertFaceCountsAndOffsets[vertIndex*2+1],
│ │ │ │ +
611 _vertFaceCountsAndOffsets[vertIndex*2]);
│ │ │ │ +
612}
│ │ │ │ +
613
│ │ │ │ + │ │ │ │ +
615Level::getVertexFaceLocalIndices(Index vertIndex) const {
│ │ │ │ +
616 return ConstLocalIndexArray( (&_vertFaceLocalIndices[0]) + _vertFaceCountsAndOffsets[vertIndex*2+1],
│ │ │ │ +
617 _vertFaceCountsAndOffsets[vertIndex*2]);
│ │ │ │ +
618}
│ │ │ │ +
619inline LocalIndexArray
│ │ │ │ +
620Level::getVertexFaceLocalIndices(Index vertIndex) {
│ │ │ │ +
621 return LocalIndexArray( (&_vertFaceLocalIndices[0]) + _vertFaceCountsAndOffsets[vertIndex*2+1],
│ │ │ │ +
622 _vertFaceCountsAndOffsets[vertIndex*2]);
│ │ │ │ +
623}
│ │ │ │ +
624
│ │ │ │ +
625inline void
│ │ │ │ +
626Level::resizeVertexFaces(Index vertIndex, int count) {
│ │ │ │ +
627 int* countOffsetPair = &_vertFaceCountsAndOffsets[vertIndex*2];
│ │ │ │ +
628
│ │ │ │ +
629 countOffsetPair[0] = count;
│ │ │ │ +
630 countOffsetPair[1] = (vertIndex == 0) ? 0 : (countOffsetPair[-2] + countOffsetPair[-1]);
│ │ │ │ +
631}
│ │ │ │ +
632inline void
│ │ │ │ +
633Level::trimVertexFaces(Index vertIndex, int count) {
│ │ │ │ +
634 _vertFaceCountsAndOffsets[vertIndex*2] = count;
│ │ │ │ +
635}
│ │ │ │ +
636
│ │ │ │ +
637//
│ │ │ │ +
638// Access/modify the edges incident a given vertex:
│ │ │ │ +
639//
│ │ │ │ +
640inline ConstIndexArray
│ │ │ │ +
641Level::getVertexEdges(Index vertIndex) const {
│ │ │ │ +
642 return ConstIndexArray( (&_vertEdgeIndices[0]) +_vertEdgeCountsAndOffsets[vertIndex*2+1],
│ │ │ │ +
643 _vertEdgeCountsAndOffsets[vertIndex*2]);
│ │ │ │ +
644}
│ │ │ │ +
645inline IndexArray
│ │ │ │ +
646Level::getVertexEdges(Index vertIndex) {
│ │ │ │ +
647 return IndexArray( (&_vertEdgeIndices[0]) +_vertEdgeCountsAndOffsets[vertIndex*2+1],
│ │ │ │ +
648 _vertEdgeCountsAndOffsets[vertIndex*2]);
│ │ │ │ +
649}
│ │ │ │ +
650
│ │ │ │ + │ │ │ │ +
652Level::getVertexEdgeLocalIndices(Index vertIndex) const {
│ │ │ │ +
653 return ConstLocalIndexArray( (&_vertEdgeLocalIndices[0]) + _vertEdgeCountsAndOffsets[vertIndex*2+1],
│ │ │ │ +
654 _vertEdgeCountsAndOffsets[vertIndex*2]);
│ │ │ │ +
655}
│ │ │ │ +
656inline LocalIndexArray
│ │ │ │ +
657Level::getVertexEdgeLocalIndices(Index vertIndex) {
│ │ │ │ +
658 return LocalIndexArray( (&_vertEdgeLocalIndices[0]) + _vertEdgeCountsAndOffsets[vertIndex*2+1],
│ │ │ │ +
659 _vertEdgeCountsAndOffsets[vertIndex*2]);
│ │ │ │ +
660}
│ │ │ │ +
661
│ │ │ │ +
662inline void
│ │ │ │ +
663Level::resizeVertexEdges(Index vertIndex, int count) {
│ │ │ │ +
664 int* countOffsetPair = &_vertEdgeCountsAndOffsets[vertIndex*2];
│ │ │ │ +
665
│ │ │ │ +
666 countOffsetPair[0] = count;
│ │ │ │ +
667 countOffsetPair[1] = (vertIndex == 0) ? 0 : (countOffsetPair[-2] + countOffsetPair[-1]);
│ │ │ │ +
668
│ │ │ │ +
669 _maxValence = std::max(_maxValence, count);
│ │ │ │ +
670}
│ │ │ │ +
671inline void
│ │ │ │ +
672Level::trimVertexEdges(Index vertIndex, int count) {
│ │ │ │ +
673 _vertEdgeCountsAndOffsets[vertIndex*2] = count;
│ │ │ │ +
674}
│ │ │ │ +
675
│ │ │ │ +
676inline void
│ │ │ │ +
677Level::setMaxValence(int valence) {
│ │ │ │ +
678 _maxValence = valence;
│ │ │ │ +
679}
│ │ │ │ +
680
│ │ │ │ +
681//
│ │ │ │ +
682// Access/modify the vertices incident a given edge:
│ │ │ │ +
683//
│ │ │ │ +
684inline ConstIndexArray
│ │ │ │ +
685Level::getEdgeVertices(Index edgeIndex) const {
│ │ │ │ +
686 return ConstIndexArray(&_edgeVertIndices[edgeIndex*2], 2);
│ │ │ │ +
687}
│ │ │ │ +
688inline IndexArray
│ │ │ │ +
689Level::getEdgeVertices(Index edgeIndex) {
│ │ │ │ +
690 return IndexArray(&_edgeVertIndices[edgeIndex*2], 2);
│ │ │ │ +
691}
│ │ │ │ +
692
│ │ │ │ +
693//
│ │ │ │ +
694// Access/modify the faces incident a given edge:
│ │ │ │ +
695//
│ │ │ │ +
696inline ConstIndexArray
│ │ │ │ +
697Level::getEdgeFaces(Index edgeIndex) const {
│ │ │ │ +
698 return ConstIndexArray(&_edgeFaceIndices[0] +
│ │ │ │ +
699 _edgeFaceCountsAndOffsets[edgeIndex*2+1],
│ │ │ │ +
700 _edgeFaceCountsAndOffsets[edgeIndex*2]);
│ │ │ │ +
701}
│ │ │ │ +
702inline IndexArray
│ │ │ │ +
703Level::getEdgeFaces(Index edgeIndex) {
│ │ │ │ +
704 return IndexArray(&_edgeFaceIndices[0] +
│ │ │ │ +
705 _edgeFaceCountsAndOffsets[edgeIndex*2+1],
│ │ │ │ +
706 _edgeFaceCountsAndOffsets[edgeIndex*2]);
│ │ │ │ +
707}
│ │ │ │ +
708
│ │ │ │ + │ │ │ │ +
710Level::getEdgeFaceLocalIndices(Index edgeIndex) const {
│ │ │ │ +
711 return ConstLocalIndexArray(&_edgeFaceLocalIndices[0] +
│ │ │ │ +
712 _edgeFaceCountsAndOffsets[edgeIndex*2+1],
│ │ │ │ +
713 _edgeFaceCountsAndOffsets[edgeIndex*2]);
│ │ │ │ +
714}
│ │ │ │ +
715inline LocalIndexArray
│ │ │ │ +
716Level::getEdgeFaceLocalIndices(Index edgeIndex) {
│ │ │ │ +
717 return LocalIndexArray(&_edgeFaceLocalIndices[0] +
│ │ │ │ +
718 _edgeFaceCountsAndOffsets[edgeIndex*2+1],
│ │ │ │ +
719 _edgeFaceCountsAndOffsets[edgeIndex*2]);
│ │ │ │ +
720}
│ │ │ │ +
721
│ │ │ │ +
722inline void
│ │ │ │ +
723Level::resizeEdgeFaces(Index edgeIndex, int count) {
│ │ │ │ +
724 int* countOffsetPair = &_edgeFaceCountsAndOffsets[edgeIndex*2];
│ │ │ │ +
725
│ │ │ │ +
726 countOffsetPair[0] = count;
│ │ │ │ +
727 countOffsetPair[1] = (edgeIndex == 0) ? 0 : (countOffsetPair[-2] + countOffsetPair[-1]);
│ │ │ │ +
728
│ │ │ │ +
729 _maxEdgeFaces = std::max(_maxEdgeFaces, count);
│ │ │ │ +
730}
│ │ │ │ +
731inline void
│ │ │ │ +
732Level::trimEdgeFaces(Index edgeIndex, int count) {
│ │ │ │ +
733 _edgeFaceCountsAndOffsets[edgeIndex*2] = count;
│ │ │ │ +
734}
│ │ │ │ +
735
│ │ │ │ +
736//
│ │ │ │ +
737// Access/modify sharpness values:
│ │ │ │ +
738//
│ │ │ │ +
739inline float
│ │ │ │ +
740Level::getEdgeSharpness(Index edgeIndex) const {
│ │ │ │ +
741 return _edgeSharpness[edgeIndex];
│ │ │ │ +
742}
│ │ │ │ +
743inline float&
│ │ │ │ +
744Level::getEdgeSharpness(Index edgeIndex) {
│ │ │ │ +
745 return _edgeSharpness[edgeIndex];
│ │ │ │ +
746}
│ │ │ │ +
747
│ │ │ │ +
748inline float
│ │ │ │ +
749Level::getVertexSharpness(Index vertIndex) const {
│ │ │ │ +
750 return _vertSharpness[vertIndex];
│ │ │ │ +
751}
│ │ │ │ +
752inline float&
│ │ │ │ +
753Level::getVertexSharpness(Index vertIndex) {
│ │ │ │ +
754 return _vertSharpness[vertIndex];
│ │ │ │ +
755}
│ │ │ │ +
756
│ │ │ │ + │ │ │ │ +
758Level::getVertexRule(Index vertIndex) const {
│ │ │ │ +
759 return (Sdc::Crease::Rule) _vertTags[vertIndex]._rule;
│ │ │ │ +
760}
│ │ │ │ +
761
│ │ │ │ +
762//
│ │ │ │ +
763// Access/modify hole tag:
│ │ │ │ +
764//
│ │ │ │ +
765inline void
│ │ │ │ +
766Level::setFaceHole(Index faceIndex, bool b) {
│ │ │ │ +
767 _faceTags[faceIndex]._hole = b;
│ │ │ │ +
768}
│ │ │ │ +
769inline bool
│ │ │ │ +
770Level::isFaceHole(Index faceIndex) const {
│ │ │ │ +
771 return _faceTags[faceIndex]._hole;
│ │ │ │ +
772}
│ │ │ │ +
773
│ │ │ │ +
774//
│ │ │ │ +
775// Access/modify non-manifold tags:
│ │ │ │ +
776//
│ │ │ │ +
777inline void
│ │ │ │ +
778Level::setEdgeNonManifold(Index edgeIndex, bool b) {
│ │ │ │ +
779 _edgeTags[edgeIndex]._nonManifold = b;
│ │ │ │ +
780}
│ │ │ │ +
781inline bool
│ │ │ │ +
782Level::isEdgeNonManifold(Index edgeIndex) const {
│ │ │ │ +
783 return _edgeTags[edgeIndex]._nonManifold;
│ │ │ │ +
784}
│ │ │ │ +
785
│ │ │ │ +
786inline void
│ │ │ │ +
787Level::setVertexNonManifold(Index vertIndex, bool b) {
│ │ │ │ +
788 _vertTags[vertIndex]._nonManifold = b;
│ │ │ │ +
789}
│ │ │ │ +
790inline bool
│ │ │ │ +
791Level::isVertexNonManifold(Index vertIndex) const {
│ │ │ │ +
792 return _vertTags[vertIndex]._nonManifold;
│ │ │ │ +
793}
│ │ │ │ +
794
│ │ │ │ +
795//
│ │ │ │ +
796// Sizing methods to allocate space:
│ │ │ │ +
797//
│ │ │ │ +
798inline void
│ │ │ │ +
799Level::resizeFaces(int faceCount) {
│ │ │ │ +
800 _faceCount = faceCount;
│ │ │ │ +
801 _faceVertCountsAndOffsets.resize(2 * faceCount);
│ │ │ │ +
802
│ │ │ │ +
803 _faceTags.resize(faceCount);
│ │ │ │ +
804 std::memset((void*) &_faceTags[0], 0, _faceCount * sizeof(FTag));
│ │ │ │ +
805}
│ │ │ │ +
806inline void
│ │ │ │ +
807Level::resizeFaceVertices(int totalFaceVertCount) {
│ │ │ │ +
808 _faceVertIndices.resize(totalFaceVertCount);
│ │ │ │ +
809}
│ │ │ │ +
810inline void
│ │ │ │ +
811Level::resizeFaceEdges(int totalFaceEdgeCount) {
│ │ │ │ +
812 _faceEdgeIndices.resize(totalFaceEdgeCount);
│ │ │ │ +
813}
│ │ │ │ +
814
│ │ │ │ +
815inline void
│ │ │ │ +
816Level::resizeEdges(int edgeCount) {
│ │ │ │ +
817
│ │ │ │ +
818 _edgeCount = edgeCount;
│ │ │ │ +
819 _edgeFaceCountsAndOffsets.resize(2 * edgeCount);
│ │ │ │ +
820
│ │ │ │ +
821 _edgeSharpness.resize(edgeCount);
│ │ │ │ +
822 _edgeTags.resize(edgeCount);
│ │ │ │ +
823
│ │ │ │ +
824 if (edgeCount>0) {
│ │ │ │ +
825 std::memset((void*) &_edgeTags[0], 0, _edgeCount * sizeof(ETag));
│ │ │ │ +
826 }
│ │ │ │ +
827}
│ │ │ │ +
828inline void
│ │ │ │ +
829Level::resizeEdgeVertices() {
│ │ │ │ +
830
│ │ │ │ +
831 _edgeVertIndices.resize(2 * _edgeCount);
│ │ │ │ +
832}
│ │ │ │ +
833inline void
│ │ │ │ +
834Level::resizeEdgeFaces(int totalEdgeFaceCount) {
│ │ │ │ +
835
│ │ │ │ +
836 _edgeFaceIndices.resize(totalEdgeFaceCount);
│ │ │ │ +
837 _edgeFaceLocalIndices.resize(totalEdgeFaceCount);
│ │ │ │ +
838}
│ │ │ │ +
839
│ │ │ │ +
840inline void
│ │ │ │ +
841Level::resizeVertices(int vertCount) {
│ │ │ │ +
842
│ │ │ │ +
843 _vertCount = vertCount;
│ │ │ │ +
844 _vertFaceCountsAndOffsets.resize(2 * vertCount);
│ │ │ │ +
845 _vertEdgeCountsAndOffsets.resize(2 * vertCount);
│ │ │ │ +
846
│ │ │ │ +
847 _vertSharpness.resize(vertCount);
│ │ │ │ +
848 _vertTags.resize(vertCount);
│ │ │ │ +
849 std::memset((void*) &_vertTags[0], 0, _vertCount * sizeof(VTag));
│ │ │ │ +
850}
│ │ │ │ +
851inline void
│ │ │ │ +
852Level::resizeVertexFaces(int totalVertFaceCount) {
│ │ │ │ +
853
│ │ │ │ +
854 _vertFaceIndices.resize(totalVertFaceCount);
│ │ │ │ +
855 _vertFaceLocalIndices.resize(totalVertFaceCount);
│ │ │ │ +
856}
│ │ │ │ +
857inline void
│ │ │ │ +
858Level::resizeVertexEdges(int totalVertEdgeCount) {
│ │ │ │ +
859
│ │ │ │ +
860 _vertEdgeIndices.resize(totalVertEdgeCount);
│ │ │ │ +
861 _vertEdgeLocalIndices.resize(totalVertEdgeCount);
│ │ │ │ +
862}
│ │ │ │ +
863
│ │ │ │ +
864inline IndexArray
│ │ │ │ +
865Level::shareFaceVertCountsAndOffsets() const {
│ │ │ │ +
866 // XXXX manuelk we have to force const casting here (classes don't 'share'
│ │ │ │ +
867 // members usually...)
│ │ │ │ +
868 return IndexArray(const_cast<Index *>(&_faceVertCountsAndOffsets[0]),
│ │ │ │ +
869 (int)_faceVertCountsAndOffsets.size());
│ │ │ │ +
870}
│ │ │ │ +
871
│ │ │ │ +
872} // end namespace internal
│ │ │ │ +
873} // end namespace Vtr
│ │ │ │ +
874
│ │ │ │ +
875} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
876using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
877} // end namespace OpenSubdiv
│ │ │ │ +
878
│ │ │ │ +
879#endif /* OPENSUBDIV3_VTR_LEVEL_H */
│ │ │ │ + │ │ │ │ +
ConstArray< LocalIndex > ConstLocalIndexArray
Definition types.h:83
│ │ │ │ +
Array< LocalIndex > LocalIndexArray
Definition types.h:82
│ │ │ │ │ │ │ │ +
ConstArray< Index > ConstIndexArray
Definition types.h:80
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -sparseSelector.h │ │ │ │ │ +level.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -23,111 +23,986 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_VTR_SPARSE_SELECTOR_H │ │ │ │ │ -25#define OPENSUBDIV3_VTR_SPARSE_SELECTOR_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_VTR_LEVEL_H │ │ │ │ │ +25#define OPENSUBDIV3_VTR_LEVEL_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ -29#include "../vtr/types.h" │ │ │ │ │ -30#include "../vtr/refinement.h" │ │ │ │ │ -31 │ │ │ │ │ -32#include │ │ │ │ │ +29#include "../sdc/types.h" │ │ │ │ │ +30#include "../sdc/crease.h" │ │ │ │ │ +31#include "../sdc/options.h" │ │ │ │ │ +32#include "../vtr/types.h" │ │ │ │ │ 33 │ │ │ │ │ -34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -35namespace OPENSUBDIV_VERSION { │ │ │ │ │ -36 │ │ │ │ │ -37namespace Vtr { │ │ │ │ │ -38namespace internal { │ │ │ │ │ +34#include │ │ │ │ │ +35#include │ │ │ │ │ +36#include │ │ │ │ │ +37#include │ │ │ │ │ +38 │ │ │ │ │ 39 │ │ │ │ │ -40// │ │ │ │ │ -41// SparseSelector: │ │ │ │ │ -42// Class supporting "selection" of components in a Level for sparse │ │ │ │ │ -Refinement. │ │ │ │ │ -43// The term "selection" here implies interest in the limit for that │ │ │ │ │ -component, i.e. │ │ │ │ │ -44// the limit point for a selected vertex, the limit patch for a face, etc. So │ │ │ │ │ -this │ │ │ │ │ -45// class is responsible for ensuring that all neighboring components required │ │ │ │ │ -to │ │ │ │ │ -46// support the limit of those selected are included in the refinement. │ │ │ │ │ -47// │ │ │ │ │ -48// This class is associated with (and constructed given) a Refinement and its │ │ │ │ │ -role │ │ │ │ │ -49// is to initialize that Refinement instance for eventual sparse refinement. │ │ │ │ │ -So it │ │ │ │ │ -50// is a friend of and expected to modify the Refinement as part of the │ │ │ │ │ -selection. │ │ │ │ │ -51// Given its simplicity and scope it may be worth nesting it in Vtr:: │ │ │ │ │ -Refinement. │ │ │ │ │ +40namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +41namespace OPENSUBDIV_VERSION { │ │ │ │ │ +42 │ │ │ │ │ +43namespace Vtr { │ │ │ │ │ +44namespace internal { │ │ │ │ │ +45 │ │ │ │ │ +46class Refinement; │ │ │ │ │ +47class TriRefinement; │ │ │ │ │ +48class QuadRefinement; │ │ │ │ │ +49class FVarRefinement; │ │ │ │ │ +50class FVarLevel; │ │ │ │ │ +51 │ │ │ │ │ 52// │ │ │ │ │ -53// While all three component types -- vertices, edges and faces -- can be │ │ │ │ │ -selected, │ │ │ │ │ -54// only selection of faces is currently used and actively supported as part │ │ │ │ │ -of the │ │ │ │ │ -55// feature-adaptive refinement. │ │ │ │ │ -56// │ │ │ │ │ -57class SparseSelector { │ │ │ │ │ -58 │ │ │ │ │ -59public: │ │ │ │ │ -60 SparseSelector(Refinement& refine) : _refine(&refine), _selected(false) { } │ │ │ │ │ -61 ~SparseSelector() { } │ │ │ │ │ -62 │ │ │ │ │ -63 void setRefinement(Refinement& refine) { _refine = &refine; } │ │ │ │ │ -64 Refinement& getRefinement() const { return *_refine; } │ │ │ │ │ -65 │ │ │ │ │ -66 bool isSelectionEmpty() const { return !_selected; } │ │ │ │ │ -67 │ │ │ │ │ -68 // │ │ │ │ │ -69 // Methods for selecting (and marking) components for refinement. All │ │ │ │ │ -component indices │ │ │ │ │ -70 // refer to components in the parent: │ │ │ │ │ -71 // │ │ │ │ │ -72 void selectVertex(_I_n_d_e_x pVertex); │ │ │ │ │ -73 void selectEdge( _I_n_d_e_x pEdge); │ │ │ │ │ -74 void selectFace( _I_n_d_e_x pFace); │ │ │ │ │ -75 │ │ │ │ │ -76private: │ │ │ │ │ -77 SparseSelector() : _refine(0), _selected(false) { } │ │ │ │ │ -78 │ │ │ │ │ -79 bool wasVertexSelected(_I_n_d_e_x pVertex) const { return _refine- │ │ │ │ │ ->getParentVertexSparseTag(pVertex)._selected; } │ │ │ │ │ -80 bool wasEdgeSelected( _I_n_d_e_x pEdge) const { return _refine- │ │ │ │ │ ->getParentEdgeSparseTag(pEdge)._selected; } │ │ │ │ │ -81 bool wasFaceSelected( _I_n_d_e_x pFace) const { return _refine- │ │ │ │ │ ->getParentFaceSparseTag(pFace)._selected; } │ │ │ │ │ +53// Level: │ │ │ │ │ +54// A refinement level includes a vectorized representation of the topology │ │ │ │ │ +55// for a particular subdivision level. The topology is "complete" in that any │ │ │ │ │ +56// level can be used as the base level of another subdivision hierarchy and │ │ │ │ │ +can │ │ │ │ │ +57// be considered a complete mesh independent of its ancestors. It currently │ │ │ │ │ +58// does contain a "depth" member -- as some inferences can then be made about │ │ │ │ │ +59// the topology (i.e. all quads or all tris if not level 0). │ │ │ │ │ +60// │ │ │ │ │ +61// This class is intended for private use within the library. There are still │ │ │ │ │ +62// opportunities to specialize levels -- e.g. those supporting N-sided faces │ │ │ │ │ +vs │ │ │ │ │ +63// those that are purely quads or tris -- so we prefer to insulate it from │ │ │ │ │ +public │ │ │ │ │ +64// access. │ │ │ │ │ +65// │ │ │ │ │ +66// The representation of topology here is to store six topological │ │ │ │ │ +relationships │ │ │ │ │ +67// in tables of integers. Each is stored in its own array(s) so the result is │ │ │ │ │ +68// a SOA representation of the topology. The six relations are: │ │ │ │ │ +69// │ │ │ │ │ +70// - face-verts: vertices incident/comprising a face │ │ │ │ │ +71// - face-edges: edges incident a face │ │ │ │ │ +72// - edge-verts: vertices incident/comprising an edge │ │ │ │ │ +73// - edge-faces: faces incident an edge │ │ │ │ │ +74// - vert-faces: faces incident a vertex │ │ │ │ │ +75// - vert-edges: edges incident a vertex │ │ │ │ │ +76// │ │ │ │ │ +77// There is some redundancy here but the intent is not that this be a minimal │ │ │ │ │ +78// representation, the intent is that it be amenable to refinement. Classes │ │ │ │ │ +in │ │ │ │ │ +79// the Far layer essentially store 5 of these 6 in a permuted form -- we add │ │ │ │ │ +80// the face-edges here to simplify refinement. │ │ │ │ │ +81// │ │ │ │ │ 82 │ │ │ │ │ -83 void markVertexSelected(_I_n_d_e_x pVertex) const { _refine- │ │ │ │ │ ->getParentVertexSparseTag(pVertex)._selected = true; } │ │ │ │ │ -84 void markEdgeSelected( _I_n_d_e_x pEdge) const { _refine->getParentEdgeSparseTag │ │ │ │ │ -(pEdge)._selected = true; } │ │ │ │ │ -85 void markFaceSelected( _I_n_d_e_x pFace) const { _refine->getParentFaceSparseTag │ │ │ │ │ -(pFace)._selected = true; } │ │ │ │ │ -86 │ │ │ │ │ -87 void initializeSelection(); │ │ │ │ │ -88 │ │ │ │ │ -89private: │ │ │ │ │ -90 Refinement* _refine; │ │ │ │ │ -91 bool _selected; │ │ │ │ │ -92}; │ │ │ │ │ -93 │ │ │ │ │ -94} // end namespace internal │ │ │ │ │ -95} // end namespace Vtr │ │ │ │ │ -96 │ │ │ │ │ -97} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -98using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -99} // end namespace OpenSubdiv │ │ │ │ │ -100 │ │ │ │ │ -101#endif /* OPENSUBDIV3_VTR_SPARSE_SELECTOR_H */ │ │ │ │ │ +83class Level { │ │ │ │ │ +84 │ │ │ │ │ +85public: │ │ │ │ │ +86 // │ │ │ │ │ +87 // Simple nested types to hold the tags for each component type -- some of │ │ │ │ │ +88 // which are user-specified features (e.g. whether a face is a hole or not) │ │ │ │ │ +89 // while others indicate the topological nature of the component, how it │ │ │ │ │ +90 // is affected by creasing in its neighborhood, etc. │ │ │ │ │ +91 // │ │ │ │ │ +92 // Most of these properties are passed down to child components during │ │ │ │ │ +93 // refinement, but some -- notably the designation of a component as semi- │ │ │ │ │ +94 // sharp -- require re-determination as sharpness values are reduced at each │ │ │ │ │ +95 // level. │ │ │ │ │ +96 // │ │ │ │ │ +97 struct VTag { │ │ │ │ │ +98 VTag() { } │ │ │ │ │ +99 │ │ │ │ │ +100 // When cleared, the VTag ALMOST represents a smooth, regular, interior │ │ │ │ │ +101 // vertex -- the Type enum requires a bit be explicitly set for Smooth, │ │ │ │ │ +102 // so that must be done explicitly if desired on initialization. │ │ │ │ │ +103 void clear() { std::memset((void*) this, 0, sizeof(VTag)); } │ │ │ │ │ +104 │ │ │ │ │ +105 typedef unsigned short VTagSize; │ │ │ │ │ +106 │ │ │ │ │ +107 VTagSize _nonManifold : 1; // fixed │ │ │ │ │ +108 VTagSize _xordinary : 1; // fixed │ │ │ │ │ +109 VTagSize _boundary : 1; // fixed │ │ │ │ │ +110 VTagSize _corner : 1; // fixed │ │ │ │ │ +111 VTagSize _infSharp : 1; // fixed │ │ │ │ │ +112 VTagSize _semiSharp : 1; // variable │ │ │ │ │ +113 VTagSize _semiSharpEdges : 1; // variable │ │ │ │ │ +114 VTagSize _rule : 4; // variable when _semiSharp │ │ │ │ │ +115 │ │ │ │ │ +116 // These next to tags are complementary -- the "incomplete" tag is only │ │ │ │ │ +117 // relevant for refined levels while the "incident an irregular face" tag │ │ │ │ │ +118 // is only relevant for the base level. They could be combined as both │ │ │ │ │ +119 // indicate "no full regular ring" around a vertex │ │ │ │ │ +120 VTagSize _incomplete : 1; // variable only set in refined levels │ │ │ │ │ +121 VTagSize _incidIrregFace : 1; // variable only set in base level │ │ │ │ │ +122 │ │ │ │ │ +123 // Tags indicating incident infinitely-sharp (permanent) features │ │ │ │ │ +124 VTagSize _infSharpEdges : 1; // fixed │ │ │ │ │ +125 VTagSize _infSharpCrease : 1; // fixed │ │ │ │ │ +126 VTagSize _infIrregular : 1; // fixed │ │ │ │ │ +127 │ │ │ │ │ +128 // Alternate constructor and accessor for dealing with integer bits │ │ │ │ │ +directly: │ │ │ │ │ +129 explicit VTag(VTagSize bits) { │ │ │ │ │ +130 std::memcpy(this, &bits, sizeof(bits)); │ │ │ │ │ +131 } │ │ │ │ │ +132 VTagSize getBits() const { │ │ │ │ │ +133 VTagSize bits; │ │ │ │ │ +134 std::memcpy(&bits, this, sizeof(bits)); │ │ │ │ │ +135 return bits; │ │ │ │ │ +136 } │ │ │ │ │ +137 │ │ │ │ │ +138 static VTag BitwiseOr(VTag const vTags[], int size = 4); │ │ │ │ │ +139 }; │ │ │ │ │ +140 struct ETag { │ │ │ │ │ +141 ETag() { } │ │ │ │ │ +142 │ │ │ │ │ +143 // When cleared, the ETag represents a smooth, manifold, interior edge │ │ │ │ │ +144 void clear() { std::memset((void*) this, 0, sizeof(ETag)); } │ │ │ │ │ +145 │ │ │ │ │ +146 typedef unsigned char ETagSize; │ │ │ │ │ +147 │ │ │ │ │ +148 ETagSize _nonManifold : 1; // fixed │ │ │ │ │ +149 ETagSize _boundary : 1; // fixed │ │ │ │ │ +150 ETagSize _infSharp : 1; // fixed │ │ │ │ │ +151 ETagSize _semiSharp : 1; // variable │ │ │ │ │ +152 │ │ │ │ │ +153 // Alternate constructor and accessor for dealing with integer bits │ │ │ │ │ +directly: │ │ │ │ │ +154 explicit ETag(ETagSize bits) { │ │ │ │ │ +155 std::memcpy(this, &bits, sizeof(bits)); │ │ │ │ │ +156 } │ │ │ │ │ +157 ETagSize getBits() const { │ │ │ │ │ +158 ETagSize bits; │ │ │ │ │ +159 std::memcpy(&bits, this, sizeof(bits)); │ │ │ │ │ +160 return bits; │ │ │ │ │ +161 } │ │ │ │ │ +162 │ │ │ │ │ +163 static ETag BitwiseOr(ETag const eTags[], int size = 4); │ │ │ │ │ +164 }; │ │ │ │ │ +165 struct FTag { │ │ │ │ │ +166 FTag() { } │ │ │ │ │ +167 │ │ │ │ │ +168 void clear() { std::memset((void*) this, 0, sizeof(FTag)); } │ │ │ │ │ +169 │ │ │ │ │ +170 typedef unsigned char FTagSize; │ │ │ │ │ +171 │ │ │ │ │ +172 FTagSize _hole : 1; // fixed │ │ │ │ │ +173 │ │ │ │ │ +174 // On deck -- coming soon... │ │ │ │ │ +175 //FTagSize _hasEdits : 1; // variable │ │ │ │ │ +176 }; │ │ │ │ │ +177 │ │ │ │ │ +178 // Additional simple struct to identify a "span" around a vertex, i.e. a │ │ │ │ │ +179 // subset of the faces around a vertex delimited by some property (e.g. a │ │ │ │ │ +180 // face-varying discontinuity, an inf-sharp edge, etc.) │ │ │ │ │ +181 // │ │ │ │ │ +182 // The span requires an "origin" and a "size" to fully define its extent. │ │ │ │ │ +183 // Use of the size is required over a leading/trailing pair as the valence │ │ │ │ │ +184 // around a non-manifold vertex cannot be trivially determined from two │ │ │ │ │ +185 // extremeties. Similarly a start face is chosen over an edge as starting │ │ │ │ │ +186 // with a manifold edge is ambiguous. Additional tags also support │ │ │ │ │ +187 // non-manifold cases, e.g. periodic spans at the apex of a double cone. │ │ │ │ │ +188 // │ │ │ │ │ +189 // Currently setting the size to 0 or leaving the span "unassigned" is an │ │ │ │ │ +190 // indication to use the full neighborhood rather than a subset -- prefer │ │ │ │ │ +191 // use of the const method here to direct inspection of the member. │ │ │ │ │ +192 // │ │ │ │ │ +193 struct VSpan { │ │ │ │ │ +194 VSpan() { std::memset((void*) this, 0, sizeof(VSpan)); } │ │ │ │ │ +195 │ │ │ │ │ +196 void clear() { std::memset((void*) this, 0, sizeof(VSpan)); } │ │ │ │ │ +197 bool isAssigned() const { return _numFaces > 0; } │ │ │ │ │ +198 │ │ │ │ │ +199 _L_o_c_a_l_I_n_d_e_x _numFaces; │ │ │ │ │ +200 _L_o_c_a_l_I_n_d_e_x _startFace; │ │ │ │ │ +201 _L_o_c_a_l_I_n_d_e_x _cornerInSpan; │ │ │ │ │ +202 │ │ │ │ │ +203 unsigned short _periodic : 1; │ │ │ │ │ +204 unsigned short _sharp : 1; │ │ │ │ │ +205 }; │ │ │ │ │ +206 │ │ │ │ │ +207public: │ │ │ │ │ +208 Level(); │ │ │ │ │ +209 ~Level(); │ │ │ │ │ +210 │ │ │ │ │ +211 // Simple accessors: │ │ │ │ │ +212 int getDepth() const { return _depth; } │ │ │ │ │ +213 │ │ │ │ │ +214 int getNumVertices() const { return _vertCount; } │ │ │ │ │ +215 int getNumFaces() const { return _faceCount; } │ │ │ │ │ +216 int getNumEdges() const { return _edgeCount; } │ │ │ │ │ +217 │ │ │ │ │ +218 // More global sizes may prove useful... │ │ │ │ │ +219 int getNumFaceVerticesTotal() const { return (int) _faceVertIndices.size(); │ │ │ │ │ +} │ │ │ │ │ +220 int getNumFaceEdgesTotal() const { return (int) _faceEdgeIndices.size(); } │ │ │ │ │ +221 int getNumEdgeVerticesTotal() const { return (int) _edgeVertIndices.size(); │ │ │ │ │ +} │ │ │ │ │ +222 int getNumEdgeFacesTotal() const { return (int) _edgeFaceIndices.size(); } │ │ │ │ │ +223 int getNumVertexFacesTotal() const { return (int) _vertFaceIndices.size(); │ │ │ │ │ +} │ │ │ │ │ +224 int getNumVertexEdgesTotal() const { return (int) _vertEdgeIndices.size(); │ │ │ │ │ +} │ │ │ │ │ +225 │ │ │ │ │ +226 int getMaxValence() const { return _maxValence; } │ │ │ │ │ +227 int getMaxEdgeFaces() const { return _maxEdgeFaces; } │ │ │ │ │ +228 │ │ │ │ │ +229 // Methods to access the relation tables/indices -- note that for some │ │ │ │ │ +relations │ │ │ │ │ +230 // (i.e. those where a component is "contained by" a neighbor, or more │ │ │ │ │ +generally │ │ │ │ │ +231 // when the neighbor is a simplex of higher dimension) we store an │ │ │ │ │ +additional │ │ │ │ │ +232 // "local index", e.g. for the case of vert-faces if one of the faces F[i] │ │ │ │ │ +is │ │ │ │ │ +233 // incident a vertex V, then L[i] is the "local index" in F[i] of vertex V. │ │ │ │ │ +234 // Once have only quads (or tris), this local index need only occupy two │ │ │ │ │ +bits │ │ │ │ │ +235 // and could conceivably be packed into the same integer as the face index, │ │ │ │ │ +but │ │ │ │ │ +236 // for now, given the need to support faces of potentially high valence │ │ │ │ │ +we'll │ │ │ │ │ +237 // use an 8- or 16-bit integer. │ │ │ │ │ +238 // │ │ │ │ │ +239 // Methods to access the six topological relations: │ │ │ │ │ +240 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceVertices(_I_n_d_e_x faceIndex) const; │ │ │ │ │ +241 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceEdges(_I_n_d_e_x faceIndex) const; │ │ │ │ │ +242 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getEdgeVertices(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ +243 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getEdgeFaces(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ +244 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getVertexFaces(_I_n_d_e_x vertIndex) const; │ │ │ │ │ +245 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getVertexEdges(_I_n_d_e_x vertIndex) const; │ │ │ │ │ +246 │ │ │ │ │ +247 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getEdgeFaceLocalIndices(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ +248 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getVertexFaceLocalIndices(_I_n_d_e_x vertIndex) const; │ │ │ │ │ +249 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getVertexEdgeLocalIndices(_I_n_d_e_x vertIndex) const; │ │ │ │ │ +250 │ │ │ │ │ +251 // Replace these with access to sharpness buffers/arrays rather than │ │ │ │ │ +elements: │ │ │ │ │ +252 float getEdgeSharpness(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ +253 float getVertexSharpness(_I_n_d_e_x vertIndex) const; │ │ │ │ │ +254 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e getVertexRule(_I_n_d_e_x vertIndex) const; │ │ │ │ │ +255 │ │ │ │ │ +256 _I_n_d_e_x findEdge(_I_n_d_e_x v0Index, _I_n_d_e_x v1Index) const; │ │ │ │ │ +257 │ │ │ │ │ +258 // Holes │ │ │ │ │ +259 void setFaceHole(_I_n_d_e_x faceIndex, bool b); │ │ │ │ │ +260 bool isFaceHole(_I_n_d_e_x faceIndex) const; │ │ │ │ │ +261 │ │ │ │ │ +262 // Face-varying │ │ │ │ │ +263 Sdc::Options getFVarOptions(int channel) const; │ │ │ │ │ +264 int getNumFVarChannels() const { return (int) _fvarChannels.size(); } │ │ │ │ │ +265 int getNumFVarValues(int channel) const; │ │ │ │ │ +266 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceFVarValues(_I_n_d_e_x faceIndex, int channel) const; │ │ │ │ │ +267 │ │ │ │ │ +268 FVarLevel & getFVarLevel(int channel) { return *_fvarChannels[channel]; } │ │ │ │ │ +269 FVarLevel const & getFVarLevel(int channel) const { return *_fvarChannels │ │ │ │ │ +[channel]; } │ │ │ │ │ +270 │ │ │ │ │ +271 // Manifold/non-manifold tags: │ │ │ │ │ +272 void setEdgeNonManifold(_I_n_d_e_x edgeIndex, bool b); │ │ │ │ │ +273 bool isEdgeNonManifold(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ +274 │ │ │ │ │ +275 void setVertexNonManifold(_I_n_d_e_x vertIndex, bool b); │ │ │ │ │ +276 bool isVertexNonManifold(_I_n_d_e_x vertIndex) const; │ │ │ │ │ +277 │ │ │ │ │ +278 // General access to all component tags: │ │ │ │ │ +279 VTag const & getVertexTag(_I_n_d_e_x vertIndex) const { return _vertTags │ │ │ │ │ +[vertIndex]; } │ │ │ │ │ +280 ETag const & getEdgeTag(_I_n_d_e_x edgeIndex) const { return _edgeTags │ │ │ │ │ +[edgeIndex]; } │ │ │ │ │ +281 FTag const & getFaceTag(_I_n_d_e_x faceIndex) const { return _faceTags │ │ │ │ │ +[faceIndex]; } │ │ │ │ │ +282 │ │ │ │ │ +283 VTag & getVertexTag(_I_n_d_e_x vertIndex) { return _vertTags[vertIndex]; } │ │ │ │ │ +284 ETag & getEdgeTag(_I_n_d_e_x edgeIndex) { return _edgeTags[edgeIndex]; } │ │ │ │ │ +285 FTag & getFaceTag(_I_n_d_e_x faceIndex) { return _faceTags[faceIndex]; } │ │ │ │ │ +286 │ │ │ │ │ +287public: │ │ │ │ │ +288 │ │ │ │ │ +289 // Debugging aides: │ │ │ │ │ +290 enum TopologyError { │ │ │ │ │ +291 TOPOLOGY_MISSING_EDGE_FACES=0, │ │ │ │ │ +292 TOPOLOGY_MISSING_EDGE_VERTS, │ │ │ │ │ +293 TOPOLOGY_MISSING_FACE_EDGES, │ │ │ │ │ +294 TOPOLOGY_MISSING_FACE_VERTS, │ │ │ │ │ +295 TOPOLOGY_MISSING_VERT_FACES, │ │ │ │ │ +296 TOPOLOGY_MISSING_VERT_EDGES, │ │ │ │ │ +297 │ │ │ │ │ +298 TOPOLOGY_FAILED_CORRELATION_EDGE_FACE, │ │ │ │ │ +299 TOPOLOGY_FAILED_CORRELATION_FACE_VERT, │ │ │ │ │ +300 TOPOLOGY_FAILED_CORRELATION_FACE_EDGE, │ │ │ │ │ +301 │ │ │ │ │ +302 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_EDGE, │ │ │ │ │ +303 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_FACE, │ │ │ │ │ +304 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_FACES_EDGES, │ │ │ │ │ +305 │ │ │ │ │ +306 TOPOLOGY_DEGENERATE_EDGE, │ │ │ │ │ +307 TOPOLOGY_NON_MANIFOLD_EDGE, │ │ │ │ │ +308 │ │ │ │ │ +309 TOPOLOGY_INVALID_CREASE_EDGE, │ │ │ │ │ +310 TOPOLOGY_INVALID_CREASE_VERT │ │ │ │ │ +311 }; │ │ │ │ │ +312 │ │ │ │ │ +313 static char const * getTopologyErrorString(TopologyError errCode); │ │ │ │ │ +314 │ │ │ │ │ +315 typedef void (* ValidationCallback)(TopologyError errCode, char const * │ │ │ │ │ +msg, void const * clientData); │ │ │ │ │ +316 │ │ │ │ │ +317 bool validateTopology(ValidationCallback callback=0, void const * │ │ │ │ │ +clientData=0) const; │ │ │ │ │ +318 │ │ │ │ │ +319 void print(const Refinement* parentRefinement = 0) const; │ │ │ │ │ +320 │ │ │ │ │ +321public: │ │ │ │ │ +322 // High-level topology queries -- these may be moved elsewhere: │ │ │ │ │ +323 │ │ │ │ │ +324 bool isSingleCreasePatch(_I_n_d_e_x face, float* sharpnessOut=NULL, int* │ │ │ │ │ +rotationOut=NULL) const; │ │ │ │ │ +325 │ │ │ │ │ +326 // │ │ │ │ │ +327 // When inspecting topology, the component tags -- particularly VTag and │ │ │ │ │ +ETag -- are most │ │ │ │ │ +328 // often inspected in groups for the face to which they belong. They are │ │ │ │ │ +designed to be │ │ │ │ │ +329 // bitwise OR'd (the result then referred to as a "composite" tag) to make │ │ │ │ │ +quick decisions │ │ │ │ │ +330 // about the face as a whole to avoid tedious topological inspection. │ │ │ │ │ +331 // │ │ │ │ │ +332 // The same logic can be applied to topology in a FVar channel when tags │ │ │ │ │ +specific to that │ │ │ │ │ +333 // channel are used. Note that the VTags apply to the FVar values assigned │ │ │ │ │ +to the corners │ │ │ │ │ +334 // of the face and not the vertex as a whole. The "composite" face-varying │ │ │ │ │ +VTag for a │ │ │ │ │ +335 // vertex is the union of VTags of all distinct FVar values for that │ │ │ │ │ +vertex. │ │ │ │ │ +336 // │ │ │ │ │ +337 bool doesVertexFVarTopologyMatch(_I_n_d_e_x vIndex, int fvarChannel) const; │ │ │ │ │ +338 bool doesFaceFVarTopologyMatch( _I_n_d_e_x fIndex, int fvarChannel) const; │ │ │ │ │ +339 bool doesEdgeFVarTopologyMatch( _I_n_d_e_x eIndex, int fvarChannel) const; │ │ │ │ │ +340 │ │ │ │ │ +341 void getFaceVTags(_I_n_d_e_x fIndex, VTag vTags[], int fvarChannel = -1) const; │ │ │ │ │ +342 void getFaceETags(_I_n_d_e_x fIndex, ETag eTags[], int fvarChannel = -1) const; │ │ │ │ │ +343 │ │ │ │ │ +344 VTag getFaceCompositeVTag(_I_n_d_e_x fIndex, int fvarChannel = -1) const; │ │ │ │ │ +345 VTag getFaceCompositeVTag(_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y & fVerts) const; │ │ │ │ │ +346 │ │ │ │ │ +347 VTag getVertexCompositeFVarVTag(_I_n_d_e_x vIndex, int fvarChannel) const; │ │ │ │ │ +348 │ │ │ │ │ +349 // │ │ │ │ │ +350 // When gathering "patch points" we may want the indices of the vertices or │ │ │ │ │ +the corresponding │ │ │ │ │ +351 // FVar values for a particular channel. Both are represented and equally │ │ │ │ │ +accessible within │ │ │ │ │ +352 // the faces, so we allow all to be returned through these methods. Setting │ │ │ │ │ +the optional FVar │ │ │ │ │ +353 // channel to -1 will retrieve indices of vertices instead of FVar values: │ │ │ │ │ +354 // │ │ │ │ │ +355 int gatherQuadLinearPatchPoints(_I_n_d_e_x fIndex, _I_n_d_e_x patchPoints[], int │ │ │ │ │ +rotation = 0, │ │ │ │ │ +356 int fvarChannel = -1) const; │ │ │ │ │ +357 │ │ │ │ │ +358 int gatherQuadRegularInteriorPatchPoints(_I_n_d_e_x fIndex, _I_n_d_e_x patchPoints[], │ │ │ │ │ +int rotation = 0, │ │ │ │ │ +359 int fvarChannel = -1) const; │ │ │ │ │ +360 int gatherQuadRegularBoundaryPatchPoints(_I_n_d_e_x fIndex, _I_n_d_e_x patchPoints[], │ │ │ │ │ +int boundaryEdgeInFace, │ │ │ │ │ +361 int fvarChannel = -1) const; │ │ │ │ │ +362 int gatherQuadRegularCornerPatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchPoints[], │ │ │ │ │ +int cornerVertInFace, │ │ │ │ │ +363 int fvarChannel = -1) const; │ │ │ │ │ +364 │ │ │ │ │ +365 int gatherQuadRegularRingAroundVertex(_I_n_d_e_x vIndex, _I_n_d_e_x ringPoints[], │ │ │ │ │ +366 int fvarChannel = -1) const; │ │ │ │ │ +367 int gatherQuadRegularPartialRingAroundVertex(_I_n_d_e_x vIndex, VSpan const & │ │ │ │ │ +span, _I_n_d_e_x ringPoints[], │ │ │ │ │ +368 int fvarChannel = -1) const; │ │ │ │ │ +369 │ │ │ │ │ +370 // WIP -- for future use, need to extend for face-varying... │ │ │ │ │ +371 int gatherTriRegularInteriorPatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchVerts[], │ │ │ │ │ +int rotation = 0) const; │ │ │ │ │ +372 int gatherTriRegularBoundaryVertexPatchPoints(_I_n_d_e_x fIndex, _I_n_d_e_x │ │ │ │ │ +patchVerts[], int boundaryVertInFace) const; │ │ │ │ │ +373 int gatherTriRegularBoundaryEdgePatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchVerts │ │ │ │ │ +[], int boundaryEdgeInFace) const; │ │ │ │ │ +374 int gatherTriRegularCornerVertexPatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchVerts │ │ │ │ │ +[], int cornerVertInFace) const; │ │ │ │ │ +375 int gatherTriRegularCornerEdgePatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchVerts │ │ │ │ │ +[], int cornerEdgeInFace) const; │ │ │ │ │ +376 │ │ │ │ │ +377public: │ │ │ │ │ +378 // Sizing methods used to construct a level to populate: │ │ │ │ │ +379 void resizeFaces( int numFaces); │ │ │ │ │ +380 void resizeFaceVertices(int numFaceVertsTotal); │ │ │ │ │ +381 void resizeFaceEdges( int numFaceEdgesTotal); │ │ │ │ │ +382 │ │ │ │ │ +383 void resizeEdges( int numEdges); │ │ │ │ │ +384 void resizeEdgeVertices(); // always 2*edgeCount │ │ │ │ │ +385 void resizeEdgeFaces(int numEdgeFacesTotal); │ │ │ │ │ +386 │ │ │ │ │ +387 void resizeVertices( int numVertices); │ │ │ │ │ +388 void resizeVertexFaces(int numVertexFacesTotal); │ │ │ │ │ +389 void resizeVertexEdges(int numVertexEdgesTotal); │ │ │ │ │ +390 │ │ │ │ │ +391 void setMaxValence(int maxValence); │ │ │ │ │ +392 │ │ │ │ │ +393 // Modifiers to populate the relations for each component: │ │ │ │ │ +394 _I_n_d_e_x_A_r_r_a_y getFaceVertices(_I_n_d_e_x faceIndex); │ │ │ │ │ +395 _I_n_d_e_x_A_r_r_a_y getFaceEdges(_I_n_d_e_x faceIndex); │ │ │ │ │ +396 _I_n_d_e_x_A_r_r_a_y getEdgeVertices(_I_n_d_e_x edgeIndex); │ │ │ │ │ +397 _I_n_d_e_x_A_r_r_a_y getEdgeFaces(_I_n_d_e_x edgeIndex); │ │ │ │ │ +398 _I_n_d_e_x_A_r_r_a_y getVertexFaces(_I_n_d_e_x vertIndex); │ │ │ │ │ +399 _I_n_d_e_x_A_r_r_a_y getVertexEdges(_I_n_d_e_x vertIndex); │ │ │ │ │ +400 │ │ │ │ │ +401 _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getEdgeFaceLocalIndices(_I_n_d_e_x edgeIndex); │ │ │ │ │ +402 _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getVertexFaceLocalIndices(_I_n_d_e_x vertIndex); │ │ │ │ │ +403 _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getVertexEdgeLocalIndices(_I_n_d_e_x vertIndex); │ │ │ │ │ +404 │ │ │ │ │ +405 // Replace these with access to sharpness buffers/arrays rather than │ │ │ │ │ +elements: │ │ │ │ │ +406 float& getEdgeSharpness(_I_n_d_e_x edgeIndex); │ │ │ │ │ +407 float& getVertexSharpness(_I_n_d_e_x vertIndex); │ │ │ │ │ +408 │ │ │ │ │ +409 // Create, destroy and populate face-varying channels: │ │ │ │ │ +410 int createFVarChannel(int fvarValueCount, Sdc::Options const& options); │ │ │ │ │ +411 void destroyFVarChannel(int channel); │ │ │ │ │ +412 │ │ │ │ │ +413 _I_n_d_e_x_A_r_r_a_y getFaceFVarValues(_I_n_d_e_x faceIndex, int channel); │ │ │ │ │ +414 │ │ │ │ │ +415 void completeFVarChannelTopology(int channel, int regBoundaryValence); │ │ │ │ │ +416 │ │ │ │ │ +417 // Counts and offsets for all relation types: │ │ │ │ │ +418 // - these may be unwarranted if we let Refinement access members │ │ │ │ │ +directly... │ │ │ │ │ +419 int getNumFaceVertices( _I_n_d_e_x faceIndex) const { return │ │ │ │ │ +_faceVertCountsAndOffsets[2*faceIndex]; } │ │ │ │ │ +420 int getOffsetOfFaceVertices(_I_n_d_e_x faceIndex) const { return │ │ │ │ │ +_faceVertCountsAndOffsets[2*faceIndex + 1]; } │ │ │ │ │ +421 │ │ │ │ │ +422 int getNumFaceEdges( _I_n_d_e_x faceIndex) const { return getNumFaceVertices │ │ │ │ │ +(faceIndex); } │ │ │ │ │ +423 int getOffsetOfFaceEdges(_I_n_d_e_x faceIndex) const { return │ │ │ │ │ +getOffsetOfFaceVertices(faceIndex); } │ │ │ │ │ +424 │ │ │ │ │ +425 int getNumEdgeVertices( _I_n_d_e_x ) const { return 2; } │ │ │ │ │ +426 int getOffsetOfEdgeVertices(_I_n_d_e_x edgeIndex) const { return 2 * edgeIndex; │ │ │ │ │ +} │ │ │ │ │ +427 │ │ │ │ │ +428 int getNumEdgeFaces( _I_n_d_e_x edgeIndex) const { return │ │ │ │ │ +_edgeFaceCountsAndOffsets[2*edgeIndex]; } │ │ │ │ │ +429 int getOffsetOfEdgeFaces(_I_n_d_e_x edgeIndex) const { return │ │ │ │ │ +_edgeFaceCountsAndOffsets[2*edgeIndex + 1]; } │ │ │ │ │ +430 │ │ │ │ │ +431 int getNumVertexFaces( _I_n_d_e_x vertIndex) const { return │ │ │ │ │ +_vertFaceCountsAndOffsets[2*vertIndex]; } │ │ │ │ │ +432 int getOffsetOfVertexFaces(_I_n_d_e_x vertIndex) const { return │ │ │ │ │ +_vertFaceCountsAndOffsets[2*vertIndex + 1]; } │ │ │ │ │ +433 │ │ │ │ │ +434 int getNumVertexEdges( _I_n_d_e_x vertIndex) const { return │ │ │ │ │ +_vertEdgeCountsAndOffsets[2*vertIndex]; } │ │ │ │ │ +435 int getOffsetOfVertexEdges(_I_n_d_e_x vertIndex) const { return │ │ │ │ │ +_vertEdgeCountsAndOffsets[2*vertIndex + 1]; } │ │ │ │ │ +436 │ │ │ │ │ +437 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceVertices() const; │ │ │ │ │ +438 │ │ │ │ │ +439 // │ │ │ │ │ +440 // Note that for some relations, the size of the relations for a child │ │ │ │ │ +component │ │ │ │ │ +441 // can vary radically from its parent due to the sparsity of the │ │ │ │ │ +refinement. So │ │ │ │ │ +442 // in these cases a few additional utilities are provided to help define │ │ │ │ │ +the set │ │ │ │ │ +443 // of incident components. Assuming adequate memory has been allocated, the │ │ │ │ │ +444 // "resize" methods here initialize the set of incident components by │ │ │ │ │ +setting │ │ │ │ │ +445 // both the size and the appropriate offset, while "trim" is use to quickly │ │ │ │ │ +lower │ │ │ │ │ +446 // the size from an upper bound and nothing else. │ │ │ │ │ +447 // │ │ │ │ │ +448 void resizeFaceVertices(_I_n_d_e_x FaceIndex, int count); │ │ │ │ │ +449 │ │ │ │ │ +450 void resizeEdgeFaces(_I_n_d_e_x edgeIndex, int count); │ │ │ │ │ +451 void trimEdgeFaces( _I_n_d_e_x edgeIndex, int count); │ │ │ │ │ +452 │ │ │ │ │ +453 void resizeVertexFaces(_I_n_d_e_x vertIndex, int count); │ │ │ │ │ +454 void trimVertexFaces( _I_n_d_e_x vertIndex, int count); │ │ │ │ │ +455 │ │ │ │ │ +456 void resizeVertexEdges(_I_n_d_e_x vertIndex, int count); │ │ │ │ │ +457 void trimVertexEdges( _I_n_d_e_x vertIndex, int count); │ │ │ │ │ +458 │ │ │ │ │ +459public: │ │ │ │ │ +460 // │ │ │ │ │ +461 // Initial plans were to have a few specific classes properly construct the │ │ │ │ │ +462 // topology from scratch, e.g. the Refinement class and a Factory class for │ │ │ │ │ +463 // the base level, by populating all topological relations. The need to │ │ │ │ │ +have │ │ │ │ │ +464 // a class construct full topology given only a simple face-vertex list, │ │ │ │ │ +made │ │ │ │ │ +465 // it necessary to write code to define and orient all relations -- and │ │ │ │ │ +most │ │ │ │ │ +466 // of that seemed best placed here. │ │ │ │ │ +467 // │ │ │ │ │ +468 bool completeTopologyFromFaceVertices(); │ │ │ │ │ +469 _I_n_d_e_x findEdge(_I_n_d_e_x v0, _I_n_d_e_x v1, _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y v0Edges) const; │ │ │ │ │ +470 │ │ │ │ │ +471 // Methods supporting the above: │ │ │ │ │ +472 void orientIncidentComponents(); │ │ │ │ │ +473 bool orderVertexFacesAndEdges(_I_n_d_e_x vIndex, _I_n_d_e_x* vFaces, _I_n_d_e_x* vEdges) │ │ │ │ │ +const; │ │ │ │ │ +474 bool orderVertexFacesAndEdges(_I_n_d_e_x vIndex); │ │ │ │ │ +475 void populateLocalIndices(); │ │ │ │ │ +476 │ │ │ │ │ +477 _I_n_d_e_x_A_r_r_a_y shareFaceVertCountsAndOffsets() const; │ │ │ │ │ +478 │ │ │ │ │ +479private: │ │ │ │ │ +480 // Refinement classes (including all subclasses) build a Level: │ │ │ │ │ +481 friend class Refinement; │ │ │ │ │ +482 friend class TriRefinement; │ │ │ │ │ +483 friend class QuadRefinement; │ │ │ │ │ +484 │ │ │ │ │ +485 // │ │ │ │ │ +486 // A Level is independent of subdivision scheme or options. While it may │ │ │ │ │ +have been │ │ │ │ │ +487 // affected by them in its construction, they are not associated with it - │ │ │ │ │ +- a Level │ │ │ │ │ +488 // is pure topology and any subdivision parameters are external. │ │ │ │ │ +489 // │ │ │ │ │ +490 │ │ │ │ │ +491 // Simple members for inventory, etc. │ │ │ │ │ +492 int _faceCount; │ │ │ │ │ +493 int _edgeCount; │ │ │ │ │ +494 int _vertCount; │ │ │ │ │ +495 │ │ │ │ │ +496 // The "depth" member is clearly useful in both the topological splitting │ │ │ │ │ +and the │ │ │ │ │ +497 // stencil queries, but arguably it ties the Level to a hierarchy which │ │ │ │ │ +counters │ │ │ │ │ +498 // the idea of it being independent. │ │ │ │ │ +499 int _depth; │ │ │ │ │ +500 │ │ │ │ │ +501 // Maxima to help clients manage sizing of data buffers. Given "max │ │ │ │ │ +valence", │ │ │ │ │ +502 // the "max edge faces" is strictly redundant as it will always be less, │ │ │ │ │ +but │ │ │ │ │ +503 // since it will typically be so much less (i.e. 2) it is kept for now. │ │ │ │ │ +504 int _maxEdgeFaces; │ │ │ │ │ +505 int _maxValence; │ │ │ │ │ +506 │ │ │ │ │ +507 // │ │ │ │ │ +508 // Topology vectors: │ │ │ │ │ +509 // Note that of all of these, only data for the face-edge relation is not │ │ │ │ │ +510 // stored in the osd::FarTables in any form. The FarTable vectors combine │ │ │ │ │ +511 // the edge-vert and edge-face relations. The eventual goal is that this │ │ │ │ │ +512 // data be part of the osd::Far classes and be a superset of the FarTable │ │ │ │ │ +513 // vectors, i.e. no data duplication or conversion. The fact that FarTable │ │ │ │ │ +514 // already stores 5 of the 6 possible relations should make the topology │ │ │ │ │ +515 // storage as a whole a non-issue. │ │ │ │ │ +516 // │ │ │ │ │ +517 // The vert-face-child and vert-edge-child indices are also arguably not │ │ │ │ │ +518 // a topology relation but more one for parent/child relations. But it is │ │ │ │ │ +519 // a topological relationship, and if named differently would not likely │ │ │ │ │ +520 // raise this. It has been named with "child" in the name as it does play │ │ │ │ │ +521 // a more significant role during subdivision in mapping between parent │ │ │ │ │ +522 // and child components, and so has been named to reflect that more │ │ │ │ │ +clearly. │ │ │ │ │ +523 // │ │ │ │ │ +524 │ │ │ │ │ +525 // Per-face: │ │ │ │ │ +526 std::vector _faceVertCountsAndOffsets; // 2 per face, redundant │ │ │ │ │ +after level 0 │ │ │ │ │ +527 std::vector _faceVertIndices; // 3 or 4 per face, variable at level │ │ │ │ │ +0 │ │ │ │ │ +528 std::vector _faceEdgeIndices; // matches face-vert indices │ │ │ │ │ +529 std::vector _faceTags; // 1 per face: includes "hole" tag │ │ │ │ │ +530 │ │ │ │ │ +531 // Per-edge: │ │ │ │ │ +532 std::vector _edgeVertIndices; // 2 per edge │ │ │ │ │ +533 std::vector _edgeFaceCountsAndOffsets; // 2 per edge │ │ │ │ │ +534 std::vector _edgeFaceIndices; // varies with faces per edge │ │ │ │ │ +535 std::vector _edgeFaceLocalIndices; // varies with faces per │ │ │ │ │ +edge │ │ │ │ │ +536 │ │ │ │ │ +537 std::vector _edgeSharpness; // 1 per edge │ │ │ │ │ +538 std::vector _edgeTags; // 1 per edge: manifold, boundary, etc. │ │ │ │ │ +539 │ │ │ │ │ +540 // Per-vertex: │ │ │ │ │ +541 std::vector _vertFaceCountsAndOffsets; // 2 per vertex │ │ │ │ │ +542 std::vector _vertFaceIndices; // varies with valence │ │ │ │ │ +543 std::vector _vertFaceLocalIndices; // varies with valence, 8- │ │ │ │ │ +bit for now │ │ │ │ │ +544 │ │ │ │ │ +545 std::vector _vertEdgeCountsAndOffsets; // 2 per vertex │ │ │ │ │ +546 std::vector _vertEdgeIndices; // varies with valence │ │ │ │ │ +547 std::vector _vertEdgeLocalIndices; // varies with valence, 8- │ │ │ │ │ +bit for now │ │ │ │ │ +548 │ │ │ │ │ +549 std::vector _vertSharpness; // 1 per vertex │ │ │ │ │ +550 std::vector _vertTags; // 1 per vertex: manifold, Sdc::Rule, etc. │ │ │ │ │ +551 │ │ │ │ │ +552 // Face-varying channels: │ │ │ │ │ +553 std::vector _fvarChannels; │ │ │ │ │ +554}; │ │ │ │ │ +555 │ │ │ │ │ +556// │ │ │ │ │ +557// Access/modify the vertices incident a given face: │ │ │ │ │ +558// │ │ │ │ │ +559inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +560Level::getFaceVertices(_I_n_d_e_x faceIndex) const { │ │ │ │ │ +561 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceVertIndices[_faceVertCountsAndOffsets │ │ │ │ │ +[faceIndex*2+1]], │ │ │ │ │ +562 _faceVertCountsAndOffsets[faceIndex*2]); │ │ │ │ │ +563} │ │ │ │ │ +564inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +565Level::getFaceVertices(_I_n_d_e_x faceIndex) { │ │ │ │ │ +566 return _I_n_d_e_x_A_r_r_a_y(&_faceVertIndices[_faceVertCountsAndOffsets │ │ │ │ │ +[faceIndex*2+1]], │ │ │ │ │ +567 _faceVertCountsAndOffsets[faceIndex*2]); │ │ │ │ │ +568} │ │ │ │ │ +569 │ │ │ │ │ +570inline void │ │ │ │ │ +571Level::resizeFaceVertices(_I_n_d_e_x faceIndex, int count) { │ │ │ │ │ +572 │ │ │ │ │ +573 int* countOffsetPair = &_faceVertCountsAndOffsets[faceIndex*2]; │ │ │ │ │ +574 │ │ │ │ │ +575 countOffsetPair[0] = count; │ │ │ │ │ +576 countOffsetPair[1] = (faceIndex == 0) ? 0 : (countOffsetPair[-2] + │ │ │ │ │ +countOffsetPair[-1]); │ │ │ │ │ +577 │ │ │ │ │ +578 _maxValence = std::max(_maxValence, count); │ │ │ │ │ +579} │ │ │ │ │ +580 │ │ │ │ │ +581inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +582Level::getFaceVertices() const { │ │ │ │ │ +583 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceVertIndices[0], (int)_faceVertIndices.size()); │ │ │ │ │ +584} │ │ │ │ │ +585 │ │ │ │ │ +586// │ │ │ │ │ +587// Access/modify the edges incident a given face: │ │ │ │ │ +588// │ │ │ │ │ +589inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +590Level::getFaceEdges(_I_n_d_e_x faceIndex) const { │ │ │ │ │ +591 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceEdgeIndices[_faceVertCountsAndOffsets │ │ │ │ │ +[faceIndex*2+1]], │ │ │ │ │ +592 _faceVertCountsAndOffsets[faceIndex*2]); │ │ │ │ │ +593} │ │ │ │ │ +594inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +595Level::getFaceEdges(_I_n_d_e_x faceIndex) { │ │ │ │ │ +596 return _I_n_d_e_x_A_r_r_a_y(&_faceEdgeIndices[_faceVertCountsAndOffsets │ │ │ │ │ +[faceIndex*2+1]], │ │ │ │ │ +597 _faceVertCountsAndOffsets[faceIndex*2]); │ │ │ │ │ +598} │ │ │ │ │ +599 │ │ │ │ │ +600// │ │ │ │ │ +601// Access/modify the faces incident a given vertex: │ │ │ │ │ +602// │ │ │ │ │ +603inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +604Level::getVertexFaces(_I_n_d_e_x vertIndex) const { │ │ │ │ │ +605 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y( (&_vertFaceIndices[0]) + _vertFaceCountsAndOffsets │ │ │ │ │ +[vertIndex*2+1], │ │ │ │ │ +606 _vertFaceCountsAndOffsets[vertIndex*2]); │ │ │ │ │ +607} │ │ │ │ │ +608inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +609Level::getVertexFaces(_I_n_d_e_x vertIndex) { │ │ │ │ │ +610 return _I_n_d_e_x_A_r_r_a_y( (&_vertFaceIndices[0]) + _vertFaceCountsAndOffsets │ │ │ │ │ +[vertIndex*2+1], │ │ │ │ │ +611 _vertFaceCountsAndOffsets[vertIndex*2]); │ │ │ │ │ +612} │ │ │ │ │ +613 │ │ │ │ │ +614inline _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +615Level::getVertexFaceLocalIndices(_I_n_d_e_x vertIndex) const { │ │ │ │ │ +616 return _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y( (&_vertFaceLocalIndices[0]) + │ │ │ │ │ +_vertFaceCountsAndOffsets[vertIndex*2+1], │ │ │ │ │ +617 _vertFaceCountsAndOffsets[vertIndex*2]); │ │ │ │ │ +618} │ │ │ │ │ +619inline _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +620Level::getVertexFaceLocalIndices(_I_n_d_e_x vertIndex) { │ │ │ │ │ +621 return _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y( (&_vertFaceLocalIndices[0]) + │ │ │ │ │ +_vertFaceCountsAndOffsets[vertIndex*2+1], │ │ │ │ │ +622 _vertFaceCountsAndOffsets[vertIndex*2]); │ │ │ │ │ +623} │ │ │ │ │ +624 │ │ │ │ │ +625inline void │ │ │ │ │ +626Level::resizeVertexFaces(_I_n_d_e_x vertIndex, int count) { │ │ │ │ │ +627 int* countOffsetPair = &_vertFaceCountsAndOffsets[vertIndex*2]; │ │ │ │ │ +628 │ │ │ │ │ +629 countOffsetPair[0] = count; │ │ │ │ │ +630 countOffsetPair[1] = (vertIndex == 0) ? 0 : (countOffsetPair[-2] + │ │ │ │ │ +countOffsetPair[-1]); │ │ │ │ │ +631} │ │ │ │ │ +632inline void │ │ │ │ │ +633Level::trimVertexFaces(_I_n_d_e_x vertIndex, int count) { │ │ │ │ │ +634 _vertFaceCountsAndOffsets[vertIndex*2] = count; │ │ │ │ │ +635} │ │ │ │ │ +636 │ │ │ │ │ +637// │ │ │ │ │ +638// Access/modify the edges incident a given vertex: │ │ │ │ │ +639// │ │ │ │ │ +640inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +641Level::getVertexEdges(_I_n_d_e_x vertIndex) const { │ │ │ │ │ +642 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y( (&_vertEdgeIndices[0]) +_vertEdgeCountsAndOffsets │ │ │ │ │ +[vertIndex*2+1], │ │ │ │ │ +643 _vertEdgeCountsAndOffsets[vertIndex*2]); │ │ │ │ │ +644} │ │ │ │ │ +645inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +646Level::getVertexEdges(_I_n_d_e_x vertIndex) { │ │ │ │ │ +647 return _I_n_d_e_x_A_r_r_a_y( (&_vertEdgeIndices[0]) +_vertEdgeCountsAndOffsets │ │ │ │ │ +[vertIndex*2+1], │ │ │ │ │ +648 _vertEdgeCountsAndOffsets[vertIndex*2]); │ │ │ │ │ +649} │ │ │ │ │ +650 │ │ │ │ │ +651inline _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +652Level::getVertexEdgeLocalIndices(_I_n_d_e_x vertIndex) const { │ │ │ │ │ +653 return _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y( (&_vertEdgeLocalIndices[0]) + │ │ │ │ │ +_vertEdgeCountsAndOffsets[vertIndex*2+1], │ │ │ │ │ +654 _vertEdgeCountsAndOffsets[vertIndex*2]); │ │ │ │ │ +655} │ │ │ │ │ +656inline _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +657Level::getVertexEdgeLocalIndices(_I_n_d_e_x vertIndex) { │ │ │ │ │ +658 return _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y( (&_vertEdgeLocalIndices[0]) + │ │ │ │ │ +_vertEdgeCountsAndOffsets[vertIndex*2+1], │ │ │ │ │ +659 _vertEdgeCountsAndOffsets[vertIndex*2]); │ │ │ │ │ +660} │ │ │ │ │ +661 │ │ │ │ │ +662inline void │ │ │ │ │ +663Level::resizeVertexEdges(_I_n_d_e_x vertIndex, int count) { │ │ │ │ │ +664 int* countOffsetPair = &_vertEdgeCountsAndOffsets[vertIndex*2]; │ │ │ │ │ +665 │ │ │ │ │ +666 countOffsetPair[0] = count; │ │ │ │ │ +667 countOffsetPair[1] = (vertIndex == 0) ? 0 : (countOffsetPair[-2] + │ │ │ │ │ +countOffsetPair[-1]); │ │ │ │ │ +668 │ │ │ │ │ +669 _maxValence = std::max(_maxValence, count); │ │ │ │ │ +670} │ │ │ │ │ +671inline void │ │ │ │ │ +672Level::trimVertexEdges(_I_n_d_e_x vertIndex, int count) { │ │ │ │ │ +673 _vertEdgeCountsAndOffsets[vertIndex*2] = count; │ │ │ │ │ +674} │ │ │ │ │ +675 │ │ │ │ │ +676inline void │ │ │ │ │ +677Level::setMaxValence(int valence) { │ │ │ │ │ +678 _maxValence = valence; │ │ │ │ │ +679} │ │ │ │ │ +680 │ │ │ │ │ +681// │ │ │ │ │ +682// Access/modify the vertices incident a given edge: │ │ │ │ │ +683// │ │ │ │ │ +684inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +685Level::getEdgeVertices(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ +686 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_edgeVertIndices[edgeIndex*2], 2); │ │ │ │ │ +687} │ │ │ │ │ +688inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +689Level::getEdgeVertices(_I_n_d_e_x edgeIndex) { │ │ │ │ │ +690 return _I_n_d_e_x_A_r_r_a_y(&_edgeVertIndices[edgeIndex*2], 2); │ │ │ │ │ +691} │ │ │ │ │ +692 │ │ │ │ │ +693// │ │ │ │ │ +694// Access/modify the faces incident a given edge: │ │ │ │ │ +695// │ │ │ │ │ +696inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +697Level::getEdgeFaces(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ +698 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_edgeFaceIndices[0] + │ │ │ │ │ +699 _edgeFaceCountsAndOffsets[edgeIndex*2+1], │ │ │ │ │ +700 _edgeFaceCountsAndOffsets[edgeIndex*2]); │ │ │ │ │ +701} │ │ │ │ │ +702inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +703Level::getEdgeFaces(_I_n_d_e_x edgeIndex) { │ │ │ │ │ +704 return _I_n_d_e_x_A_r_r_a_y(&_edgeFaceIndices[0] + │ │ │ │ │ +705 _edgeFaceCountsAndOffsets[edgeIndex*2+1], │ │ │ │ │ +706 _edgeFaceCountsAndOffsets[edgeIndex*2]); │ │ │ │ │ +707} │ │ │ │ │ +708 │ │ │ │ │ +709inline _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +710Level::getEdgeFaceLocalIndices(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ +711 return _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y(&_edgeFaceLocalIndices[0] + │ │ │ │ │ +712 _edgeFaceCountsAndOffsets[edgeIndex*2+1], │ │ │ │ │ +713 _edgeFaceCountsAndOffsets[edgeIndex*2]); │ │ │ │ │ +714} │ │ │ │ │ +715inline _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +716Level::getEdgeFaceLocalIndices(_I_n_d_e_x edgeIndex) { │ │ │ │ │ +717 return _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y(&_edgeFaceLocalIndices[0] + │ │ │ │ │ +718 _edgeFaceCountsAndOffsets[edgeIndex*2+1], │ │ │ │ │ +719 _edgeFaceCountsAndOffsets[edgeIndex*2]); │ │ │ │ │ +720} │ │ │ │ │ +721 │ │ │ │ │ +722inline void │ │ │ │ │ +723Level::resizeEdgeFaces(_I_n_d_e_x edgeIndex, int count) { │ │ │ │ │ +724 int* countOffsetPair = &_edgeFaceCountsAndOffsets[edgeIndex*2]; │ │ │ │ │ +725 │ │ │ │ │ +726 countOffsetPair[0] = count; │ │ │ │ │ +727 countOffsetPair[1] = (edgeIndex == 0) ? 0 : (countOffsetPair[-2] + │ │ │ │ │ +countOffsetPair[-1]); │ │ │ │ │ +728 │ │ │ │ │ +729 _maxEdgeFaces = std::max(_maxEdgeFaces, count); │ │ │ │ │ +730} │ │ │ │ │ +731inline void │ │ │ │ │ +732Level::trimEdgeFaces(_I_n_d_e_x edgeIndex, int count) { │ │ │ │ │ +733 _edgeFaceCountsAndOffsets[edgeIndex*2] = count; │ │ │ │ │ +734} │ │ │ │ │ +735 │ │ │ │ │ +736// │ │ │ │ │ +737// Access/modify sharpness values: │ │ │ │ │ +738// │ │ │ │ │ +739inline float │ │ │ │ │ +740Level::getEdgeSharpness(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ +741 return _edgeSharpness[edgeIndex]; │ │ │ │ │ +742} │ │ │ │ │ +743inline float& │ │ │ │ │ +744Level::getEdgeSharpness(_I_n_d_e_x edgeIndex) { │ │ │ │ │ +745 return _edgeSharpness[edgeIndex]; │ │ │ │ │ +746} │ │ │ │ │ +747 │ │ │ │ │ +748inline float │ │ │ │ │ +749Level::getVertexSharpness(_I_n_d_e_x vertIndex) const { │ │ │ │ │ +750 return _vertSharpness[vertIndex]; │ │ │ │ │ +751} │ │ │ │ │ +752inline float& │ │ │ │ │ +753Level::getVertexSharpness(_I_n_d_e_x vertIndex) { │ │ │ │ │ +754 return _vertSharpness[vertIndex]; │ │ │ │ │ +755} │ │ │ │ │ +756 │ │ │ │ │ +757inline _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ +758Level::getVertexRule(_I_n_d_e_x vertIndex) const { │ │ │ │ │ +759 return (_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e) _vertTags[vertIndex]._rule; │ │ │ │ │ +760} │ │ │ │ │ +761 │ │ │ │ │ +762// │ │ │ │ │ +763// Access/modify hole tag: │ │ │ │ │ +764// │ │ │ │ │ +765inline void │ │ │ │ │ +766Level::setFaceHole(_I_n_d_e_x faceIndex, bool b) { │ │ │ │ │ +767 _faceTags[faceIndex]._hole = b; │ │ │ │ │ +768} │ │ │ │ │ +769inline bool │ │ │ │ │ +770Level::isFaceHole(_I_n_d_e_x faceIndex) const { │ │ │ │ │ +771 return _faceTags[faceIndex]._hole; │ │ │ │ │ +772} │ │ │ │ │ +773 │ │ │ │ │ +774// │ │ │ │ │ +775// Access/modify non-manifold tags: │ │ │ │ │ +776// │ │ │ │ │ +777inline void │ │ │ │ │ +778Level::setEdgeNonManifold(_I_n_d_e_x edgeIndex, bool b) { │ │ │ │ │ +779 _edgeTags[edgeIndex]._nonManifold = b; │ │ │ │ │ +780} │ │ │ │ │ +781inline bool │ │ │ │ │ +782Level::isEdgeNonManifold(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ +783 return _edgeTags[edgeIndex]._nonManifold; │ │ │ │ │ +784} │ │ │ │ │ +785 │ │ │ │ │ +786inline void │ │ │ │ │ +787Level::setVertexNonManifold(_I_n_d_e_x vertIndex, bool b) { │ │ │ │ │ +788 _vertTags[vertIndex]._nonManifold = b; │ │ │ │ │ +789} │ │ │ │ │ +790inline bool │ │ │ │ │ +791Level::isVertexNonManifold(_I_n_d_e_x vertIndex) const { │ │ │ │ │ +792 return _vertTags[vertIndex]._nonManifold; │ │ │ │ │ +793} │ │ │ │ │ +794 │ │ │ │ │ +795// │ │ │ │ │ +796// Sizing methods to allocate space: │ │ │ │ │ +797// │ │ │ │ │ +798inline void │ │ │ │ │ +799Level::resizeFaces(int faceCount) { │ │ │ │ │ +800 _faceCount = faceCount; │ │ │ │ │ +801 _faceVertCountsAndOffsets.resize(2 * faceCount); │ │ │ │ │ +802 │ │ │ │ │ +803 _faceTags.resize(faceCount); │ │ │ │ │ +804 std::memset((void*) &_faceTags[0], 0, _faceCount * sizeof(FTag)); │ │ │ │ │ +805} │ │ │ │ │ +806inline void │ │ │ │ │ +807Level::resizeFaceVertices(int totalFaceVertCount) { │ │ │ │ │ +808 _faceVertIndices.resize(totalFaceVertCount); │ │ │ │ │ +809} │ │ │ │ │ +810inline void │ │ │ │ │ +811Level::resizeFaceEdges(int totalFaceEdgeCount) { │ │ │ │ │ +812 _faceEdgeIndices.resize(totalFaceEdgeCount); │ │ │ │ │ +813} │ │ │ │ │ +814 │ │ │ │ │ +815inline void │ │ │ │ │ +816Level::resizeEdges(int edgeCount) { │ │ │ │ │ +817 │ │ │ │ │ +818 _edgeCount = edgeCount; │ │ │ │ │ +819 _edgeFaceCountsAndOffsets.resize(2 * edgeCount); │ │ │ │ │ +820 │ │ │ │ │ +821 _edgeSharpness.resize(edgeCount); │ │ │ │ │ +822 _edgeTags.resize(edgeCount); │ │ │ │ │ +823 │ │ │ │ │ +824 if (edgeCount>0) { │ │ │ │ │ +825 std::memset((void*) &_edgeTags[0], 0, _edgeCount * sizeof(ETag)); │ │ │ │ │ +826 } │ │ │ │ │ +827} │ │ │ │ │ +828inline void │ │ │ │ │ +829Level::resizeEdgeVertices() { │ │ │ │ │ +830 │ │ │ │ │ +831 _edgeVertIndices.resize(2 * _edgeCount); │ │ │ │ │ +832} │ │ │ │ │ +833inline void │ │ │ │ │ +834Level::resizeEdgeFaces(int totalEdgeFaceCount) { │ │ │ │ │ +835 │ │ │ │ │ +836 _edgeFaceIndices.resize(totalEdgeFaceCount); │ │ │ │ │ +837 _edgeFaceLocalIndices.resize(totalEdgeFaceCount); │ │ │ │ │ +838} │ │ │ │ │ +839 │ │ │ │ │ +840inline void │ │ │ │ │ +841Level::resizeVertices(int vertCount) { │ │ │ │ │ +842 │ │ │ │ │ +843 _vertCount = vertCount; │ │ │ │ │ +844 _vertFaceCountsAndOffsets.resize(2 * vertCount); │ │ │ │ │ +845 _vertEdgeCountsAndOffsets.resize(2 * vertCount); │ │ │ │ │ +846 │ │ │ │ │ +847 _vertSharpness.resize(vertCount); │ │ │ │ │ +848 _vertTags.resize(vertCount); │ │ │ │ │ +849 std::memset((void*) &_vertTags[0], 0, _vertCount * sizeof(VTag)); │ │ │ │ │ +850} │ │ │ │ │ +851inline void │ │ │ │ │ +852Level::resizeVertexFaces(int totalVertFaceCount) { │ │ │ │ │ +853 │ │ │ │ │ +854 _vertFaceIndices.resize(totalVertFaceCount); │ │ │ │ │ +855 _vertFaceLocalIndices.resize(totalVertFaceCount); │ │ │ │ │ +856} │ │ │ │ │ +857inline void │ │ │ │ │ +858Level::resizeVertexEdges(int totalVertEdgeCount) { │ │ │ │ │ +859 │ │ │ │ │ +860 _vertEdgeIndices.resize(totalVertEdgeCount); │ │ │ │ │ +861 _vertEdgeLocalIndices.resize(totalVertEdgeCount); │ │ │ │ │ +862} │ │ │ │ │ +863 │ │ │ │ │ +864inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +865Level::shareFaceVertCountsAndOffsets() const { │ │ │ │ │ +866 // XXXX manuelk we have to force const casting here (classes don't 'share' │ │ │ │ │ +867 // members usually...) │ │ │ │ │ +868 return _I_n_d_e_x_A_r_r_a_y(const_cast<_I_n_d_e_x *>(&_faceVertCountsAndOffsets[0]), │ │ │ │ │ +869 (int)_faceVertCountsAndOffsets.size()); │ │ │ │ │ +870} │ │ │ │ │ +871 │ │ │ │ │ +872} // end namespace internal │ │ │ │ │ +873} // end namespace Vtr │ │ │ │ │ +874 │ │ │ │ │ +875} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +876using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +877} // end namespace OpenSubdiv │ │ │ │ │ +878 │ │ │ │ │ +879#endif /* OPENSUBDIV3_VTR_LEVEL_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +ConstArray< LocalIndex > ConstLocalIndexArray │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_8_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +Array< LocalIndex > LocalIndexArray │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_8_2 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x │ │ │ │ │ int Index │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +ConstArray< Index > ConstIndexArray │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_8_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_L_o_c_a_l_I_n_d_e_x │ │ │ │ │ +unsigned short LocalIndex │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +Array< Index > IndexArray │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_7_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ +Rule │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _v_t_r │ │ │ │ │ - * _s_p_a_r_s_e_S_e_l_e_c_t_o_r_._h │ │ │ │ │ + * _l_e_v_e_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00752.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/vtr/refinement.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/vtr/sparseSelector.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -89,22 +89,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Namespaces
│ │ │ │ -
refinement.h File Reference
│ │ │ │ +
sparseSelector.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/types.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ #include "../vtr/types.h"
│ │ │ │ -#include "../vtr/level.h"
│ │ │ │ +#include "../vtr/refinement.h"
│ │ │ │ #include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -115,13 +113,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,24 +1,22 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -refinement.h File Reference │ │ │ │ │ +sparseSelector.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ #include "_._._/_v_t_r_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_v_t_r_/_l_e_v_e_l_._h" │ │ │ │ │ +#include "_._._/_v_t_r_/_r_e_f_i_n_e_m_e_n_t_._h" │ │ │ │ │ #include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _v_t_r │ │ │ │ │ - * _r_e_f_i_n_e_m_e_n_t_._h │ │ │ │ │ + * _s_p_a_r_s_e_S_e_l_e_c_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00752_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/vtr/refinement.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/vtr/sparseSelector.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
refinement.h
│ │ │ │ +
sparseSelector.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2014 DreamWorks Animation LLC.
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -118,457 +118,98 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24#ifndef OPENSUBDIV3_VTR_REFINEMENT_H
│ │ │ │ -
25#define OPENSUBDIV3_VTR_REFINEMENT_H
│ │ │ │ +
24#ifndef OPENSUBDIV3_VTR_SPARSE_SELECTOR_H
│ │ │ │ +
25#define OPENSUBDIV3_VTR_SPARSE_SELECTOR_H
│ │ │ │
26
│ │ │ │
27#include "../version.h"
│ │ │ │
28
│ │ │ │ -
29#include "../sdc/types.h"
│ │ │ │ -
30#include "../sdc/options.h"
│ │ │ │ -
31#include "../vtr/types.h"
│ │ │ │ -
32#include "../vtr/level.h"
│ │ │ │ +
29#include "../vtr/types.h"
│ │ │ │ +
30#include "../vtr/refinement.h"
│ │ │ │ +
31
│ │ │ │ +
32#include <vector>
│ │ │ │
33
│ │ │ │ -
34#include <vector>
│ │ │ │ -
35
│ │ │ │ -
36//
│ │ │ │ -
37// Declaration for the main refinement class (Refinement) and its pre-requisites:
│ │ │ │ -
38//
│ │ │ │ -
39namespace OpenSubdiv {
│ │ │ │ -
40namespace OPENSUBDIV_VERSION {
│ │ │ │ -
41
│ │ │ │ -
42namespace Vtr {
│ │ │ │ -
43namespace internal {
│ │ │ │ -
44
│ │ │ │ -
45class FVarRefinement;
│ │ │ │ -
46
│ │ │ │ +
34namespace OpenSubdiv {
│ │ │ │ +
35namespace OPENSUBDIV_VERSION {
│ │ │ │ +
36
│ │ │ │ +
37namespace Vtr {
│ │ │ │ +
38namespace internal {
│ │ │ │ +
39
│ │ │ │ +
40//
│ │ │ │ +
41// SparseSelector:
│ │ │ │ +
42// Class supporting "selection" of components in a Level for sparse Refinement.
│ │ │ │ +
43// The term "selection" here implies interest in the limit for that component, i.e.
│ │ │ │ +
44// the limit point for a selected vertex, the limit patch for a face, etc. So this
│ │ │ │ +
45// class is responsible for ensuring that all neighboring components required to
│ │ │ │ +
46// support the limit of those selected are included in the refinement.
│ │ │ │
47//
│ │ │ │ -
48// Refinement:
│ │ │ │ -
49// A refinement is a mapping between two levels -- relating the components in the original
│ │ │ │ -
50// (parent) level to the one refined (child). The refinement may be complete (uniform) or sparse
│ │ │ │ -
51// (adaptive or otherwise selective), so not all components in the parent level will spawn
│ │ │ │ -
52// components in the child level.
│ │ │ │ -
53//
│ │ │ │ -
54// Refinement is an abstract class and expects subclasses corresponding to the different types
│ │ │ │ -
55// of topological splits that the supported subdivision schemes collectively require, i.e. those
│ │ │ │ -
56// listed in Sdc::SplitType. Note the virtual requirements expected of the subclasses in the list
│ │ │ │ -
57// of protected methods -- they differ mainly in the topology that is created in the child Level
│ │ │ │ -
58// and not the propagation of tags through refinement, subdivision of sharpness values or the
│ │ │ │ -
59// treatment of face-varying data. The primary subclasses are QuadRefinement and TriRefinement.
│ │ │ │ -
60//
│ │ │ │ -
61// At a high level, all that is necessary in terms of interface is to construct, initialize
│ │ │ │ -
62// (linking the two levels), optionally select components for sparse refinement (via use of the
│ │ │ │ -
63// SparseSelector) and call the refine() method. This usage is expected of Far::TopologyRefiner.
│ │ │ │ -
64//
│ │ │ │ -
65// Since we really want this class to be restricted from public access eventually, all methods
│ │ │ │ -
66// begin with lower case (as is the convention for protected methods) and the list of friends
│ │ │ │ -
67// will be maintained more strictly.
│ │ │ │ -
68//
│ │ │ │ -
69class Refinement {
│ │ │ │ -
70
│ │ │ │ -
71public:
│ │ │ │ -
72 Refinement(Level const & parent, Level & child, Sdc::Options const& schemeOptions);
│ │ │ │ -
73 virtual ~Refinement();
│ │ │ │ -
74
│ │ │ │ -
75 Level const& parent() const { return *_parent; }
│ │ │ │ -
76 Level const& child() const { return *_child; }
│ │ │ │ -
77 Level& child() { return *_child; }
│ │ │ │ +
48// This class is associated with (and constructed given) a Refinement and its role
│ │ │ │ +
49// is to initialize that Refinement instance for eventual sparse refinement. So it
│ │ │ │ +
50// is a friend of and expected to modify the Refinement as part of the selection.
│ │ │ │ +
51// Given its simplicity and scope it may be worth nesting it in Vtr::Refinement.
│ │ │ │ +
52//
│ │ │ │ +
53// While all three component types -- vertices, edges and faces -- can be selected,
│ │ │ │ +
54// only selection of faces is currently used and actively supported as part of the
│ │ │ │ +
55// feature-adaptive refinement.
│ │ │ │ +
56//
│ │ │ │ +
57class SparseSelector {
│ │ │ │ +
58
│ │ │ │ +
59public:
│ │ │ │ +
60 SparseSelector(Refinement& refine) : _refine(&refine), _selected(false) { }
│ │ │ │ +
61 ~SparseSelector() { }
│ │ │ │ +
62
│ │ │ │ +
63 void setRefinement(Refinement& refine) { _refine = &refine; }
│ │ │ │ +
64 Refinement& getRefinement() const { return *_refine; }
│ │ │ │ +
65
│ │ │ │ +
66 bool isSelectionEmpty() const { return !_selected; }
│ │ │ │ +
67
│ │ │ │ +
68 //
│ │ │ │ +
69 // Methods for selecting (and marking) components for refinement. All component indices
│ │ │ │ +
70 // refer to components in the parent:
│ │ │ │ +
71 //
│ │ │ │ +
72 void selectVertex(Index pVertex);
│ │ │ │ +
73 void selectEdge( Index pEdge);
│ │ │ │ +
74 void selectFace( Index pFace);
│ │ │ │ +
75
│ │ │ │ +
76private:
│ │ │ │ +
77 SparseSelector() : _refine(0), _selected(false) { }
│ │ │ │
78
│ │ │ │ -
79 Sdc::Split getSplitType() const { return _splitType; }
│ │ │ │ -
80 int getRegularFaceSize() const { return _regFaceSize; }
│ │ │ │ -
81 Sdc::Options getOptions() const { return _options; }
│ │ │ │ +
79 bool wasVertexSelected(Index pVertex) const { return _refine->getParentVertexSparseTag(pVertex)._selected; }
│ │ │ │ +
80 bool wasEdgeSelected( Index pEdge) const { return _refine->getParentEdgeSparseTag(pEdge)._selected; }
│ │ │ │ +
81 bool wasFaceSelected( Index pFace) const { return _refine->getParentFaceSparseTag(pFace)._selected; }
│ │ │ │
82
│ │ │ │ -
83 // Face-varying:
│ │ │ │ -
84 int getNumFVarChannels() const { return (int) _fvarChannels.size(); }
│ │ │ │ -
85
│ │ │ │ -
86 FVarRefinement const & getFVarRefinement(int c) const { return *_fvarChannels[c]; }
│ │ │ │ -
87
│ │ │ │ -
88 //
│ │ │ │ -
89 // Options associated with the actual refinement operation, which may end up
│ │ │ │ -
90 // quite involved if we want to allow for the refinement of data that is not
│ │ │ │ -
91 // of interest to be suppressed. For now we have:
│ │ │ │ -
92 //
│ │ │ │ -
93 // "sparse": the alternative to uniform refinement, which requires that
│ │ │ │ -
94 // components be previously selected/marked to be included.
│ │ │ │ -
95 //
│ │ │ │ -
96 // "minimal topology": this is one that may get broken down into a finer
│ │ │ │ -
97 // set of options. It suppresses "full topology" in the child level
│ │ │ │ -
98 // and only generates what is minimally necessary for interpolation --
│ │ │ │ -
99 // which requires at least the face-vertices for faces, but also the
│ │ │ │ -
100 // vertex-faces for any face-varying channels present. So it will
│ │ │ │ -
101 // generate one or two of the six possible topological relations.
│ │ │ │ -
102 //
│ │ │ │ -
103 // These are strictly controlled right now, e.g. for sparse refinement, we
│ │ │ │ -
104 // currently enforce full topology at the finest level to allow for subsequent
│ │ │ │ -
105 // patch construction.
│ │ │ │ -
106 //
│ │ │ │ -
107 struct Options {
│ │ │ │ -
108 Options() : _sparse(false),
│ │ │ │ -
109 _faceVertsFirst(false),
│ │ │ │ -
110 _minimalTopology(false)
│ │ │ │ -
111 { }
│ │ │ │ -
112
│ │ │ │ -
113 unsigned int _sparse : 1;
│ │ │ │ -
114 unsigned int _faceVertsFirst : 1;
│ │ │ │ -
115 unsigned int _minimalTopology : 1;
│ │ │ │ -
116
│ │ │ │ -
117 // Still under consideration:
│ │ │ │ -
118 //unsigned int _childToParentMap : 1;
│ │ │ │ -
119 };
│ │ │ │ -
120
│ │ │ │ -
121 void refine(Options options = Options());
│ │ │ │ -
122
│ │ │ │ -
123 bool hasFaceVerticesFirst() const { return _faceVertsFirst; }
│ │ │ │ -
124
│ │ │ │ -
125public:
│ │ │ │ -
126 //
│ │ │ │ -
127 // Access to members -- some testing classes (involving vertex interpolation)
│ │ │ │ -
128 // currently make use of these:
│ │ │ │ -
129 //
│ │ │ │ -
130 int getNumChildFacesFromFaces() const { return _childFaceFromFaceCount; }
│ │ │ │ -
131 int getNumChildEdgesFromFaces() const { return _childEdgeFromFaceCount; }
│ │ │ │ -
132 int getNumChildEdgesFromEdges() const { return _childEdgeFromEdgeCount; }
│ │ │ │ -
133 int getNumChildVerticesFromFaces() const { return _childVertFromFaceCount; }
│ │ │ │ -
134 int getNumChildVerticesFromEdges() const { return _childVertFromEdgeCount; }
│ │ │ │ -
135 int getNumChildVerticesFromVertices() const { return _childVertFromVertCount; }
│ │ │ │ -
136
│ │ │ │ -
137 Index getFirstChildFaceFromFaces() const { return _firstChildFaceFromFace; }
│ │ │ │ -
138 Index getFirstChildEdgeFromFaces() const { return _firstChildEdgeFromFace; }
│ │ │ │ -
139 Index getFirstChildEdgeFromEdges() const { return _firstChildEdgeFromEdge; }
│ │ │ │ -
140 Index getFirstChildVertexFromFaces() const { return _firstChildVertFromFace; }
│ │ │ │ -
141 Index getFirstChildVertexFromEdges() const { return _firstChildVertFromEdge; }
│ │ │ │ -
142 Index getFirstChildVertexFromVertices() const { return _firstChildVertFromVert; }
│ │ │ │ -
143
│ │ │ │ -
144 Index getFaceChildVertex(Index f) const { return _faceChildVertIndex[f]; }
│ │ │ │ -
145 Index getEdgeChildVertex(Index e) const { return _edgeChildVertIndex[e]; }
│ │ │ │ -
146 Index getVertexChildVertex(Index v) const { return _vertChildVertIndex[v]; }
│ │ │ │ -
147
│ │ │ │ -
148 ConstIndexArray getFaceChildFaces(Index parentFace) const;
│ │ │ │ -
149 ConstIndexArray getFaceChildEdges(Index parentFace) const;
│ │ │ │ -
150 ConstIndexArray getEdgeChildEdges(Index parentEdge) const;
│ │ │ │ -
151
│ │ │ │ -
152 // Child-to-parent relationships
│ │ │ │ -
153 bool isChildVertexComplete(Index v) const { return ! _childVertexTag[v]._incomplete; }
│ │ │ │ -
154
│ │ │ │ -
155 Index getChildFaceParentFace(Index f) const { return _childFaceParentIndex[f]; }
│ │ │ │ -
156 int getChildFaceInParentFace(Index f) const { return _childFaceTag[f]._indexInParent; }
│ │ │ │ -
157
│ │ │ │ -
158 Index getChildEdgeParentIndex(Index e) const { return _childEdgeParentIndex[e]; }
│ │ │ │ -
159
│ │ │ │ -
160 Index getChildVertexParentIndex(Index v) const { return _childVertexParentIndex[v]; }
│ │ │ │ -
161
│ │ │ │ -
162//
│ │ │ │ -
163// Modifiers intended for internal/protected use:
│ │ │ │ -
164//
│ │ │ │ -
165public:
│ │ │ │ -
166
│ │ │ │ -
167 IndexArray getFaceChildFaces(Index parentFace);
│ │ │ │ -
168 IndexArray getFaceChildEdges(Index parentFace);
│ │ │ │ -
169 IndexArray getEdgeChildEdges(Index parentEdge);
│ │ │ │ -
170
│ │ │ │ -
171public:
│ │ │ │ -
172 //
│ │ │ │ -
173 // Tags have now been added per-component in Level, but there is additional need to tag
│ │ │ │ -
174 // components within Refinement -- we can't tag the parent level components for any
│ │ │ │ -
175 // refinement (in order to keep it const) and tags associated with children that are
│ │ │ │ -
176 // specific to the child-to-parent mapping may not be warranted in the child level.
│ │ │ │ -
177 //
│ │ │ │ -
178 // Parent tags are only required for sparse refinement. The main property to tag is
│ │ │ │ -
179 // whether a component was selected, and so a single SparseTag is used for all three
│ │ │ │ -
180 // component types. Tagging if a component is "transitional" is also useful. This may
│ │ │ │ -
181 // only be necessary for edges but is currently packed into a mask per-edge for faces,
│ │ │ │ -
182 // which could be deferred, in which case "transitional" could be a single bit.
│ │ │ │ -
183 //
│ │ │ │ -
184 // Child tags are part of the child-to-parent mapping, which consists of the parent
│ │ │ │ -
185 // component index for each child component, plus a tag for the child indicating more
│ │ │ │ -
186 // about its relationship to its parent, e.g. is it completely defined, what the parent
│ │ │ │ -
187 // component type is, what is the index of the child within its parent, etc.
│ │ │ │ -
188 //
│ │ │ │ -
189 struct SparseTag {
│ │ │ │ -
190 SparseTag() : _selected(0), _transitional(0) { }
│ │ │ │ -
191
│ │ │ │ -
192 unsigned char _selected : 1; // component specifically selected for refinement
│ │ │ │ -
193 unsigned char _transitional : 4; // adjacent to a refined component (4-bits for face)
│ │ │ │ -
194 };
│ │ │ │ -
195
│ │ │ │ -
196 struct ChildTag {
│ │ │ │ -
197 ChildTag() { }
│ │ │ │ -
198
│ │ │ │ -
199 unsigned char _incomplete : 1; // incomplete neighborhood to represent limit of parent
│ │ │ │ -
200 unsigned char _parentType : 2; // type of parent component: vertex, edge or face
│ │ │ │ -
201 unsigned char _indexInParent : 2; // index of child wrt parent: 0-3, or iterative if N > 4
│ │ │ │ -
202 };
│ │ │ │ -
203
│ │ │ │ -
204 // Methods to access and modify tags:
│ │ │ │ -
205 SparseTag const & getParentFaceSparseTag( Index f) const { return _parentFaceTag[f]; }
│ │ │ │ -
206 SparseTag const & getParentEdgeSparseTag( Index e) const { return _parentEdgeTag[e]; }
│ │ │ │ -
207 SparseTag const & getParentVertexSparseTag(Index v) const { return _parentVertexTag[v]; }
│ │ │ │ -
208
│ │ │ │ -
209 SparseTag & getParentFaceSparseTag( Index f) { return _parentFaceTag[f]; }
│ │ │ │ -
210 SparseTag & getParentEdgeSparseTag( Index e) { return _parentEdgeTag[e]; }
│ │ │ │ -
211 SparseTag & getParentVertexSparseTag(Index v) { return _parentVertexTag[v]; }
│ │ │ │ -
212
│ │ │ │ -
213 ChildTag const & getChildFaceTag( Index f) const { return _childFaceTag[f]; }
│ │ │ │ -
214 ChildTag const & getChildEdgeTag( Index e) const { return _childEdgeTag[e]; }
│ │ │ │ -
215 ChildTag const & getChildVertexTag(Index v) const { return _childVertexTag[v]; }
│ │ │ │ -
216
│ │ │ │ -
217 ChildTag & getChildFaceTag( Index f) { return _childFaceTag[f]; }
│ │ │ │ -
218 ChildTag & getChildEdgeTag( Index e) { return _childEdgeTag[e]; }
│ │ │ │ -
219 ChildTag & getChildVertexTag(Index v) { return _childVertexTag[v]; }
│ │ │ │ -
220
│ │ │ │ -
221// Remaining methods should really be protected -- for use by subclasses...
│ │ │ │ -
222public:
│ │ │ │ -
223 //
│ │ │ │ -
224 // Methods involved in constructing the parent-to-child mapping -- when the
│ │ │ │ -
225 // refinement is sparse, additional methods are needed to identify the selection:
│ │ │ │ -
226 //
│ │ │ │ -
227 void populateParentToChildMapping();
│ │ │ │ -
228 void populateParentChildIndices();
│ │ │ │ -
229 void printParentToChildMapping() const;
│ │ │ │ -
230
│ │ │ │ -
231 virtual void allocateParentChildIndices() = 0;
│ │ │ │ -
232
│ │ │ │ -
233 // Supporting method for sparse refinement:
│ │ │ │ -
234 void initializeSparseSelectionTags();
│ │ │ │ -
235 void markSparseChildComponentIndices();
│ │ │ │ -
236 void markSparseVertexChildren();
│ │ │ │ -
237 void markSparseEdgeChildren();
│ │ │ │ -
238
│ │ │ │ -
239 virtual void markSparseFaceChildren() = 0;
│ │ │ │ -
240
│ │ │ │ -
241 void initializeChildComponentCounts();
│ │ │ │ -
242
│ │ │ │ -
243 //
│ │ │ │ -
244 // Methods involved in constructing the child-to-parent mapping:
│ │ │ │ -
245 //
│ │ │ │ -
246 void populateChildToParentMapping();
│ │ │ │ -
247
│ │ │ │ -
248 void populateFaceParentVectors(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
249 void populateFaceParentFromParentFaces(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
250
│ │ │ │ -
251 void populateEdgeParentVectors(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
252 void populateEdgeParentFromParentFaces(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
253 void populateEdgeParentFromParentEdges(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
254
│ │ │ │ -
255 void populateVertexParentVectors(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
256 void populateVertexParentFromParentFaces(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
257 void populateVertexParentFromParentEdges(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
258 void populateVertexParentFromParentVertices(ChildTag const initialChildTags[2][4]);
│ │ │ │ -
259
│ │ │ │ -
260 //
│ │ │ │ -
261 // Methods involved in propagating component tags from parent to child:
│ │ │ │ -
262 //
│ │ │ │ -
263 void propagateComponentTags();
│ │ │ │ -
264
│ │ │ │ -
265 void populateFaceTagVectors();
│ │ │ │ -
266 void populateFaceTagsFromParentFaces();
│ │ │ │ -
267
│ │ │ │ -
268 void populateEdgeTagVectors();
│ │ │ │ -
269 void populateEdgeTagsFromParentFaces();
│ │ │ │ -
270 void populateEdgeTagsFromParentEdges();
│ │ │ │ -
271
│ │ │ │ -
272 void populateVertexTagVectors();
│ │ │ │ -
273 void populateVertexTagsFromParentFaces();
│ │ │ │ -
274 void populateVertexTagsFromParentEdges();
│ │ │ │ -
275 void populateVertexTagsFromParentVertices();
│ │ │ │ -
276
│ │ │ │ -
277 //
│ │ │ │ -
278 // Methods (and types) involved in subdividing the topology -- though not
│ │ │ │ -
279 // fully exploited, any subset of the 6 relations can be generated:
│ │ │ │ -
280 //
│ │ │ │ -
281 struct Relations {
│ │ │ │ -
282 unsigned int _faceVertices : 1;
│ │ │ │ -
283 unsigned int _faceEdges : 1;
│ │ │ │ -
284 unsigned int _edgeVertices : 1;
│ │ │ │ -
285 unsigned int _edgeFaces : 1;
│ │ │ │ -
286 unsigned int _vertexFaces : 1;
│ │ │ │ -
287 unsigned int _vertexEdges : 1;
│ │ │ │ -
288
│ │ │ │ -
289 void setAll(bool enable) {
│ │ │ │ -
290 _faceVertices = enable;
│ │ │ │ -
291 _faceEdges = enable;
│ │ │ │ -
292 _edgeVertices = enable;
│ │ │ │ -
293 _edgeFaces = enable;
│ │ │ │ -
294 _vertexFaces = enable;
│ │ │ │ -
295 _vertexEdges = enable;
│ │ │ │ -
296 }
│ │ │ │ -
297 };
│ │ │ │ -
298
│ │ │ │ -
299 void subdivideTopology(Relations const& relationsToSubdivide);
│ │ │ │ -
300
│ │ │ │ -
301 virtual void populateFaceVertexRelation() = 0;
│ │ │ │ -
302 virtual void populateFaceEdgeRelation() = 0;
│ │ │ │ -
303 virtual void populateEdgeVertexRelation() = 0;
│ │ │ │ -
304 virtual void populateEdgeFaceRelation() = 0;
│ │ │ │ -
305 virtual void populateVertexFaceRelation() = 0;
│ │ │ │ -
306 virtual void populateVertexEdgeRelation() = 0;
│ │ │ │ -
307
│ │ │ │ -
308 //
│ │ │ │ -
309 // Methods involved in subdividing and inspecting sharpness values:
│ │ │ │ -
310 //
│ │ │ │ -
311 void subdivideSharpnessValues();
│ │ │ │ -
312
│ │ │ │ -
313 void subdivideVertexSharpness();
│ │ │ │ -
314 void subdivideEdgeSharpness();
│ │ │ │ -
315 void reclassifySemisharpVertices();
│ │ │ │ -
316
│ │ │ │ -
317 //
│ │ │ │ -
318 // Methods involved in subdividing face-varying topology:
│ │ │ │ -
319 //
│ │ │ │ -
320 void subdivideFVarChannels();
│ │ │ │ -
321
│ │ │ │ -
322protected:
│ │ │ │ -
323 // A debug method of Level prints a Refinement (should really change this)
│ │ │ │ -
324 friend void Level::print(const Refinement *) const;
│ │ │ │ -
325
│ │ │ │ -
326 //
│ │ │ │ -
327 // Data members -- the logical grouping of some of these (and methods that make use
│ │ │ │ -
328 // of them) may lead to grouping them into a few utility classes or structs...
│ │ │ │ -
329 //
│ │ │ │ -
330
│ │ │ │ -
331 // Defined on construction:
│ │ │ │ -
332 Level const * _parent;
│ │ │ │ -
333 Level * _child;
│ │ │ │ -
334 Sdc::Options _options;
│ │ │ │ -
335
│ │ │ │ -
336 // Defined by the subclass:
│ │ │ │ -
337 Sdc::Split _splitType;
│ │ │ │ -
338 int _regFaceSize;
│ │ │ │ -
339
│ │ │ │ -
340 // Determined by the refinement options:
│ │ │ │ -
341 bool _uniform;
│ │ │ │ -
342 bool _faceVertsFirst;
│ │ │ │ -
343
│ │ │ │ -
344 //
│ │ │ │ -
345 // Inventory and ordering of the types of child components:
│ │ │ │ -
346 //
│ │ │ │ -
347 int _childFaceFromFaceCount; // arguably redundant (all faces originate from faces)
│ │ │ │ -
348 int _childEdgeFromFaceCount;
│ │ │ │ -
349 int _childEdgeFromEdgeCount;
│ │ │ │ -
350 int _childVertFromFaceCount;
│ │ │ │ -
351 int _childVertFromEdgeCount;
│ │ │ │ -
352 int _childVertFromVertCount;
│ │ │ │ -
353
│ │ │ │ -
354 int _firstChildFaceFromFace; // arguably redundant (all faces originate from faces)
│ │ │ │ -
355 int _firstChildEdgeFromFace;
│ │ │ │ -
356 int _firstChildEdgeFromEdge;
│ │ │ │ -
357 int _firstChildVertFromFace;
│ │ │ │ -
358 int _firstChildVertFromEdge;
│ │ │ │ -
359 int _firstChildVertFromVert;
│ │ │ │ -
360
│ │ │ │ -
361 //
│ │ │ │ -
362 // The parent-to-child mapping:
│ │ │ │ -
363 // These are vectors sized according to the number of parent components (and
│ │ │ │ -
364 // their topology) that contain references/indices to the child components that
│ │ │ │ -
365 // result from them by refinement. When refinement is sparse, parent components
│ │ │ │ -
366 // that have not spawned all child components will have their missing children
│ │ │ │ -
367 // marked as invalid.
│ │ │ │ -
368 //
│ │ │ │ -
369 // NOTE the "Array" members here. Often vectors within the Level can be shared
│ │ │ │ -
370 // with the Refinement, and an Array instance is used to do so. If not shared
│ │ │ │ -
371 // the subclass just initializes the Array members after allocating its own local
│ │ │ │ -
372 // vector members.
│ │ │ │ -
373 //
│ │ │ │ -
374 IndexArray _faceChildFaceCountsAndOffsets;
│ │ │ │ -
375 IndexArray _faceChildEdgeCountsAndOffsets;
│ │ │ │ -
376
│ │ │ │ -
377 IndexVector _faceChildFaceIndices; // *cannot* always use face-vert counts/offsets
│ │ │ │ -
378 IndexVector _faceChildEdgeIndices; // can use face-vert counts/offsets
│ │ │ │ -
379 IndexVector _faceChildVertIndex;
│ │ │ │ -
380
│ │ │ │ -
381 IndexVector _edgeChildEdgeIndices; // trivial/corresponding pair for each
│ │ │ │ -
382 IndexVector _edgeChildVertIndex;
│ │ │ │ -
383
│ │ │ │ -
384 IndexVector _vertChildVertIndex;
│ │ │ │ -
385
│ │ │ │ -
386 //
│ │ │ │ -
387 // The child-to-parent mapping:
│ │ │ │ -
388 //
│ │ │ │ -
389 IndexVector _childFaceParentIndex;
│ │ │ │ -
390 IndexVector _childEdgeParentIndex;
│ │ │ │ -
391 IndexVector _childVertexParentIndex;
│ │ │ │ -
392
│ │ │ │ -
393 std::vector<ChildTag> _childFaceTag;
│ │ │ │ -
394 std::vector<ChildTag> _childEdgeTag;
│ │ │ │ -
395 std::vector<ChildTag> _childVertexTag;
│ │ │ │ -
396
│ │ │ │ -
397 //
│ │ │ │ -
398 // Tags for sparse selection of components:
│ │ │ │ -
399 //
│ │ │ │ -
400 std::vector<SparseTag> _parentFaceTag;
│ │ │ │ -
401 std::vector<SparseTag> _parentEdgeTag;
│ │ │ │ -
402 std::vector<SparseTag> _parentVertexTag;
│ │ │ │ -
403
│ │ │ │ -
404 //
│ │ │ │ -
405 // Refinement data for face-varying channels present in the Levels being refined:
│ │ │ │ -
406 //
│ │ │ │ -
407 std::vector<FVarRefinement*> _fvarChannels;
│ │ │ │ -
408};
│ │ │ │ -
409
│ │ │ │ -
410inline ConstIndexArray
│ │ │ │ -
411Refinement::getFaceChildFaces(Index parentFace) const {
│ │ │ │ -
412
│ │ │ │ -
413 return ConstIndexArray(&_faceChildFaceIndices[_faceChildFaceCountsAndOffsets[2*parentFace+1]],
│ │ │ │ -
414 _faceChildFaceCountsAndOffsets[2*parentFace]);
│ │ │ │ -
415}
│ │ │ │ -
416
│ │ │ │ -
417inline IndexArray
│ │ │ │ -
418Refinement::getFaceChildFaces(Index parentFace) {
│ │ │ │ -
419
│ │ │ │ -
420 return IndexArray(&_faceChildFaceIndices[_faceChildFaceCountsAndOffsets[2*parentFace+1]],
│ │ │ │ -
421 _faceChildFaceCountsAndOffsets[2*parentFace]);
│ │ │ │ -
422}
│ │ │ │ -
423
│ │ │ │ -
424inline ConstIndexArray
│ │ │ │ -
425Refinement::getFaceChildEdges(Index parentFace) const {
│ │ │ │ -
426
│ │ │ │ -
427 return ConstIndexArray(&_faceChildEdgeIndices[_faceChildEdgeCountsAndOffsets[2*parentFace+1]],
│ │ │ │ -
428 _faceChildEdgeCountsAndOffsets[2*parentFace]);
│ │ │ │ -
429}
│ │ │ │ -
430inline IndexArray
│ │ │ │ -
431Refinement::getFaceChildEdges(Index parentFace) {
│ │ │ │ -
432
│ │ │ │ -
433 return IndexArray(&_faceChildEdgeIndices[_faceChildEdgeCountsAndOffsets[2*parentFace+1]],
│ │ │ │ -
434 _faceChildEdgeCountsAndOffsets[2*parentFace]);
│ │ │ │ -
435}
│ │ │ │ -
436
│ │ │ │ -
437inline ConstIndexArray
│ │ │ │ -
438Refinement::getEdgeChildEdges(Index parentEdge) const {
│ │ │ │ -
439
│ │ │ │ -
440 return ConstIndexArray(&_edgeChildEdgeIndices[parentEdge*2], 2);
│ │ │ │ -
441}
│ │ │ │ -
442
│ │ │ │ -
443inline IndexArray
│ │ │ │ -
444Refinement::getEdgeChildEdges(Index parentEdge) {
│ │ │ │ -
445
│ │ │ │ -
446 return IndexArray(&_edgeChildEdgeIndices[parentEdge*2], 2);
│ │ │ │ -
447}
│ │ │ │ -
448
│ │ │ │ -
449} // end namespace internal
│ │ │ │ -
450} // end namespace Vtr
│ │ │ │ -
451
│ │ │ │ -
452} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
453using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
454} // end namespace OpenSubdiv
│ │ │ │ -
455
│ │ │ │ -
456#endif /* OPENSUBDIV3_VTR_REFINEMENT_H */
│ │ │ │ - │ │ │ │ +
83 void markVertexSelected(Index pVertex) const { _refine->getParentVertexSparseTag(pVertex)._selected = true; }
│ │ │ │ +
84 void markEdgeSelected( Index pEdge) const { _refine->getParentEdgeSparseTag(pEdge)._selected = true; }
│ │ │ │ +
85 void markFaceSelected( Index pFace) const { _refine->getParentFaceSparseTag(pFace)._selected = true; }
│ │ │ │ +
86
│ │ │ │ +
87 void initializeSelection();
│ │ │ │ +
88
│ │ │ │ +
89private:
│ │ │ │ +
90 Refinement* _refine;
│ │ │ │ +
91 bool _selected;
│ │ │ │ +
92};
│ │ │ │ +
93
│ │ │ │ +
94} // end namespace internal
│ │ │ │ +
95} // end namespace Vtr
│ │ │ │ +
96
│ │ │ │ +
97} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
98using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
99} // end namespace OpenSubdiv
│ │ │ │ +
100
│ │ │ │ +
101#endif /* OPENSUBDIV3_VTR_SPARSE_SELECTOR_H */
│ │ │ │ + │ │ │ │ │ │ │ │ -
std::vector< Index > IndexVector
Definition types.h:77
│ │ │ │ -
ConstArray< Index > ConstIndexArray
Definition types.h:80
│ │ │ │ - │ │ │ │ -
Split
Enumerated type for all face splitting schemes.
Definition types.h:47
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -refinement.h │ │ │ │ │ +sparseSelector.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -23,545 +23,111 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_VTR_REFINEMENT_H │ │ │ │ │ -25#define OPENSUBDIV3_VTR_REFINEMENT_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_VTR_SPARSE_SELECTOR_H │ │ │ │ │ +25#define OPENSUBDIV3_VTR_SPARSE_SELECTOR_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ -29#include "../sdc/types.h" │ │ │ │ │ -30#include "../sdc/options.h" │ │ │ │ │ -31#include "../vtr/types.h" │ │ │ │ │ -32#include "../vtr/level.h" │ │ │ │ │ +29#include "../vtr/types.h" │ │ │ │ │ +30#include "../vtr/refinement.h" │ │ │ │ │ +31 │ │ │ │ │ +32#include │ │ │ │ │ 33 │ │ │ │ │ -34#include │ │ │ │ │ -35 │ │ │ │ │ -36// │ │ │ │ │ -37// Declaration for the main refinement class (Refinement) and its pre- │ │ │ │ │ -requisites: │ │ │ │ │ -38// │ │ │ │ │ -39namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -40namespace OPENSUBDIV_VERSION { │ │ │ │ │ -41 │ │ │ │ │ -42namespace Vtr { │ │ │ │ │ -43namespace internal { │ │ │ │ │ -44 │ │ │ │ │ -45class FVarRefinement; │ │ │ │ │ -46 │ │ │ │ │ +34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +35namespace OPENSUBDIV_VERSION { │ │ │ │ │ +36 │ │ │ │ │ +37namespace Vtr { │ │ │ │ │ +38namespace internal { │ │ │ │ │ +39 │ │ │ │ │ +40// │ │ │ │ │ +41// SparseSelector: │ │ │ │ │ +42// Class supporting "selection" of components in a Level for sparse │ │ │ │ │ +Refinement. │ │ │ │ │ +43// The term "selection" here implies interest in the limit for that │ │ │ │ │ +component, i.e. │ │ │ │ │ +44// the limit point for a selected vertex, the limit patch for a face, etc. So │ │ │ │ │ +this │ │ │ │ │ +45// class is responsible for ensuring that all neighboring components required │ │ │ │ │ +to │ │ │ │ │ +46// support the limit of those selected are included in the refinement. │ │ │ │ │ 47// │ │ │ │ │ -48// Refinement: │ │ │ │ │ -49// A refinement is a mapping between two levels -- relating the components in │ │ │ │ │ -the original │ │ │ │ │ -50// (parent) level to the one refined (child). The refinement may be complete │ │ │ │ │ -(uniform) or sparse │ │ │ │ │ -51// (adaptive or otherwise selective), so not all components in the parent │ │ │ │ │ -level will spawn │ │ │ │ │ -52// components in the child level. │ │ │ │ │ -53// │ │ │ │ │ -54// Refinement is an abstract class and expects subclasses corresponding to │ │ │ │ │ -the different types │ │ │ │ │ -55// of topological splits that the supported subdivision schemes collectively │ │ │ │ │ -require, i.e. those │ │ │ │ │ -56// listed in Sdc::SplitType. Note the virtual requirements expected of the │ │ │ │ │ -subclasses in the list │ │ │ │ │ -57// of protected methods -- they differ mainly in the topology that is created │ │ │ │ │ -in the child Level │ │ │ │ │ -58// and not the propagation of tags through refinement, subdivision of │ │ │ │ │ -sharpness values or the │ │ │ │ │ -59// treatment of face-varying data. The primary subclasses are QuadRefinement │ │ │ │ │ -and TriRefinement. │ │ │ │ │ -60// │ │ │ │ │ -61// At a high level, all that is necessary in terms of interface is to │ │ │ │ │ -construct, initialize │ │ │ │ │ -62// (linking the two levels), optionally select components for sparse │ │ │ │ │ -refinement (via use of the │ │ │ │ │ -63// SparseSelector) and call the refine() method. This usage is expected of │ │ │ │ │ -Far::TopologyRefiner. │ │ │ │ │ -64// │ │ │ │ │ -65// Since we really want this class to be restricted from public access │ │ │ │ │ -eventually, all methods │ │ │ │ │ -66// begin with lower case (as is the convention for protected methods) and the │ │ │ │ │ -list of friends │ │ │ │ │ -67// will be maintained more strictly. │ │ │ │ │ -68// │ │ │ │ │ -69class Refinement { │ │ │ │ │ -70 │ │ │ │ │ -71public: │ │ │ │ │ -72 Refinement(Level const & parent, Level & child, Sdc::Options const& │ │ │ │ │ -schemeOptions); │ │ │ │ │ -73 virtual ~Refinement(); │ │ │ │ │ -74 │ │ │ │ │ -75 Level const& parent() const { return *_parent; } │ │ │ │ │ -76 Level const& child() const { return *_child; } │ │ │ │ │ -77 Level& child() { return *_child; } │ │ │ │ │ +48// This class is associated with (and constructed given) a Refinement and its │ │ │ │ │ +role │ │ │ │ │ +49// is to initialize that Refinement instance for eventual sparse refinement. │ │ │ │ │ +So it │ │ │ │ │ +50// is a friend of and expected to modify the Refinement as part of the │ │ │ │ │ +selection. │ │ │ │ │ +51// Given its simplicity and scope it may be worth nesting it in Vtr:: │ │ │ │ │ +Refinement. │ │ │ │ │ +52// │ │ │ │ │ +53// While all three component types -- vertices, edges and faces -- can be │ │ │ │ │ +selected, │ │ │ │ │ +54// only selection of faces is currently used and actively supported as part │ │ │ │ │ +of the │ │ │ │ │ +55// feature-adaptive refinement. │ │ │ │ │ +56// │ │ │ │ │ +57class SparseSelector { │ │ │ │ │ +58 │ │ │ │ │ +59public: │ │ │ │ │ +60 SparseSelector(Refinement& refine) : _refine(&refine), _selected(false) { } │ │ │ │ │ +61 ~SparseSelector() { } │ │ │ │ │ +62 │ │ │ │ │ +63 void setRefinement(Refinement& refine) { _refine = &refine; } │ │ │ │ │ +64 Refinement& getRefinement() const { return *_refine; } │ │ │ │ │ +65 │ │ │ │ │ +66 bool isSelectionEmpty() const { return !_selected; } │ │ │ │ │ +67 │ │ │ │ │ +68 // │ │ │ │ │ +69 // Methods for selecting (and marking) components for refinement. All │ │ │ │ │ +component indices │ │ │ │ │ +70 // refer to components in the parent: │ │ │ │ │ +71 // │ │ │ │ │ +72 void selectVertex(_I_n_d_e_x pVertex); │ │ │ │ │ +73 void selectEdge( _I_n_d_e_x pEdge); │ │ │ │ │ +74 void selectFace( _I_n_d_e_x pFace); │ │ │ │ │ +75 │ │ │ │ │ +76private: │ │ │ │ │ +77 SparseSelector() : _refine(0), _selected(false) { } │ │ │ │ │ 78 │ │ │ │ │ -79 _S_d_c_:_:_S_p_l_i_t getSplitType() const { return _splitType; } │ │ │ │ │ -80 int getRegularFaceSize() const { return _regFaceSize; } │ │ │ │ │ -81 Sdc::Options getOptions() const { return _options; } │ │ │ │ │ +79 bool wasVertexSelected(_I_n_d_e_x pVertex) const { return _refine- │ │ │ │ │ +>getParentVertexSparseTag(pVertex)._selected; } │ │ │ │ │ +80 bool wasEdgeSelected( _I_n_d_e_x pEdge) const { return _refine- │ │ │ │ │ +>getParentEdgeSparseTag(pEdge)._selected; } │ │ │ │ │ +81 bool wasFaceSelected( _I_n_d_e_x pFace) const { return _refine- │ │ │ │ │ +>getParentFaceSparseTag(pFace)._selected; } │ │ │ │ │ 82 │ │ │ │ │ -83 // Face-varying: │ │ │ │ │ -84 int getNumFVarChannels() const { return (int) _fvarChannels.size(); } │ │ │ │ │ -85 │ │ │ │ │ -86 FVarRefinement const & getFVarRefinement(int c) const { return │ │ │ │ │ -*_fvarChannels[c]; } │ │ │ │ │ -87 │ │ │ │ │ -88 // │ │ │ │ │ -89 // Options associated with the actual refinement operation, which may end up │ │ │ │ │ -90 // quite involved if we want to allow for the refinement of data that is not │ │ │ │ │ -91 // of interest to be suppressed. For now we have: │ │ │ │ │ -92 // │ │ │ │ │ -93 // "sparse": the alternative to uniform refinement, which requires that │ │ │ │ │ -94 // components be previously selected/marked to be included. │ │ │ │ │ -95 // │ │ │ │ │ -96 // "minimal topology": this is one that may get broken down into a finer │ │ │ │ │ -97 // set of options. It suppresses "full topology" in the child level │ │ │ │ │ -98 // and only generates what is minimally necessary for interpolation -- │ │ │ │ │ -99 // which requires at least the face-vertices for faces, but also the │ │ │ │ │ -100 // vertex-faces for any face-varying channels present. So it will │ │ │ │ │ -101 // generate one or two of the six possible topological relations. │ │ │ │ │ -102 // │ │ │ │ │ -103 // These are strictly controlled right now, e.g. for sparse refinement, we │ │ │ │ │ -104 // currently enforce full topology at the finest level to allow for │ │ │ │ │ -subsequent │ │ │ │ │ -105 // patch construction. │ │ │ │ │ -106 // │ │ │ │ │ -107 struct Options { │ │ │ │ │ -108 Options() : _sparse(false), │ │ │ │ │ -109 _faceVertsFirst(false), │ │ │ │ │ -110 _minimalTopology(false) │ │ │ │ │ -111 { } │ │ │ │ │ -112 │ │ │ │ │ -113 unsigned int _sparse : 1; │ │ │ │ │ -114 unsigned int _faceVertsFirst : 1; │ │ │ │ │ -115 unsigned int _minimalTopology : 1; │ │ │ │ │ -116 │ │ │ │ │ -117 // Still under consideration: │ │ │ │ │ -118 //unsigned int _childToParentMap : 1; │ │ │ │ │ -119 }; │ │ │ │ │ -120 │ │ │ │ │ -121 void refine(Options options = Options()); │ │ │ │ │ -122 │ │ │ │ │ -123 bool hasFaceVerticesFirst() const { return _faceVertsFirst; } │ │ │ │ │ -124 │ │ │ │ │ -125public: │ │ │ │ │ -126 // │ │ │ │ │ -127 // Access to members -- some testing classes (involving vertex │ │ │ │ │ -interpolation) │ │ │ │ │ -128 // currently make use of these: │ │ │ │ │ -129 // │ │ │ │ │ -130 int getNumChildFacesFromFaces() const { return _childFaceFromFaceCount; } │ │ │ │ │ -131 int getNumChildEdgesFromFaces() const { return _childEdgeFromFaceCount; } │ │ │ │ │ -132 int getNumChildEdgesFromEdges() const { return _childEdgeFromEdgeCount; } │ │ │ │ │ -133 int getNumChildVerticesFromFaces() const { return _childVertFromFaceCount; │ │ │ │ │ -} │ │ │ │ │ -134 int getNumChildVerticesFromEdges() const { return _childVertFromEdgeCount; │ │ │ │ │ -} │ │ │ │ │ -135 int getNumChildVerticesFromVertices() const { return │ │ │ │ │ -_childVertFromVertCount; } │ │ │ │ │ -136 │ │ │ │ │ -137 _I_n_d_e_x getFirstChildFaceFromFaces() const { return _firstChildFaceFromFace; │ │ │ │ │ -} │ │ │ │ │ -138 _I_n_d_e_x getFirstChildEdgeFromFaces() const { return _firstChildEdgeFromFace; │ │ │ │ │ -} │ │ │ │ │ -139 _I_n_d_e_x getFirstChildEdgeFromEdges() const { return _firstChildEdgeFromEdge; │ │ │ │ │ -} │ │ │ │ │ -140 _I_n_d_e_x getFirstChildVertexFromFaces() const { return │ │ │ │ │ -_firstChildVertFromFace; } │ │ │ │ │ -141 _I_n_d_e_x getFirstChildVertexFromEdges() const { return │ │ │ │ │ -_firstChildVertFromEdge; } │ │ │ │ │ -142 _I_n_d_e_x getFirstChildVertexFromVertices() const { return │ │ │ │ │ -_firstChildVertFromVert; } │ │ │ │ │ -143 │ │ │ │ │ -144 _I_n_d_e_x getFaceChildVertex(_I_n_d_e_x f) const { return _faceChildVertIndex[f]; } │ │ │ │ │ -145 _I_n_d_e_x getEdgeChildVertex(_I_n_d_e_x e) const { return _edgeChildVertIndex[e]; } │ │ │ │ │ -146 _I_n_d_e_x getVertexChildVertex(_I_n_d_e_x v) const { return _vertChildVertIndex[v]; │ │ │ │ │ -} │ │ │ │ │ -147 │ │ │ │ │ -148 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceChildFaces(_I_n_d_e_x parentFace) const; │ │ │ │ │ -149 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceChildEdges(_I_n_d_e_x parentFace) const; │ │ │ │ │ -150 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getEdgeChildEdges(_I_n_d_e_x parentEdge) const; │ │ │ │ │ -151 │ │ │ │ │ -152 // Child-to-parent relationships │ │ │ │ │ -153 bool isChildVertexComplete(_I_n_d_e_x v) const { return ! _childVertexTag │ │ │ │ │ -[v]._incomplete; } │ │ │ │ │ -154 │ │ │ │ │ -155 _I_n_d_e_x getChildFaceParentFace(_I_n_d_e_x f) const { return _childFaceParentIndex │ │ │ │ │ -[f]; } │ │ │ │ │ -156 int getChildFaceInParentFace(_I_n_d_e_x f) const { return _childFaceTag │ │ │ │ │ -[f]._indexInParent; } │ │ │ │ │ -157 │ │ │ │ │ -158 _I_n_d_e_x getChildEdgeParentIndex(_I_n_d_e_x e) const { return _childEdgeParentIndex │ │ │ │ │ -[e]; } │ │ │ │ │ -159 │ │ │ │ │ -160 _I_n_d_e_x getChildVertexParentIndex(_I_n_d_e_x v) const { return │ │ │ │ │ -_childVertexParentIndex[v]; } │ │ │ │ │ -161 │ │ │ │ │ -162// │ │ │ │ │ -163// Modifiers intended for internal/protected use: │ │ │ │ │ -164// │ │ │ │ │ -165public: │ │ │ │ │ -166 │ │ │ │ │ -167 _I_n_d_e_x_A_r_r_a_y getFaceChildFaces(_I_n_d_e_x parentFace); │ │ │ │ │ -168 _I_n_d_e_x_A_r_r_a_y getFaceChildEdges(_I_n_d_e_x parentFace); │ │ │ │ │ -169 _I_n_d_e_x_A_r_r_a_y getEdgeChildEdges(_I_n_d_e_x parentEdge); │ │ │ │ │ -170 │ │ │ │ │ -171public: │ │ │ │ │ -172 // │ │ │ │ │ -173 // Tags have now been added per-component in Level, but there is additional │ │ │ │ │ -need to tag │ │ │ │ │ -174 // components within Refinement -- we can't tag the parent level components │ │ │ │ │ -for any │ │ │ │ │ -175 // refinement (in order to keep it const) and tags associated with children │ │ │ │ │ -that are │ │ │ │ │ -176 // specific to the child-to-parent mapping may not be warranted in the │ │ │ │ │ -child level. │ │ │ │ │ -177 // │ │ │ │ │ -178 // Parent tags are only required for sparse refinement. The main property │ │ │ │ │ -to tag is │ │ │ │ │ -179 // whether a component was selected, and so a single SparseTag is used for │ │ │ │ │ -all three │ │ │ │ │ -180 // component types. Tagging if a component is "transitional" is also │ │ │ │ │ -useful. This may │ │ │ │ │ -181 // only be necessary for edges but is currently packed into a mask per-edge │ │ │ │ │ -for faces, │ │ │ │ │ -182 // which could be deferred, in which case "transitional" could be a single │ │ │ │ │ -bit. │ │ │ │ │ -183 // │ │ │ │ │ -184 // Child tags are part of the child-to-parent mapping, which consists of │ │ │ │ │ -the parent │ │ │ │ │ -185 // component index for each child component, plus a tag for the child │ │ │ │ │ -indicating more │ │ │ │ │ -186 // about its relationship to its parent, e.g. is it completely defined, │ │ │ │ │ -what the parent │ │ │ │ │ -187 // component type is, what is the index of the child within its parent, │ │ │ │ │ -etc. │ │ │ │ │ -188 // │ │ │ │ │ -189 struct SparseTag { │ │ │ │ │ -190 SparseTag() : _selected(0), _transitional(0) { } │ │ │ │ │ -191 │ │ │ │ │ -192 unsigned char _selected : 1; // component specifically selected for │ │ │ │ │ -refinement │ │ │ │ │ -193 unsigned char _transitional : 4; // adjacent to a refined component (4-bits │ │ │ │ │ -for face) │ │ │ │ │ -194 }; │ │ │ │ │ -195 │ │ │ │ │ -196 struct ChildTag { │ │ │ │ │ -197 ChildTag() { } │ │ │ │ │ -198 │ │ │ │ │ -199 unsigned char _incomplete : 1; // incomplete neighborhood to represent │ │ │ │ │ -limit of parent │ │ │ │ │ -200 unsigned char _parentType : 2; // type of parent component: vertex, edge or │ │ │ │ │ -face │ │ │ │ │ -201 unsigned char _indexInParent : 2; // index of child wrt parent: 0-3, or │ │ │ │ │ -iterative if N > 4 │ │ │ │ │ -202 }; │ │ │ │ │ -203 │ │ │ │ │ -204 // Methods to access and modify tags: │ │ │ │ │ -205 SparseTag const & getParentFaceSparseTag( _I_n_d_e_x f) const { return │ │ │ │ │ -_parentFaceTag[f]; } │ │ │ │ │ -206 SparseTag const & getParentEdgeSparseTag( _I_n_d_e_x e) const { return │ │ │ │ │ -_parentEdgeTag[e]; } │ │ │ │ │ -207 SparseTag const & getParentVertexSparseTag(_I_n_d_e_x v) const { return │ │ │ │ │ -_parentVertexTag[v]; } │ │ │ │ │ -208 │ │ │ │ │ -209 SparseTag & getParentFaceSparseTag( _I_n_d_e_x f) { return _parentFaceTag[f]; } │ │ │ │ │ -210 SparseTag & getParentEdgeSparseTag( _I_n_d_e_x e) { return _parentEdgeTag[e]; } │ │ │ │ │ -211 SparseTag & getParentVertexSparseTag(_I_n_d_e_x v) { return _parentVertexTag[v]; │ │ │ │ │ -} │ │ │ │ │ -212 │ │ │ │ │ -213 ChildTag const & getChildFaceTag( _I_n_d_e_x f) const { return _childFaceTag[f]; │ │ │ │ │ -} │ │ │ │ │ -214 ChildTag const & getChildEdgeTag( _I_n_d_e_x e) const { return _childEdgeTag[e]; │ │ │ │ │ -} │ │ │ │ │ -215 ChildTag const & getChildVertexTag(_I_n_d_e_x v) const { return _childVertexTag │ │ │ │ │ -[v]; } │ │ │ │ │ -216 │ │ │ │ │ -217 ChildTag & getChildFaceTag( _I_n_d_e_x f) { return _childFaceTag[f]; } │ │ │ │ │ -218 ChildTag & getChildEdgeTag( _I_n_d_e_x e) { return _childEdgeTag[e]; } │ │ │ │ │ -219 ChildTag & getChildVertexTag(_I_n_d_e_x v) { return _childVertexTag[v]; } │ │ │ │ │ -220 │ │ │ │ │ -221// Remaining methods should really be protected -- for use by subclasses... │ │ │ │ │ -222public: │ │ │ │ │ -223 // │ │ │ │ │ -224 // Methods involved in constructing the parent-to-child mapping -- when the │ │ │ │ │ -225 // refinement is sparse, additional methods are needed to identify the │ │ │ │ │ -selection: │ │ │ │ │ -226 // │ │ │ │ │ -227 void populateParentToChildMapping(); │ │ │ │ │ -228 void populateParentChildIndices(); │ │ │ │ │ -229 void printParentToChildMapping() const; │ │ │ │ │ -230 │ │ │ │ │ -231 virtual void allocateParentChildIndices() = 0; │ │ │ │ │ -232 │ │ │ │ │ -233 // Supporting method for sparse refinement: │ │ │ │ │ -234 void initializeSparseSelectionTags(); │ │ │ │ │ -235 void markSparseChildComponentIndices(); │ │ │ │ │ -236 void markSparseVertexChildren(); │ │ │ │ │ -237 void markSparseEdgeChildren(); │ │ │ │ │ -238 │ │ │ │ │ -239 virtual void markSparseFaceChildren() = 0; │ │ │ │ │ -240 │ │ │ │ │ -241 void initializeChildComponentCounts(); │ │ │ │ │ -242 │ │ │ │ │ -243 // │ │ │ │ │ -244 // Methods involved in constructing the child-to-parent mapping: │ │ │ │ │ -245 // │ │ │ │ │ -246 void populateChildToParentMapping(); │ │ │ │ │ -247 │ │ │ │ │ -248 void populateFaceParentVectors(ChildTag const initialChildTags[2][4]); │ │ │ │ │ -249 void populateFaceParentFromParentFaces(ChildTag const initialChildTags[2] │ │ │ │ │ -[4]); │ │ │ │ │ -250 │ │ │ │ │ -251 void populateEdgeParentVectors(ChildTag const initialChildTags[2][4]); │ │ │ │ │ -252 void populateEdgeParentFromParentFaces(ChildTag const initialChildTags[2] │ │ │ │ │ -[4]); │ │ │ │ │ -253 void populateEdgeParentFromParentEdges(ChildTag const initialChildTags[2] │ │ │ │ │ -[4]); │ │ │ │ │ -254 │ │ │ │ │ -255 void populateVertexParentVectors(ChildTag const initialChildTags[2][4]); │ │ │ │ │ -256 void populateVertexParentFromParentFaces(ChildTag const initialChildTags[2] │ │ │ │ │ -[4]); │ │ │ │ │ -257 void populateVertexParentFromParentEdges(ChildTag const initialChildTags[2] │ │ │ │ │ -[4]); │ │ │ │ │ -258 void populateVertexParentFromParentVertices(ChildTag const initialChildTags │ │ │ │ │ -[2][4]); │ │ │ │ │ -259 │ │ │ │ │ -260 // │ │ │ │ │ -261 // Methods involved in propagating component tags from parent to child: │ │ │ │ │ -262 // │ │ │ │ │ -263 void propagateComponentTags(); │ │ │ │ │ -264 │ │ │ │ │ -265 void populateFaceTagVectors(); │ │ │ │ │ -266 void populateFaceTagsFromParentFaces(); │ │ │ │ │ -267 │ │ │ │ │ -268 void populateEdgeTagVectors(); │ │ │ │ │ -269 void populateEdgeTagsFromParentFaces(); │ │ │ │ │ -270 void populateEdgeTagsFromParentEdges(); │ │ │ │ │ -271 │ │ │ │ │ -272 void populateVertexTagVectors(); │ │ │ │ │ -273 void populateVertexTagsFromParentFaces(); │ │ │ │ │ -274 void populateVertexTagsFromParentEdges(); │ │ │ │ │ -275 void populateVertexTagsFromParentVertices(); │ │ │ │ │ -276 │ │ │ │ │ -277 // │ │ │ │ │ -278 // Methods (and types) involved in subdividing the topology -- though not │ │ │ │ │ -279 // fully exploited, any subset of the 6 relations can be generated: │ │ │ │ │ -280 // │ │ │ │ │ -281 struct Relations { │ │ │ │ │ -282 unsigned int _faceVertices : 1; │ │ │ │ │ -283 unsigned int _faceEdges : 1; │ │ │ │ │ -284 unsigned int _edgeVertices : 1; │ │ │ │ │ -285 unsigned int _edgeFaces : 1; │ │ │ │ │ -286 unsigned int _vertexFaces : 1; │ │ │ │ │ -287 unsigned int _vertexEdges : 1; │ │ │ │ │ -288 │ │ │ │ │ -289 void setAll(bool enable) { │ │ │ │ │ -290 _faceVertices = enable; │ │ │ │ │ -291 _faceEdges = enable; │ │ │ │ │ -292 _edgeVertices = enable; │ │ │ │ │ -293 _edgeFaces = enable; │ │ │ │ │ -294 _vertexFaces = enable; │ │ │ │ │ -295 _vertexEdges = enable; │ │ │ │ │ -296 } │ │ │ │ │ -297 }; │ │ │ │ │ -298 │ │ │ │ │ -299 void subdivideTopology(Relations const& relationsToSubdivide); │ │ │ │ │ -300 │ │ │ │ │ -301 virtual void populateFaceVertexRelation() = 0; │ │ │ │ │ -302 virtual void populateFaceEdgeRelation() = 0; │ │ │ │ │ -303 virtual void populateEdgeVertexRelation() = 0; │ │ │ │ │ -304 virtual void populateEdgeFaceRelation() = 0; │ │ │ │ │ -305 virtual void populateVertexFaceRelation() = 0; │ │ │ │ │ -306 virtual void populateVertexEdgeRelation() = 0; │ │ │ │ │ -307 │ │ │ │ │ -308 // │ │ │ │ │ -309 // Methods involved in subdividing and inspecting sharpness values: │ │ │ │ │ -310 // │ │ │ │ │ -311 void subdivideSharpnessValues(); │ │ │ │ │ -312 │ │ │ │ │ -313 void subdivideVertexSharpness(); │ │ │ │ │ -314 void subdivideEdgeSharpness(); │ │ │ │ │ -315 void reclassifySemisharpVertices(); │ │ │ │ │ -316 │ │ │ │ │ -317 // │ │ │ │ │ -318 // Methods involved in subdividing face-varying topology: │ │ │ │ │ -319 // │ │ │ │ │ -320 void subdivideFVarChannels(); │ │ │ │ │ -321 │ │ │ │ │ -322protected: │ │ │ │ │ -323 // A debug method of Level prints a Refinement (should really change this) │ │ │ │ │ -324 friend void Level::print(const Refinement *) const; │ │ │ │ │ -325 │ │ │ │ │ -326 // │ │ │ │ │ -327 // Data members -- the logical grouping of some of these (and methods that │ │ │ │ │ -make use │ │ │ │ │ -328 // of them) may lead to grouping them into a few utility classes or │ │ │ │ │ -structs... │ │ │ │ │ -329 // │ │ │ │ │ -330 │ │ │ │ │ -331 // Defined on construction: │ │ │ │ │ -332 Level const * _parent; │ │ │ │ │ -333 Level * _child; │ │ │ │ │ -334 Sdc::Options _options; │ │ │ │ │ -335 │ │ │ │ │ -336 // Defined by the subclass: │ │ │ │ │ -337 _S_d_c_:_:_S_p_l_i_t _splitType; │ │ │ │ │ -338 int _regFaceSize; │ │ │ │ │ -339 │ │ │ │ │ -340 // Determined by the refinement options: │ │ │ │ │ -341 bool _uniform; │ │ │ │ │ -342 bool _faceVertsFirst; │ │ │ │ │ -343 │ │ │ │ │ -344 // │ │ │ │ │ -345 // Inventory and ordering of the types of child components: │ │ │ │ │ -346 // │ │ │ │ │ -347 int _childFaceFromFaceCount; // arguably redundant (all faces originate │ │ │ │ │ -from faces) │ │ │ │ │ -348 int _childEdgeFromFaceCount; │ │ │ │ │ -349 int _childEdgeFromEdgeCount; │ │ │ │ │ -350 int _childVertFromFaceCount; │ │ │ │ │ -351 int _childVertFromEdgeCount; │ │ │ │ │ -352 int _childVertFromVertCount; │ │ │ │ │ -353 │ │ │ │ │ -354 int _firstChildFaceFromFace; // arguably redundant (all faces originate │ │ │ │ │ -from faces) │ │ │ │ │ -355 int _firstChildEdgeFromFace; │ │ │ │ │ -356 int _firstChildEdgeFromEdge; │ │ │ │ │ -357 int _firstChildVertFromFace; │ │ │ │ │ -358 int _firstChildVertFromEdge; │ │ │ │ │ -359 int _firstChildVertFromVert; │ │ │ │ │ -360 │ │ │ │ │ -361 // │ │ │ │ │ -362 // The parent-to-child mapping: │ │ │ │ │ -363 // These are vectors sized according to the number of parent components │ │ │ │ │ -(and │ │ │ │ │ -364 // their topology) that contain references/indices to the child components │ │ │ │ │ -that │ │ │ │ │ -365 // result from them by refinement. When refinement is sparse, parent │ │ │ │ │ -components │ │ │ │ │ -366 // that have not spawned all child components will have their missing │ │ │ │ │ -children │ │ │ │ │ -367 // marked as invalid. │ │ │ │ │ -368 // │ │ │ │ │ -369 // NOTE the "Array" members here. Often vectors within the Level can be │ │ │ │ │ -shared │ │ │ │ │ -370 // with the Refinement, and an Array instance is used to do so. If not │ │ │ │ │ -shared │ │ │ │ │ -371 // the subclass just initializes the Array members after allocating its own │ │ │ │ │ -local │ │ │ │ │ -372 // vector members. │ │ │ │ │ -373 // │ │ │ │ │ -374 _I_n_d_e_x_A_r_r_a_y _faceChildFaceCountsAndOffsets; │ │ │ │ │ -375 _I_n_d_e_x_A_r_r_a_y _faceChildEdgeCountsAndOffsets; │ │ │ │ │ -376 │ │ │ │ │ -377 _I_n_d_e_x_V_e_c_t_o_r _faceChildFaceIndices; // *cannot* always use face-vert counts/ │ │ │ │ │ -offsets │ │ │ │ │ -378 _I_n_d_e_x_V_e_c_t_o_r _faceChildEdgeIndices; // can use face-vert counts/offsets │ │ │ │ │ -379 _I_n_d_e_x_V_e_c_t_o_r _faceChildVertIndex; │ │ │ │ │ -380 │ │ │ │ │ -381 _I_n_d_e_x_V_e_c_t_o_r _edgeChildEdgeIndices; // trivial/corresponding pair for each │ │ │ │ │ -382 _I_n_d_e_x_V_e_c_t_o_r _edgeChildVertIndex; │ │ │ │ │ -383 │ │ │ │ │ -384 _I_n_d_e_x_V_e_c_t_o_r _vertChildVertIndex; │ │ │ │ │ -385 │ │ │ │ │ -386 // │ │ │ │ │ -387 // The child-to-parent mapping: │ │ │ │ │ -388 // │ │ │ │ │ -389 _I_n_d_e_x_V_e_c_t_o_r _childFaceParentIndex; │ │ │ │ │ -390 _I_n_d_e_x_V_e_c_t_o_r _childEdgeParentIndex; │ │ │ │ │ -391 _I_n_d_e_x_V_e_c_t_o_r _childVertexParentIndex; │ │ │ │ │ -392 │ │ │ │ │ -393 std::vector _childFaceTag; │ │ │ │ │ -394 std::vector _childEdgeTag; │ │ │ │ │ -395 std::vector _childVertexTag; │ │ │ │ │ -396 │ │ │ │ │ -397 // │ │ │ │ │ -398 // Tags for sparse selection of components: │ │ │ │ │ -399 // │ │ │ │ │ -400 std::vector _parentFaceTag; │ │ │ │ │ -401 std::vector _parentEdgeTag; │ │ │ │ │ -402 std::vector _parentVertexTag; │ │ │ │ │ -403 │ │ │ │ │ -404 // │ │ │ │ │ -405 // Refinement data for face-varying channels present in the Levels being │ │ │ │ │ -refined: │ │ │ │ │ -406 // │ │ │ │ │ -407 std::vector _fvarChannels; │ │ │ │ │ -408}; │ │ │ │ │ -409 │ │ │ │ │ -410inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -411Refinement::getFaceChildFaces(_I_n_d_e_x parentFace) const { │ │ │ │ │ -412 │ │ │ │ │ -413 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceChildFaceIndices │ │ │ │ │ -[_faceChildFaceCountsAndOffsets[2*parentFace+1]], │ │ │ │ │ -414 _faceChildFaceCountsAndOffsets[2*parentFace]); │ │ │ │ │ -415} │ │ │ │ │ -416 │ │ │ │ │ -417inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -418Refinement::getFaceChildFaces(_I_n_d_e_x parentFace) { │ │ │ │ │ -419 │ │ │ │ │ -420 return _I_n_d_e_x_A_r_r_a_y(&_faceChildFaceIndices[_faceChildFaceCountsAndOffsets │ │ │ │ │ -[2*parentFace+1]], │ │ │ │ │ -421 _faceChildFaceCountsAndOffsets[2*parentFace]); │ │ │ │ │ -422} │ │ │ │ │ -423 │ │ │ │ │ -424inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -425Refinement::getFaceChildEdges(_I_n_d_e_x parentFace) const { │ │ │ │ │ -426 │ │ │ │ │ -427 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceChildEdgeIndices │ │ │ │ │ -[_faceChildEdgeCountsAndOffsets[2*parentFace+1]], │ │ │ │ │ -428 _faceChildEdgeCountsAndOffsets[2*parentFace]); │ │ │ │ │ -429} │ │ │ │ │ -430inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -431Refinement::getFaceChildEdges(_I_n_d_e_x parentFace) { │ │ │ │ │ -432 │ │ │ │ │ -433 return _I_n_d_e_x_A_r_r_a_y(&_faceChildEdgeIndices[_faceChildEdgeCountsAndOffsets │ │ │ │ │ -[2*parentFace+1]], │ │ │ │ │ -434 _faceChildEdgeCountsAndOffsets[2*parentFace]); │ │ │ │ │ -435} │ │ │ │ │ -436 │ │ │ │ │ -437inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -438Refinement::getEdgeChildEdges(_I_n_d_e_x parentEdge) const { │ │ │ │ │ -439 │ │ │ │ │ -440 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_edgeChildEdgeIndices[parentEdge*2], 2); │ │ │ │ │ -441} │ │ │ │ │ -442 │ │ │ │ │ -443inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -444Refinement::getEdgeChildEdges(_I_n_d_e_x parentEdge) { │ │ │ │ │ -445 │ │ │ │ │ -446 return _I_n_d_e_x_A_r_r_a_y(&_edgeChildEdgeIndices[parentEdge*2], 2); │ │ │ │ │ -447} │ │ │ │ │ -448 │ │ │ │ │ -449} // end namespace internal │ │ │ │ │ -450} // end namespace Vtr │ │ │ │ │ -451 │ │ │ │ │ -452} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -453using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -454} // end namespace OpenSubdiv │ │ │ │ │ -455 │ │ │ │ │ -456#endif /* OPENSUBDIV3_VTR_REFINEMENT_H */ │ │ │ │ │ +83 void markVertexSelected(_I_n_d_e_x pVertex) const { _refine- │ │ │ │ │ +>getParentVertexSparseTag(pVertex)._selected = true; } │ │ │ │ │ +84 void markEdgeSelected( _I_n_d_e_x pEdge) const { _refine->getParentEdgeSparseTag │ │ │ │ │ +(pEdge)._selected = true; } │ │ │ │ │ +85 void markFaceSelected( _I_n_d_e_x pFace) const { _refine->getParentFaceSparseTag │ │ │ │ │ +(pFace)._selected = true; } │ │ │ │ │ +86 │ │ │ │ │ +87 void initializeSelection(); │ │ │ │ │ +88 │ │ │ │ │ +89private: │ │ │ │ │ +90 Refinement* _refine; │ │ │ │ │ +91 bool _selected; │ │ │ │ │ +92}; │ │ │ │ │ +93 │ │ │ │ │ +94} // end namespace internal │ │ │ │ │ +95} // end namespace Vtr │ │ │ │ │ +96 │ │ │ │ │ +97} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +98using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +99} // end namespace OpenSubdiv │ │ │ │ │ +100 │ │ │ │ │ +101#endif /* OPENSUBDIV3_VTR_SPARSE_SELECTOR_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x │ │ │ │ │ int Index │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_5_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x_V_e_c_t_o_r │ │ │ │ │ -std::vector< Index > IndexVector │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_7_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -ConstArray< Index > ConstIndexArray │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_8_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -Array< Index > IndexArray │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_7_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_p_l_i_t │ │ │ │ │ -Split │ │ │ │ │ -Enumerated type for all face splitting schemes. │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _v_t_r │ │ │ │ │ - * _r_e_f_i_n_e_m_e_n_t_._h │ │ │ │ │ + * _s_p_a_r_s_e_S_e_l_e_c_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00755.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/vtr/level.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/vtr/refinement.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -89,26 +89,23 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Namespaces
│ │ │ │ -
level.h File Reference
│ │ │ │ +
refinement.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include "../sdc/types.h"
│ │ │ │ -#include "../sdc/crease.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │ #include "../vtr/types.h"
│ │ │ │ -#include <algorithm>
│ │ │ │ +#include "../vtr/level.h"
│ │ │ │ #include <vector>
│ │ │ │ -#include <cassert>
│ │ │ │ -#include <cstring>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -118,13 +115,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,27 +1,24 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -level.h File Reference │ │ │ │ │ +refinement.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ #include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_c_r_e_a_s_e_._h" │ │ │ │ │ #include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ #include "_._._/_v_t_r_/_t_y_p_e_s_._h" │ │ │ │ │ -#include │ │ │ │ │ +#include "_._._/_v_t_r_/_l_e_v_e_l_._h" │ │ │ │ │ #include │ │ │ │ │ -#include │ │ │ │ │ -#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _v_t_r │ │ │ │ │ - * _l_e_v_e_l_._h │ │ │ │ │ + * _r_e_f_i_n_e_m_e_n_t_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00755_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/vtr/level.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/vtr/refinement.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
level.h
│ │ │ │ +
refinement.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2014 DreamWorks Animation LLC.
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -118,882 +118,457 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24#ifndef OPENSUBDIV3_VTR_LEVEL_H
│ │ │ │ -
25#define OPENSUBDIV3_VTR_LEVEL_H
│ │ │ │ +
24#ifndef OPENSUBDIV3_VTR_REFINEMENT_H
│ │ │ │ +
25#define OPENSUBDIV3_VTR_REFINEMENT_H
│ │ │ │
26
│ │ │ │
27#include "../version.h"
│ │ │ │
28
│ │ │ │
29#include "../sdc/types.h"
│ │ │ │ -
30#include "../sdc/crease.h"
│ │ │ │ -
31#include "../sdc/options.h"
│ │ │ │ -
32#include "../vtr/types.h"
│ │ │ │ +
30#include "../sdc/options.h"
│ │ │ │ +
31#include "../vtr/types.h"
│ │ │ │ +
32#include "../vtr/level.h"
│ │ │ │
33
│ │ │ │ -
34#include <algorithm>
│ │ │ │ -
35#include <vector>
│ │ │ │ -
36#include <cassert>
│ │ │ │ -
37#include <cstring>
│ │ │ │ -
38
│ │ │ │ -
39
│ │ │ │ -
40namespace OpenSubdiv {
│ │ │ │ -
41namespace OPENSUBDIV_VERSION {
│ │ │ │ -
42
│ │ │ │ -
43namespace Vtr {
│ │ │ │ -
44namespace internal {
│ │ │ │ -
45
│ │ │ │ -
46class Refinement;
│ │ │ │ -
47class TriRefinement;
│ │ │ │ -
48class QuadRefinement;
│ │ │ │ -
49class FVarRefinement;
│ │ │ │ -
50class FVarLevel;
│ │ │ │ -
51
│ │ │ │ -
52//
│ │ │ │ -
53// Level:
│ │ │ │ -
54// A refinement level includes a vectorized representation of the topology
│ │ │ │ -
55// for a particular subdivision level. The topology is "complete" in that any
│ │ │ │ -
56// level can be used as the base level of another subdivision hierarchy and can
│ │ │ │ -
57// be considered a complete mesh independent of its ancestors. It currently
│ │ │ │ -
58// does contain a "depth" member -- as some inferences can then be made about
│ │ │ │ -
59// the topology (i.e. all quads or all tris if not level 0).
│ │ │ │ +
34#include <vector>
│ │ │ │ +
35
│ │ │ │ +
36//
│ │ │ │ +
37// Declaration for the main refinement class (Refinement) and its pre-requisites:
│ │ │ │ +
38//
│ │ │ │ +
39namespace OpenSubdiv {
│ │ │ │ +
40namespace OPENSUBDIV_VERSION {
│ │ │ │ +
41
│ │ │ │ +
42namespace Vtr {
│ │ │ │ +
43namespace internal {
│ │ │ │ +
44
│ │ │ │ +
45class FVarRefinement;
│ │ │ │ +
46
│ │ │ │ +
47//
│ │ │ │ +
48// Refinement:
│ │ │ │ +
49// A refinement is a mapping between two levels -- relating the components in the original
│ │ │ │ +
50// (parent) level to the one refined (child). The refinement may be complete (uniform) or sparse
│ │ │ │ +
51// (adaptive or otherwise selective), so not all components in the parent level will spawn
│ │ │ │ +
52// components in the child level.
│ │ │ │ +
53//
│ │ │ │ +
54// Refinement is an abstract class and expects subclasses corresponding to the different types
│ │ │ │ +
55// of topological splits that the supported subdivision schemes collectively require, i.e. those
│ │ │ │ +
56// listed in Sdc::SplitType. Note the virtual requirements expected of the subclasses in the list
│ │ │ │ +
57// of protected methods -- they differ mainly in the topology that is created in the child Level
│ │ │ │ +
58// and not the propagation of tags through refinement, subdivision of sharpness values or the
│ │ │ │ +
59// treatment of face-varying data. The primary subclasses are QuadRefinement and TriRefinement.
│ │ │ │
60//
│ │ │ │ -
61// This class is intended for private use within the library. There are still
│ │ │ │ -
62// opportunities to specialize levels -- e.g. those supporting N-sided faces vs
│ │ │ │ -
63// those that are purely quads or tris -- so we prefer to insulate it from public
│ │ │ │ -
64// access.
│ │ │ │ -
65//
│ │ │ │ -
66// The representation of topology here is to store six topological relationships
│ │ │ │ -
67// in tables of integers. Each is stored in its own array(s) so the result is
│ │ │ │ -
68// a SOA representation of the topology. The six relations are:
│ │ │ │ -
69//
│ │ │ │ -
70// - face-verts: vertices incident/comprising a face
│ │ │ │ -
71// - face-edges: edges incident a face
│ │ │ │ -
72// - edge-verts: vertices incident/comprising an edge
│ │ │ │ -
73// - edge-faces: faces incident an edge
│ │ │ │ -
74// - vert-faces: faces incident a vertex
│ │ │ │ -
75// - vert-edges: edges incident a vertex
│ │ │ │ -
76//
│ │ │ │ -
77// There is some redundancy here but the intent is not that this be a minimal
│ │ │ │ -
78// representation, the intent is that it be amenable to refinement. Classes in
│ │ │ │ -
79// the Far layer essentially store 5 of these 6 in a permuted form -- we add
│ │ │ │ -
80// the face-edges here to simplify refinement.
│ │ │ │ -
81//
│ │ │ │ +
61// At a high level, all that is necessary in terms of interface is to construct, initialize
│ │ │ │ +
62// (linking the two levels), optionally select components for sparse refinement (via use of the
│ │ │ │ +
63// SparseSelector) and call the refine() method. This usage is expected of Far::TopologyRefiner.
│ │ │ │ +
64//
│ │ │ │ +
65// Since we really want this class to be restricted from public access eventually, all methods
│ │ │ │ +
66// begin with lower case (as is the convention for protected methods) and the list of friends
│ │ │ │ +
67// will be maintained more strictly.
│ │ │ │ +
68//
│ │ │ │ +
69class Refinement {
│ │ │ │ +
70
│ │ │ │ +
71public:
│ │ │ │ +
72 Refinement(Level const & parent, Level & child, Sdc::Options const& schemeOptions);
│ │ │ │ +
73 virtual ~Refinement();
│ │ │ │ +
74
│ │ │ │ +
75 Level const& parent() const { return *_parent; }
│ │ │ │ +
76 Level const& child() const { return *_child; }
│ │ │ │ +
77 Level& child() { return *_child; }
│ │ │ │ +
78
│ │ │ │ +
79 Sdc::Split getSplitType() const { return _splitType; }
│ │ │ │ +
80 int getRegularFaceSize() const { return _regFaceSize; }
│ │ │ │ +
81 Sdc::Options getOptions() const { return _options; }
│ │ │ │
82
│ │ │ │ -
83class Level {
│ │ │ │ -
84
│ │ │ │ -
85public:
│ │ │ │ -
86 //
│ │ │ │ -
87 // Simple nested types to hold the tags for each component type -- some of
│ │ │ │ -
88 // which are user-specified features (e.g. whether a face is a hole or not)
│ │ │ │ -
89 // while others indicate the topological nature of the component, how it
│ │ │ │ -
90 // is affected by creasing in its neighborhood, etc.
│ │ │ │ -
91 //
│ │ │ │ -
92 // Most of these properties are passed down to child components during
│ │ │ │ -
93 // refinement, but some -- notably the designation of a component as semi-
│ │ │ │ -
94 // sharp -- require re-determination as sharpness values are reduced at each
│ │ │ │ -
95 // level.
│ │ │ │ -
96 //
│ │ │ │ -
97 struct VTag {
│ │ │ │ -
98 VTag() { }
│ │ │ │ -
99
│ │ │ │ -
100 // When cleared, the VTag ALMOST represents a smooth, regular, interior
│ │ │ │ -
101 // vertex -- the Type enum requires a bit be explicitly set for Smooth,
│ │ │ │ -
102 // so that must be done explicitly if desired on initialization.
│ │ │ │ -
103 void clear() { std::memset((void*) this, 0, sizeof(VTag)); }
│ │ │ │ -
104
│ │ │ │ -
105 typedef unsigned short VTagSize;
│ │ │ │ -
106
│ │ │ │ -
107 VTagSize _nonManifold : 1; // fixed
│ │ │ │ -
108 VTagSize _xordinary : 1; // fixed
│ │ │ │ -
109 VTagSize _boundary : 1; // fixed
│ │ │ │ -
110 VTagSize _corner : 1; // fixed
│ │ │ │ -
111 VTagSize _infSharp : 1; // fixed
│ │ │ │ -
112 VTagSize _semiSharp : 1; // variable
│ │ │ │ -
113 VTagSize _semiSharpEdges : 1; // variable
│ │ │ │ -
114 VTagSize _rule : 4; // variable when _semiSharp
│ │ │ │ -
115
│ │ │ │ -
116 // These next to tags are complementary -- the "incomplete" tag is only
│ │ │ │ -
117 // relevant for refined levels while the "incident an irregular face" tag
│ │ │ │ -
118 // is only relevant for the base level. They could be combined as both
│ │ │ │ -
119 // indicate "no full regular ring" around a vertex
│ │ │ │ -
120 VTagSize _incomplete : 1; // variable only set in refined levels
│ │ │ │ -
121 VTagSize _incidIrregFace : 1; // variable only set in base level
│ │ │ │ +
83 // Face-varying:
│ │ │ │ +
84 int getNumFVarChannels() const { return (int) _fvarChannels.size(); }
│ │ │ │ +
85
│ │ │ │ +
86 FVarRefinement const & getFVarRefinement(int c) const { return *_fvarChannels[c]; }
│ │ │ │ +
87
│ │ │ │ +
88 //
│ │ │ │ +
89 // Options associated with the actual refinement operation, which may end up
│ │ │ │ +
90 // quite involved if we want to allow for the refinement of data that is not
│ │ │ │ +
91 // of interest to be suppressed. For now we have:
│ │ │ │ +
92 //
│ │ │ │ +
93 // "sparse": the alternative to uniform refinement, which requires that
│ │ │ │ +
94 // components be previously selected/marked to be included.
│ │ │ │ +
95 //
│ │ │ │ +
96 // "minimal topology": this is one that may get broken down into a finer
│ │ │ │ +
97 // set of options. It suppresses "full topology" in the child level
│ │ │ │ +
98 // and only generates what is minimally necessary for interpolation --
│ │ │ │ +
99 // which requires at least the face-vertices for faces, but also the
│ │ │ │ +
100 // vertex-faces for any face-varying channels present. So it will
│ │ │ │ +
101 // generate one or two of the six possible topological relations.
│ │ │ │ +
102 //
│ │ │ │ +
103 // These are strictly controlled right now, e.g. for sparse refinement, we
│ │ │ │ +
104 // currently enforce full topology at the finest level to allow for subsequent
│ │ │ │ +
105 // patch construction.
│ │ │ │ +
106 //
│ │ │ │ +
107 struct Options {
│ │ │ │ +
108 Options() : _sparse(false),
│ │ │ │ +
109 _faceVertsFirst(false),
│ │ │ │ +
110 _minimalTopology(false)
│ │ │ │ +
111 { }
│ │ │ │ +
112
│ │ │ │ +
113 unsigned int _sparse : 1;
│ │ │ │ +
114 unsigned int _faceVertsFirst : 1;
│ │ │ │ +
115 unsigned int _minimalTopology : 1;
│ │ │ │ +
116
│ │ │ │ +
117 // Still under consideration:
│ │ │ │ +
118 //unsigned int _childToParentMap : 1;
│ │ │ │ +
119 };
│ │ │ │ +
120
│ │ │ │ +
121 void refine(Options options = Options());
│ │ │ │
122
│ │ │ │ -
123 // Tags indicating incident infinitely-sharp (permanent) features
│ │ │ │ -
124 VTagSize _infSharpEdges : 1; // fixed
│ │ │ │ -
125 VTagSize _infSharpCrease : 1; // fixed
│ │ │ │ -
126 VTagSize _infIrregular : 1; // fixed
│ │ │ │ -
127
│ │ │ │ -
128 // Alternate constructor and accessor for dealing with integer bits directly:
│ │ │ │ -
129 explicit VTag(VTagSize bits) {
│ │ │ │ -
130 std::memcpy(this, &bits, sizeof(bits));
│ │ │ │ -
131 }
│ │ │ │ -
132 VTagSize getBits() const {
│ │ │ │ -
133 VTagSize bits;
│ │ │ │ -
134 std::memcpy(&bits, this, sizeof(bits));
│ │ │ │ -
135 return bits;
│ │ │ │ -
136 }
│ │ │ │ -
137
│ │ │ │ -
138 static VTag BitwiseOr(VTag const vTags[], int size = 4);
│ │ │ │ -
139 };
│ │ │ │ -
140 struct ETag {
│ │ │ │ -
141 ETag() { }
│ │ │ │ -
142
│ │ │ │ -
143 // When cleared, the ETag represents a smooth, manifold, interior edge
│ │ │ │ -
144 void clear() { std::memset((void*) this, 0, sizeof(ETag)); }
│ │ │ │ -
145
│ │ │ │ -
146 typedef unsigned char ETagSize;
│ │ │ │ +
123 bool hasFaceVerticesFirst() const { return _faceVertsFirst; }
│ │ │ │ +
124
│ │ │ │ +
125public:
│ │ │ │ +
126 //
│ │ │ │ +
127 // Access to members -- some testing classes (involving vertex interpolation)
│ │ │ │ +
128 // currently make use of these:
│ │ │ │ +
129 //
│ │ │ │ +
130 int getNumChildFacesFromFaces() const { return _childFaceFromFaceCount; }
│ │ │ │ +
131 int getNumChildEdgesFromFaces() const { return _childEdgeFromFaceCount; }
│ │ │ │ +
132 int getNumChildEdgesFromEdges() const { return _childEdgeFromEdgeCount; }
│ │ │ │ +
133 int getNumChildVerticesFromFaces() const { return _childVertFromFaceCount; }
│ │ │ │ +
134 int getNumChildVerticesFromEdges() const { return _childVertFromEdgeCount; }
│ │ │ │ +
135 int getNumChildVerticesFromVertices() const { return _childVertFromVertCount; }
│ │ │ │ +
136
│ │ │ │ +
137 Index getFirstChildFaceFromFaces() const { return _firstChildFaceFromFace; }
│ │ │ │ +
138 Index getFirstChildEdgeFromFaces() const { return _firstChildEdgeFromFace; }
│ │ │ │ +
139 Index getFirstChildEdgeFromEdges() const { return _firstChildEdgeFromEdge; }
│ │ │ │ +
140 Index getFirstChildVertexFromFaces() const { return _firstChildVertFromFace; }
│ │ │ │ +
141 Index getFirstChildVertexFromEdges() const { return _firstChildVertFromEdge; }
│ │ │ │ +
142 Index getFirstChildVertexFromVertices() const { return _firstChildVertFromVert; }
│ │ │ │ +
143
│ │ │ │ +
144 Index getFaceChildVertex(Index f) const { return _faceChildVertIndex[f]; }
│ │ │ │ +
145 Index getEdgeChildVertex(Index e) const { return _edgeChildVertIndex[e]; }
│ │ │ │ +
146 Index getVertexChildVertex(Index v) const { return _vertChildVertIndex[v]; }
│ │ │ │
147
│ │ │ │ -
148 ETagSize _nonManifold : 1; // fixed
│ │ │ │ -
149 ETagSize _boundary : 1; // fixed
│ │ │ │ -
150 ETagSize _infSharp : 1; // fixed
│ │ │ │ -
151 ETagSize _semiSharp : 1; // variable
│ │ │ │ -
152
│ │ │ │ -
153 // Alternate constructor and accessor for dealing with integer bits directly:
│ │ │ │ -
154 explicit ETag(ETagSize bits) {
│ │ │ │ -
155 std::memcpy(this, &bits, sizeof(bits));
│ │ │ │ -
156 }
│ │ │ │ -
157 ETagSize getBits() const {
│ │ │ │ -
158 ETagSize bits;
│ │ │ │ -
159 std::memcpy(&bits, this, sizeof(bits));
│ │ │ │ -
160 return bits;
│ │ │ │ -
161 }
│ │ │ │ -
162
│ │ │ │ -
163 static ETag BitwiseOr(ETag const eTags[], int size = 4);
│ │ │ │ -
164 };
│ │ │ │ -
165 struct FTag {
│ │ │ │ -
166 FTag() { }
│ │ │ │ -
167
│ │ │ │ -
168 void clear() { std::memset((void*) this, 0, sizeof(FTag)); }
│ │ │ │ -
169
│ │ │ │ -
170 typedef unsigned char FTagSize;
│ │ │ │ -
171
│ │ │ │ -
172 FTagSize _hole : 1; // fixed
│ │ │ │ -
173
│ │ │ │ -
174 // On deck -- coming soon...
│ │ │ │ -
175 //FTagSize _hasEdits : 1; // variable
│ │ │ │ -
176 };
│ │ │ │ -
177
│ │ │ │ -
178 // Additional simple struct to identify a "span" around a vertex, i.e. a
│ │ │ │ -
179 // subset of the faces around a vertex delimited by some property (e.g. a
│ │ │ │ -
180 // face-varying discontinuity, an inf-sharp edge, etc.)
│ │ │ │ -
181 //
│ │ │ │ -
182 // The span requires an "origin" and a "size" to fully define its extent.
│ │ │ │ -
183 // Use of the size is required over a leading/trailing pair as the valence
│ │ │ │ -
184 // around a non-manifold vertex cannot be trivially determined from two
│ │ │ │ -
185 // extremeties. Similarly a start face is chosen over an edge as starting
│ │ │ │ -
186 // with a manifold edge is ambiguous. Additional tags also support
│ │ │ │ -
187 // non-manifold cases, e.g. periodic spans at the apex of a double cone.
│ │ │ │ +
148 ConstIndexArray getFaceChildFaces(Index parentFace) const;
│ │ │ │ +
149 ConstIndexArray getFaceChildEdges(Index parentFace) const;
│ │ │ │ +
150 ConstIndexArray getEdgeChildEdges(Index parentEdge) const;
│ │ │ │ +
151
│ │ │ │ +
152 // Child-to-parent relationships
│ │ │ │ +
153 bool isChildVertexComplete(Index v) const { return ! _childVertexTag[v]._incomplete; }
│ │ │ │ +
154
│ │ │ │ +
155 Index getChildFaceParentFace(Index f) const { return _childFaceParentIndex[f]; }
│ │ │ │ +
156 int getChildFaceInParentFace(Index f) const { return _childFaceTag[f]._indexInParent; }
│ │ │ │ +
157
│ │ │ │ +
158 Index getChildEdgeParentIndex(Index e) const { return _childEdgeParentIndex[e]; }
│ │ │ │ +
159
│ │ │ │ +
160 Index getChildVertexParentIndex(Index v) const { return _childVertexParentIndex[v]; }
│ │ │ │ +
161
│ │ │ │ +
162//
│ │ │ │ +
163// Modifiers intended for internal/protected use:
│ │ │ │ +
164//
│ │ │ │ +
165public:
│ │ │ │ +
166
│ │ │ │ +
167 IndexArray getFaceChildFaces(Index parentFace);
│ │ │ │ +
168 IndexArray getFaceChildEdges(Index parentFace);
│ │ │ │ +
169 IndexArray getEdgeChildEdges(Index parentEdge);
│ │ │ │ +
170
│ │ │ │ +
171public:
│ │ │ │ +
172 //
│ │ │ │ +
173 // Tags have now been added per-component in Level, but there is additional need to tag
│ │ │ │ +
174 // components within Refinement -- we can't tag the parent level components for any
│ │ │ │ +
175 // refinement (in order to keep it const) and tags associated with children that are
│ │ │ │ +
176 // specific to the child-to-parent mapping may not be warranted in the child level.
│ │ │ │ +
177 //
│ │ │ │ +
178 // Parent tags are only required for sparse refinement. The main property to tag is
│ │ │ │ +
179 // whether a component was selected, and so a single SparseTag is used for all three
│ │ │ │ +
180 // component types. Tagging if a component is "transitional" is also useful. This may
│ │ │ │ +
181 // only be necessary for edges but is currently packed into a mask per-edge for faces,
│ │ │ │ +
182 // which could be deferred, in which case "transitional" could be a single bit.
│ │ │ │ +
183 //
│ │ │ │ +
184 // Child tags are part of the child-to-parent mapping, which consists of the parent
│ │ │ │ +
185 // component index for each child component, plus a tag for the child indicating more
│ │ │ │ +
186 // about its relationship to its parent, e.g. is it completely defined, what the parent
│ │ │ │ +
187 // component type is, what is the index of the child within its parent, etc.
│ │ │ │
188 //
│ │ │ │ -
189 // Currently setting the size to 0 or leaving the span "unassigned" is an
│ │ │ │ -
190 // indication to use the full neighborhood rather than a subset -- prefer
│ │ │ │ -
191 // use of the const method here to direct inspection of the member.
│ │ │ │ -
192 //
│ │ │ │ -
193 struct VSpan {
│ │ │ │ -
194 VSpan() { std::memset((void*) this, 0, sizeof(VSpan)); }
│ │ │ │ +
189 struct SparseTag {
│ │ │ │ +
190 SparseTag() : _selected(0), _transitional(0) { }
│ │ │ │ +
191
│ │ │ │ +
192 unsigned char _selected : 1; // component specifically selected for refinement
│ │ │ │ +
193 unsigned char _transitional : 4; // adjacent to a refined component (4-bits for face)
│ │ │ │ +
194 };
│ │ │ │
195
│ │ │ │ -
196 void clear() { std::memset((void*) this, 0, sizeof(VSpan)); }
│ │ │ │ -
197 bool isAssigned() const { return _numFaces > 0; }
│ │ │ │ +
196 struct ChildTag {
│ │ │ │ +
197 ChildTag() { }
│ │ │ │
198
│ │ │ │ -
199 LocalIndex _numFaces;
│ │ │ │ -
200 LocalIndex _startFace;
│ │ │ │ -
201 LocalIndex _cornerInSpan;
│ │ │ │ -
202
│ │ │ │ -
203 unsigned short _periodic : 1;
│ │ │ │ -
204 unsigned short _sharp : 1;
│ │ │ │ -
205 };
│ │ │ │ -
206
│ │ │ │ -
207public:
│ │ │ │ -
208 Level();
│ │ │ │ -
209 ~Level();
│ │ │ │ -
210
│ │ │ │ -
211 // Simple accessors:
│ │ │ │ -
212 int getDepth() const { return _depth; }
│ │ │ │ -
213
│ │ │ │ -
214 int getNumVertices() const { return _vertCount; }
│ │ │ │ -
215 int getNumFaces() const { return _faceCount; }
│ │ │ │ -
216 int getNumEdges() const { return _edgeCount; }
│ │ │ │ -
217
│ │ │ │ -
218 // More global sizes may prove useful...
│ │ │ │ -
219 int getNumFaceVerticesTotal() const { return (int) _faceVertIndices.size(); }
│ │ │ │ -
220 int getNumFaceEdgesTotal() const { return (int) _faceEdgeIndices.size(); }
│ │ │ │ -
221 int getNumEdgeVerticesTotal() const { return (int) _edgeVertIndices.size(); }
│ │ │ │ -
222 int getNumEdgeFacesTotal() const { return (int) _edgeFaceIndices.size(); }
│ │ │ │ -
223 int getNumVertexFacesTotal() const { return (int) _vertFaceIndices.size(); }
│ │ │ │ -
224 int getNumVertexEdgesTotal() const { return (int) _vertEdgeIndices.size(); }
│ │ │ │ -
225
│ │ │ │ -
226 int getMaxValence() const { return _maxValence; }
│ │ │ │ -
227 int getMaxEdgeFaces() const { return _maxEdgeFaces; }
│ │ │ │ -
228
│ │ │ │ -
229 // Methods to access the relation tables/indices -- note that for some relations
│ │ │ │ -
230 // (i.e. those where a component is "contained by" a neighbor, or more generally
│ │ │ │ -
231 // when the neighbor is a simplex of higher dimension) we store an additional
│ │ │ │ -
232 // "local index", e.g. for the case of vert-faces if one of the faces F[i] is
│ │ │ │ -
233 // incident a vertex V, then L[i] is the "local index" in F[i] of vertex V.
│ │ │ │ -
234 // Once have only quads (or tris), this local index need only occupy two bits
│ │ │ │ -
235 // and could conceivably be packed into the same integer as the face index, but
│ │ │ │ -
236 // for now, given the need to support faces of potentially high valence we'll
│ │ │ │ -
237 // use an 8- or 16-bit integer.
│ │ │ │ -
238 //
│ │ │ │ -
239 // Methods to access the six topological relations:
│ │ │ │ -
240 ConstIndexArray getFaceVertices(Index faceIndex) const;
│ │ │ │ -
241 ConstIndexArray getFaceEdges(Index faceIndex) const;
│ │ │ │ -
242 ConstIndexArray getEdgeVertices(Index edgeIndex) const;
│ │ │ │ -
243 ConstIndexArray getEdgeFaces(Index edgeIndex) const;
│ │ │ │ -
244 ConstIndexArray getVertexFaces(Index vertIndex) const;
│ │ │ │ -
245 ConstIndexArray getVertexEdges(Index vertIndex) const;
│ │ │ │ -
246
│ │ │ │ -
247 ConstLocalIndexArray getEdgeFaceLocalIndices(Index edgeIndex) const;
│ │ │ │ -
248 ConstLocalIndexArray getVertexFaceLocalIndices(Index vertIndex) const;
│ │ │ │ -
249 ConstLocalIndexArray getVertexEdgeLocalIndices(Index vertIndex) const;
│ │ │ │ +
199 unsigned char _incomplete : 1; // incomplete neighborhood to represent limit of parent
│ │ │ │ +
200 unsigned char _parentType : 2; // type of parent component: vertex, edge or face
│ │ │ │ +
201 unsigned char _indexInParent : 2; // index of child wrt parent: 0-3, or iterative if N > 4
│ │ │ │ +
202 };
│ │ │ │ +
203
│ │ │ │ +
204 // Methods to access and modify tags:
│ │ │ │ +
205 SparseTag const & getParentFaceSparseTag( Index f) const { return _parentFaceTag[f]; }
│ │ │ │ +
206 SparseTag const & getParentEdgeSparseTag( Index e) const { return _parentEdgeTag[e]; }
│ │ │ │ +
207 SparseTag const & getParentVertexSparseTag(Index v) const { return _parentVertexTag[v]; }
│ │ │ │ +
208
│ │ │ │ +
209 SparseTag & getParentFaceSparseTag( Index f) { return _parentFaceTag[f]; }
│ │ │ │ +
210 SparseTag & getParentEdgeSparseTag( Index e) { return _parentEdgeTag[e]; }
│ │ │ │ +
211 SparseTag & getParentVertexSparseTag(Index v) { return _parentVertexTag[v]; }
│ │ │ │ +
212
│ │ │ │ +
213 ChildTag const & getChildFaceTag( Index f) const { return _childFaceTag[f]; }
│ │ │ │ +
214 ChildTag const & getChildEdgeTag( Index e) const { return _childEdgeTag[e]; }
│ │ │ │ +
215 ChildTag const & getChildVertexTag(Index v) const { return _childVertexTag[v]; }
│ │ │ │ +
216
│ │ │ │ +
217 ChildTag & getChildFaceTag( Index f) { return _childFaceTag[f]; }
│ │ │ │ +
218 ChildTag & getChildEdgeTag( Index e) { return _childEdgeTag[e]; }
│ │ │ │ +
219 ChildTag & getChildVertexTag(Index v) { return _childVertexTag[v]; }
│ │ │ │ +
220
│ │ │ │ +
221// Remaining methods should really be protected -- for use by subclasses...
│ │ │ │ +
222public:
│ │ │ │ +
223 //
│ │ │ │ +
224 // Methods involved in constructing the parent-to-child mapping -- when the
│ │ │ │ +
225 // refinement is sparse, additional methods are needed to identify the selection:
│ │ │ │ +
226 //
│ │ │ │ +
227 void populateParentToChildMapping();
│ │ │ │ +
228 void populateParentChildIndices();
│ │ │ │ +
229 void printParentToChildMapping() const;
│ │ │ │ +
230
│ │ │ │ +
231 virtual void allocateParentChildIndices() = 0;
│ │ │ │ +
232
│ │ │ │ +
233 // Supporting method for sparse refinement:
│ │ │ │ +
234 void initializeSparseSelectionTags();
│ │ │ │ +
235 void markSparseChildComponentIndices();
│ │ │ │ +
236 void markSparseVertexChildren();
│ │ │ │ +
237 void markSparseEdgeChildren();
│ │ │ │ +
238
│ │ │ │ +
239 virtual void markSparseFaceChildren() = 0;
│ │ │ │ +
240
│ │ │ │ +
241 void initializeChildComponentCounts();
│ │ │ │ +
242
│ │ │ │ +
243 //
│ │ │ │ +
244 // Methods involved in constructing the child-to-parent mapping:
│ │ │ │ +
245 //
│ │ │ │ +
246 void populateChildToParentMapping();
│ │ │ │ +
247
│ │ │ │ +
248 void populateFaceParentVectors(ChildTag const initialChildTags[2][4]);
│ │ │ │ +
249 void populateFaceParentFromParentFaces(ChildTag const initialChildTags[2][4]);
│ │ │ │
250
│ │ │ │ -
251 // Replace these with access to sharpness buffers/arrays rather than elements:
│ │ │ │ -
252 float getEdgeSharpness(Index edgeIndex) const;
│ │ │ │ -
253 float getVertexSharpness(Index vertIndex) const;
│ │ │ │ -
254 Sdc::Crease::Rule getVertexRule(Index vertIndex) const;
│ │ │ │ -
255
│ │ │ │ -
256 Index findEdge(Index v0Index, Index v1Index) const;
│ │ │ │ -
257
│ │ │ │ -
258 // Holes
│ │ │ │ -
259 void setFaceHole(Index faceIndex, bool b);
│ │ │ │ -
260 bool isFaceHole(Index faceIndex) const;
│ │ │ │ -
261
│ │ │ │ -
262 // Face-varying
│ │ │ │ -
263 Sdc::Options getFVarOptions(int channel) const;
│ │ │ │ -
264 int getNumFVarChannels() const { return (int) _fvarChannels.size(); }
│ │ │ │ -
265 int getNumFVarValues(int channel) const;
│ │ │ │ -
266 ConstIndexArray getFaceFVarValues(Index faceIndex, int channel) const;
│ │ │ │ +
251 void populateEdgeParentVectors(ChildTag const initialChildTags[2][4]);
│ │ │ │ +
252 void populateEdgeParentFromParentFaces(ChildTag const initialChildTags[2][4]);
│ │ │ │ +
253 void populateEdgeParentFromParentEdges(ChildTag const initialChildTags[2][4]);
│ │ │ │ +
254
│ │ │ │ +
255 void populateVertexParentVectors(ChildTag const initialChildTags[2][4]);
│ │ │ │ +
256 void populateVertexParentFromParentFaces(ChildTag const initialChildTags[2][4]);
│ │ │ │ +
257 void populateVertexParentFromParentEdges(ChildTag const initialChildTags[2][4]);
│ │ │ │ +
258 void populateVertexParentFromParentVertices(ChildTag const initialChildTags[2][4]);
│ │ │ │ +
259
│ │ │ │ +
260 //
│ │ │ │ +
261 // Methods involved in propagating component tags from parent to child:
│ │ │ │ +
262 //
│ │ │ │ +
263 void propagateComponentTags();
│ │ │ │ +
264
│ │ │ │ +
265 void populateFaceTagVectors();
│ │ │ │ +
266 void populateFaceTagsFromParentFaces();
│ │ │ │
267
│ │ │ │ -
268 FVarLevel & getFVarLevel(int channel) { return *_fvarChannels[channel]; }
│ │ │ │ -
269 FVarLevel const & getFVarLevel(int channel) const { return *_fvarChannels[channel]; }
│ │ │ │ -
270
│ │ │ │ -
271 // Manifold/non-manifold tags:
│ │ │ │ -
272 void setEdgeNonManifold(Index edgeIndex, bool b);
│ │ │ │ -
273 bool isEdgeNonManifold(Index edgeIndex) const;
│ │ │ │ -
274
│ │ │ │ -
275 void setVertexNonManifold(Index vertIndex, bool b);
│ │ │ │ -
276 bool isVertexNonManifold(Index vertIndex) const;
│ │ │ │ -
277
│ │ │ │ -
278 // General access to all component tags:
│ │ │ │ -
279 VTag const & getVertexTag(Index vertIndex) const { return _vertTags[vertIndex]; }
│ │ │ │ -
280 ETag const & getEdgeTag(Index edgeIndex) const { return _edgeTags[edgeIndex]; }
│ │ │ │ -
281 FTag const & getFaceTag(Index faceIndex) const { return _faceTags[faceIndex]; }
│ │ │ │ -
282
│ │ │ │ -
283 VTag & getVertexTag(Index vertIndex) { return _vertTags[vertIndex]; }
│ │ │ │ -
284 ETag & getEdgeTag(Index edgeIndex) { return _edgeTags[edgeIndex]; }
│ │ │ │ -
285 FTag & getFaceTag(Index faceIndex) { return _faceTags[faceIndex]; }
│ │ │ │ -
286
│ │ │ │ -
287public:
│ │ │ │ +
268 void populateEdgeTagVectors();
│ │ │ │ +
269 void populateEdgeTagsFromParentFaces();
│ │ │ │ +
270 void populateEdgeTagsFromParentEdges();
│ │ │ │ +
271
│ │ │ │ +
272 void populateVertexTagVectors();
│ │ │ │ +
273 void populateVertexTagsFromParentFaces();
│ │ │ │ +
274 void populateVertexTagsFromParentEdges();
│ │ │ │ +
275 void populateVertexTagsFromParentVertices();
│ │ │ │ +
276
│ │ │ │ +
277 //
│ │ │ │ +
278 // Methods (and types) involved in subdividing the topology -- though not
│ │ │ │ +
279 // fully exploited, any subset of the 6 relations can be generated:
│ │ │ │ +
280 //
│ │ │ │ +
281 struct Relations {
│ │ │ │ +
282 unsigned int _faceVertices : 1;
│ │ │ │ +
283 unsigned int _faceEdges : 1;
│ │ │ │ +
284 unsigned int _edgeVertices : 1;
│ │ │ │ +
285 unsigned int _edgeFaces : 1;
│ │ │ │ +
286 unsigned int _vertexFaces : 1;
│ │ │ │ +
287 unsigned int _vertexEdges : 1;
│ │ │ │
288
│ │ │ │ -
289 // Debugging aides:
│ │ │ │ -
290 enum TopologyError {
│ │ │ │ -
291 TOPOLOGY_MISSING_EDGE_FACES=0,
│ │ │ │ -
292 TOPOLOGY_MISSING_EDGE_VERTS,
│ │ │ │ -
293 TOPOLOGY_MISSING_FACE_EDGES,
│ │ │ │ -
294 TOPOLOGY_MISSING_FACE_VERTS,
│ │ │ │ -
295 TOPOLOGY_MISSING_VERT_FACES,
│ │ │ │ -
296 TOPOLOGY_MISSING_VERT_EDGES,
│ │ │ │ -
297
│ │ │ │ -
298 TOPOLOGY_FAILED_CORRELATION_EDGE_FACE,
│ │ │ │ -
299 TOPOLOGY_FAILED_CORRELATION_FACE_VERT,
│ │ │ │ -
300 TOPOLOGY_FAILED_CORRELATION_FACE_EDGE,
│ │ │ │ -
301
│ │ │ │ -
302 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_EDGE,
│ │ │ │ -
303 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_FACE,
│ │ │ │ -
304 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_FACES_EDGES,
│ │ │ │ -
305
│ │ │ │ -
306 TOPOLOGY_DEGENERATE_EDGE,
│ │ │ │ -
307 TOPOLOGY_NON_MANIFOLD_EDGE,
│ │ │ │ -
308
│ │ │ │ -
309 TOPOLOGY_INVALID_CREASE_EDGE,
│ │ │ │ -
310 TOPOLOGY_INVALID_CREASE_VERT
│ │ │ │ -
311 };
│ │ │ │ +
289 void setAll(bool enable) {
│ │ │ │ +
290 _faceVertices = enable;
│ │ │ │ +
291 _faceEdges = enable;
│ │ │ │ +
292 _edgeVertices = enable;
│ │ │ │ +
293 _edgeFaces = enable;
│ │ │ │ +
294 _vertexFaces = enable;
│ │ │ │ +
295 _vertexEdges = enable;
│ │ │ │ +
296 }
│ │ │ │ +
297 };
│ │ │ │ +
298
│ │ │ │ +
299 void subdivideTopology(Relations const& relationsToSubdivide);
│ │ │ │ +
300
│ │ │ │ +
301 virtual void populateFaceVertexRelation() = 0;
│ │ │ │ +
302 virtual void populateFaceEdgeRelation() = 0;
│ │ │ │ +
303 virtual void populateEdgeVertexRelation() = 0;
│ │ │ │ +
304 virtual void populateEdgeFaceRelation() = 0;
│ │ │ │ +
305 virtual void populateVertexFaceRelation() = 0;
│ │ │ │ +
306 virtual void populateVertexEdgeRelation() = 0;
│ │ │ │ +
307
│ │ │ │ +
308 //
│ │ │ │ +
309 // Methods involved in subdividing and inspecting sharpness values:
│ │ │ │ +
310 //
│ │ │ │ +
311 void subdivideSharpnessValues();
│ │ │ │
312
│ │ │ │ -
313 static char const * getTopologyErrorString(TopologyError errCode);
│ │ │ │ -
314
│ │ │ │ -
315 typedef void (* ValidationCallback)(TopologyError errCode, char const * msg, void const * clientData);
│ │ │ │ +
313 void subdivideVertexSharpness();
│ │ │ │ +
314 void subdivideEdgeSharpness();
│ │ │ │ +
315 void reclassifySemisharpVertices();
│ │ │ │
316
│ │ │ │ -
317 bool validateTopology(ValidationCallback callback=0, void const * clientData=0) const;
│ │ │ │ -
318
│ │ │ │ -
319 void print(const Refinement* parentRefinement = 0) const;
│ │ │ │ -
320
│ │ │ │ -
321public:
│ │ │ │ -
322 // High-level topology queries -- these may be moved elsewhere:
│ │ │ │ -
323
│ │ │ │ -
324 bool isSingleCreasePatch(Index face, float* sharpnessOut=NULL, int* rotationOut=NULL) const;
│ │ │ │ +
317 //
│ │ │ │ +
318 // Methods involved in subdividing face-varying topology:
│ │ │ │ +
319 //
│ │ │ │ +
320 void subdivideFVarChannels();
│ │ │ │ +
321
│ │ │ │ +
322protected:
│ │ │ │ +
323 // A debug method of Level prints a Refinement (should really change this)
│ │ │ │ +
324 friend void Level::print(const Refinement *) const;
│ │ │ │
325
│ │ │ │
326 //
│ │ │ │ -
327 // When inspecting topology, the component tags -- particularly VTag and ETag -- are most
│ │ │ │ -
328 // often inspected in groups for the face to which they belong. They are designed to be
│ │ │ │ -
329 // bitwise OR'd (the result then referred to as a "composite" tag) to make quick decisions
│ │ │ │ -
330 // about the face as a whole to avoid tedious topological inspection.
│ │ │ │ -
331 //
│ │ │ │ -
332 // The same logic can be applied to topology in a FVar channel when tags specific to that
│ │ │ │ -
333 // channel are used. Note that the VTags apply to the FVar values assigned to the corners
│ │ │ │ -
334 // of the face and not the vertex as a whole. The "composite" face-varying VTag for a
│ │ │ │ -
335 // vertex is the union of VTags of all distinct FVar values for that vertex.
│ │ │ │ -
336 //
│ │ │ │ -
337 bool doesVertexFVarTopologyMatch(Index vIndex, int fvarChannel) const;
│ │ │ │ -
338 bool doesFaceFVarTopologyMatch( Index fIndex, int fvarChannel) const;
│ │ │ │ -
339 bool doesEdgeFVarTopologyMatch( Index eIndex, int fvarChannel) const;
│ │ │ │ -
340
│ │ │ │ -
341 void getFaceVTags(Index fIndex, VTag vTags[], int fvarChannel = -1) const;
│ │ │ │ -
342 void getFaceETags(Index fIndex, ETag eTags[], int fvarChannel = -1) const;
│ │ │ │ +
327 // Data members -- the logical grouping of some of these (and methods that make use
│ │ │ │ +
328 // of them) may lead to grouping them into a few utility classes or structs...
│ │ │ │ +
329 //
│ │ │ │ +
330
│ │ │ │ +
331 // Defined on construction:
│ │ │ │ +
332 Level const * _parent;
│ │ │ │ +
333 Level * _child;
│ │ │ │ +
334 Sdc::Options _options;
│ │ │ │ +
335
│ │ │ │ +
336 // Defined by the subclass:
│ │ │ │ +
337 Sdc::Split _splitType;
│ │ │ │ +
338 int _regFaceSize;
│ │ │ │ +
339
│ │ │ │ +
340 // Determined by the refinement options:
│ │ │ │ +
341 bool _uniform;
│ │ │ │ +
342 bool _faceVertsFirst;
│ │ │ │
343
│ │ │ │ -
344 VTag getFaceCompositeVTag(Index fIndex, int fvarChannel = -1) const;
│ │ │ │ -
345 VTag getFaceCompositeVTag(ConstIndexArray & fVerts) const;
│ │ │ │ -
346
│ │ │ │ -
347 VTag getVertexCompositeFVarVTag(Index vIndex, int fvarChannel) const;
│ │ │ │ -
348
│ │ │ │ -
349 //
│ │ │ │ -
350 // When gathering "patch points" we may want the indices of the vertices or the corresponding
│ │ │ │ -
351 // FVar values for a particular channel. Both are represented and equally accessible within
│ │ │ │ -
352 // the faces, so we allow all to be returned through these methods. Setting the optional FVar
│ │ │ │ -
353 // channel to -1 will retrieve indices of vertices instead of FVar values:
│ │ │ │ -
354 //
│ │ │ │ -
355 int gatherQuadLinearPatchPoints(Index fIndex, Index patchPoints[], int rotation = 0,
│ │ │ │ -
356 int fvarChannel = -1) const;
│ │ │ │ -
357
│ │ │ │ -
358 int gatherQuadRegularInteriorPatchPoints(Index fIndex, Index patchPoints[], int rotation = 0,
│ │ │ │ -
359 int fvarChannel = -1) const;
│ │ │ │ -
360 int gatherQuadRegularBoundaryPatchPoints(Index fIndex, Index patchPoints[], int boundaryEdgeInFace,
│ │ │ │ -
361 int fvarChannel = -1) const;
│ │ │ │ -
362 int gatherQuadRegularCornerPatchPoints( Index fIndex, Index patchPoints[], int cornerVertInFace,
│ │ │ │ -
363 int fvarChannel = -1) const;
│ │ │ │ -
364
│ │ │ │ -
365 int gatherQuadRegularRingAroundVertex(Index vIndex, Index ringPoints[],
│ │ │ │ -
366 int fvarChannel = -1) const;
│ │ │ │ -
367 int gatherQuadRegularPartialRingAroundVertex(Index vIndex, VSpan const & span, Index ringPoints[],
│ │ │ │ -
368 int fvarChannel = -1) const;
│ │ │ │ -
369
│ │ │ │ -
370 // WIP -- for future use, need to extend for face-varying...
│ │ │ │ -
371 int gatherTriRegularInteriorPatchPoints( Index fIndex, Index patchVerts[], int rotation = 0) const;
│ │ │ │ -
372 int gatherTriRegularBoundaryVertexPatchPoints(Index fIndex, Index patchVerts[], int boundaryVertInFace) const;
│ │ │ │ -
373 int gatherTriRegularBoundaryEdgePatchPoints( Index fIndex, Index patchVerts[], int boundaryEdgeInFace) const;
│ │ │ │ -
374 int gatherTriRegularCornerVertexPatchPoints( Index fIndex, Index patchVerts[], int cornerVertInFace) const;
│ │ │ │ -
375 int gatherTriRegularCornerEdgePatchPoints( Index fIndex, Index patchVerts[], int cornerEdgeInFace) const;
│ │ │ │ +
344 //
│ │ │ │ +
345 // Inventory and ordering of the types of child components:
│ │ │ │ +
346 //
│ │ │ │ +
347 int _childFaceFromFaceCount; // arguably redundant (all faces originate from faces)
│ │ │ │ +
348 int _childEdgeFromFaceCount;
│ │ │ │ +
349 int _childEdgeFromEdgeCount;
│ │ │ │ +
350 int _childVertFromFaceCount;
│ │ │ │ +
351 int _childVertFromEdgeCount;
│ │ │ │ +
352 int _childVertFromVertCount;
│ │ │ │ +
353
│ │ │ │ +
354 int _firstChildFaceFromFace; // arguably redundant (all faces originate from faces)
│ │ │ │ +
355 int _firstChildEdgeFromFace;
│ │ │ │ +
356 int _firstChildEdgeFromEdge;
│ │ │ │ +
357 int _firstChildVertFromFace;
│ │ │ │ +
358 int _firstChildVertFromEdge;
│ │ │ │ +
359 int _firstChildVertFromVert;
│ │ │ │ +
360
│ │ │ │ +
361 //
│ │ │ │ +
362 // The parent-to-child mapping:
│ │ │ │ +
363 // These are vectors sized according to the number of parent components (and
│ │ │ │ +
364 // their topology) that contain references/indices to the child components that
│ │ │ │ +
365 // result from them by refinement. When refinement is sparse, parent components
│ │ │ │ +
366 // that have not spawned all child components will have their missing children
│ │ │ │ +
367 // marked as invalid.
│ │ │ │ +
368 //
│ │ │ │ +
369 // NOTE the "Array" members here. Often vectors within the Level can be shared
│ │ │ │ +
370 // with the Refinement, and an Array instance is used to do so. If not shared
│ │ │ │ +
371 // the subclass just initializes the Array members after allocating its own local
│ │ │ │ +
372 // vector members.
│ │ │ │ +
373 //
│ │ │ │ +
374 IndexArray _faceChildFaceCountsAndOffsets;
│ │ │ │ +
375 IndexArray _faceChildEdgeCountsAndOffsets;
│ │ │ │
376
│ │ │ │ -
377public:
│ │ │ │ -
378 // Sizing methods used to construct a level to populate:
│ │ │ │ -
379 void resizeFaces( int numFaces);
│ │ │ │ -
380 void resizeFaceVertices(int numFaceVertsTotal);
│ │ │ │ -
381 void resizeFaceEdges( int numFaceEdgesTotal);
│ │ │ │ -
382
│ │ │ │ -
383 void resizeEdges( int numEdges);
│ │ │ │ -
384 void resizeEdgeVertices(); // always 2*edgeCount
│ │ │ │ -
385 void resizeEdgeFaces(int numEdgeFacesTotal);
│ │ │ │ -
386
│ │ │ │ -
387 void resizeVertices( int numVertices);
│ │ │ │ -
388 void resizeVertexFaces(int numVertexFacesTotal);
│ │ │ │ -
389 void resizeVertexEdges(int numVertexEdgesTotal);
│ │ │ │ -
390
│ │ │ │ -
391 void setMaxValence(int maxValence);
│ │ │ │ +
377 IndexVector _faceChildFaceIndices; // *cannot* always use face-vert counts/offsets
│ │ │ │ +
378 IndexVector _faceChildEdgeIndices; // can use face-vert counts/offsets
│ │ │ │ +
379 IndexVector _faceChildVertIndex;
│ │ │ │ +
380
│ │ │ │ +
381 IndexVector _edgeChildEdgeIndices; // trivial/corresponding pair for each
│ │ │ │ +
382 IndexVector _edgeChildVertIndex;
│ │ │ │ +
383
│ │ │ │ +
384 IndexVector _vertChildVertIndex;
│ │ │ │ +
385
│ │ │ │ +
386 //
│ │ │ │ +
387 // The child-to-parent mapping:
│ │ │ │ +
388 //
│ │ │ │ +
389 IndexVector _childFaceParentIndex;
│ │ │ │ +
390 IndexVector _childEdgeParentIndex;
│ │ │ │ +
391 IndexVector _childVertexParentIndex;
│ │ │ │
392
│ │ │ │ -
393 // Modifiers to populate the relations for each component:
│ │ │ │ -
394 IndexArray getFaceVertices(Index faceIndex);
│ │ │ │ -
395 IndexArray getFaceEdges(Index faceIndex);
│ │ │ │ -
396 IndexArray getEdgeVertices(Index edgeIndex);
│ │ │ │ -
397 IndexArray getEdgeFaces(Index edgeIndex);
│ │ │ │ -
398 IndexArray getVertexFaces(Index vertIndex);
│ │ │ │ -
399 IndexArray getVertexEdges(Index vertIndex);
│ │ │ │ -
400
│ │ │ │ -
401 LocalIndexArray getEdgeFaceLocalIndices(Index edgeIndex);
│ │ │ │ -
402 LocalIndexArray getVertexFaceLocalIndices(Index vertIndex);
│ │ │ │ -
403 LocalIndexArray getVertexEdgeLocalIndices(Index vertIndex);
│ │ │ │ -
404
│ │ │ │ -
405 // Replace these with access to sharpness buffers/arrays rather than elements:
│ │ │ │ -
406 float& getEdgeSharpness(Index edgeIndex);
│ │ │ │ -
407 float& getVertexSharpness(Index vertIndex);
│ │ │ │ -
408
│ │ │ │ -
409 // Create, destroy and populate face-varying channels:
│ │ │ │ -
410 int createFVarChannel(int fvarValueCount, Sdc::Options const& options);
│ │ │ │ -
411 void destroyFVarChannel(int channel);
│ │ │ │ +
393 std::vector<ChildTag> _childFaceTag;
│ │ │ │ +
394 std::vector<ChildTag> _childEdgeTag;
│ │ │ │ +
395 std::vector<ChildTag> _childVertexTag;
│ │ │ │ +
396
│ │ │ │ +
397 //
│ │ │ │ +
398 // Tags for sparse selection of components:
│ │ │ │ +
399 //
│ │ │ │ +
400 std::vector<SparseTag> _parentFaceTag;
│ │ │ │ +
401 std::vector<SparseTag> _parentEdgeTag;
│ │ │ │ +
402 std::vector<SparseTag> _parentVertexTag;
│ │ │ │ +
403
│ │ │ │ +
404 //
│ │ │ │ +
405 // Refinement data for face-varying channels present in the Levels being refined:
│ │ │ │ +
406 //
│ │ │ │ +
407 std::vector<FVarRefinement*> _fvarChannels;
│ │ │ │ +
408};
│ │ │ │ +
409
│ │ │ │ +
410inline ConstIndexArray
│ │ │ │ +
411Refinement::getFaceChildFaces(Index parentFace) const {
│ │ │ │
412
│ │ │ │ -
413 IndexArray getFaceFVarValues(Index faceIndex, int channel);
│ │ │ │ -
414
│ │ │ │ -
415 void completeFVarChannelTopology(int channel, int regBoundaryValence);
│ │ │ │ +
413 return ConstIndexArray(&_faceChildFaceIndices[_faceChildFaceCountsAndOffsets[2*parentFace+1]],
│ │ │ │ +
414 _faceChildFaceCountsAndOffsets[2*parentFace]);
│ │ │ │ +
415}
│ │ │ │
416
│ │ │ │ -
417 // Counts and offsets for all relation types:
│ │ │ │ -
418 // - these may be unwarranted if we let Refinement access members directly...
│ │ │ │ -
419 int getNumFaceVertices( Index faceIndex) const { return _faceVertCountsAndOffsets[2*faceIndex]; }
│ │ │ │ -
420 int getOffsetOfFaceVertices(Index faceIndex) const { return _faceVertCountsAndOffsets[2*faceIndex + 1]; }
│ │ │ │ -
421
│ │ │ │ -
422 int getNumFaceEdges( Index faceIndex) const { return getNumFaceVertices(faceIndex); }
│ │ │ │ -
423 int getOffsetOfFaceEdges(Index faceIndex) const { return getOffsetOfFaceVertices(faceIndex); }
│ │ │ │ -
424
│ │ │ │ -
425 int getNumEdgeVertices( Index ) const { return 2; }
│ │ │ │ -
426 int getOffsetOfEdgeVertices(Index edgeIndex) const { return 2 * edgeIndex; }
│ │ │ │ -
427
│ │ │ │ -
428 int getNumEdgeFaces( Index edgeIndex) const { return _edgeFaceCountsAndOffsets[2*edgeIndex]; }
│ │ │ │ -
429 int getOffsetOfEdgeFaces(Index edgeIndex) const { return _edgeFaceCountsAndOffsets[2*edgeIndex + 1]; }
│ │ │ │ -
430
│ │ │ │ -
431 int getNumVertexFaces( Index vertIndex) const { return _vertFaceCountsAndOffsets[2*vertIndex]; }
│ │ │ │ -
432 int getOffsetOfVertexFaces(Index vertIndex) const { return _vertFaceCountsAndOffsets[2*vertIndex + 1]; }
│ │ │ │ -
433
│ │ │ │ -
434 int getNumVertexEdges( Index vertIndex) const { return _vertEdgeCountsAndOffsets[2*vertIndex]; }
│ │ │ │ -
435 int getOffsetOfVertexEdges(Index vertIndex) const { return _vertEdgeCountsAndOffsets[2*vertIndex + 1]; }
│ │ │ │ +
417inline IndexArray
│ │ │ │ +
418Refinement::getFaceChildFaces(Index parentFace) {
│ │ │ │ +
419
│ │ │ │ +
420 return IndexArray(&_faceChildFaceIndices[_faceChildFaceCountsAndOffsets[2*parentFace+1]],
│ │ │ │ +
421 _faceChildFaceCountsAndOffsets[2*parentFace]);
│ │ │ │ +
422}
│ │ │ │ +
423
│ │ │ │ +
424inline ConstIndexArray
│ │ │ │ +
425Refinement::getFaceChildEdges(Index parentFace) const {
│ │ │ │ +
426
│ │ │ │ +
427 return ConstIndexArray(&_faceChildEdgeIndices[_faceChildEdgeCountsAndOffsets[2*parentFace+1]],
│ │ │ │ +
428 _faceChildEdgeCountsAndOffsets[2*parentFace]);
│ │ │ │ +
429}
│ │ │ │ +
430inline IndexArray
│ │ │ │ +
431Refinement::getFaceChildEdges(Index parentFace) {
│ │ │ │ +
432
│ │ │ │ +
433 return IndexArray(&_faceChildEdgeIndices[_faceChildEdgeCountsAndOffsets[2*parentFace+1]],
│ │ │ │ +
434 _faceChildEdgeCountsAndOffsets[2*parentFace]);
│ │ │ │ +
435}
│ │ │ │
436
│ │ │ │ -
437 ConstIndexArray getFaceVertices() const;
│ │ │ │ -
438
│ │ │ │ -
439 //
│ │ │ │ -
440 // Note that for some relations, the size of the relations for a child component
│ │ │ │ -
441 // can vary radically from its parent due to the sparsity of the refinement. So
│ │ │ │ -
442 // in these cases a few additional utilities are provided to help define the set
│ │ │ │ -
443 // of incident components. Assuming adequate memory has been allocated, the
│ │ │ │ -
444 // "resize" methods here initialize the set of incident components by setting
│ │ │ │ -
445 // both the size and the appropriate offset, while "trim" is use to quickly lower
│ │ │ │ -
446 // the size from an upper bound and nothing else.
│ │ │ │ -
447 //
│ │ │ │ -
448 void resizeFaceVertices(Index FaceIndex, int count);
│ │ │ │ -
449
│ │ │ │ -
450 void resizeEdgeFaces(Index edgeIndex, int count);
│ │ │ │ -
451 void trimEdgeFaces( Index edgeIndex, int count);
│ │ │ │ -
452
│ │ │ │ -
453 void resizeVertexFaces(Index vertIndex, int count);
│ │ │ │ -
454 void trimVertexFaces( Index vertIndex, int count);
│ │ │ │ +
437inline ConstIndexArray
│ │ │ │ +
438Refinement::getEdgeChildEdges(Index parentEdge) const {
│ │ │ │ +
439
│ │ │ │ +
440 return ConstIndexArray(&_edgeChildEdgeIndices[parentEdge*2], 2);
│ │ │ │ +
441}
│ │ │ │ +
442
│ │ │ │ +
443inline IndexArray
│ │ │ │ +
444Refinement::getEdgeChildEdges(Index parentEdge) {
│ │ │ │ +
445
│ │ │ │ +
446 return IndexArray(&_edgeChildEdgeIndices[parentEdge*2], 2);
│ │ │ │ +
447}
│ │ │ │ +
448
│ │ │ │ +
449} // end namespace internal
│ │ │ │ +
450} // end namespace Vtr
│ │ │ │ +
451
│ │ │ │ +
452} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
453using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
454} // end namespace OpenSubdiv
│ │ │ │
455
│ │ │ │ -
456 void resizeVertexEdges(Index vertIndex, int count);
│ │ │ │ -
457 void trimVertexEdges( Index vertIndex, int count);
│ │ │ │ -
458
│ │ │ │ -
459public:
│ │ │ │ -
460 //
│ │ │ │ -
461 // Initial plans were to have a few specific classes properly construct the
│ │ │ │ -
462 // topology from scratch, e.g. the Refinement class and a Factory class for
│ │ │ │ -
463 // the base level, by populating all topological relations. The need to have
│ │ │ │ -
464 // a class construct full topology given only a simple face-vertex list, made
│ │ │ │ -
465 // it necessary to write code to define and orient all relations -- and most
│ │ │ │ -
466 // of that seemed best placed here.
│ │ │ │ -
467 //
│ │ │ │ -
468 bool completeTopologyFromFaceVertices();
│ │ │ │ -
469 Index findEdge(Index v0, Index v1, ConstIndexArray v0Edges) const;
│ │ │ │ -
470
│ │ │ │ -
471 // Methods supporting the above:
│ │ │ │ -
472 void orientIncidentComponents();
│ │ │ │ -
473 bool orderVertexFacesAndEdges(Index vIndex, Index* vFaces, Index* vEdges) const;
│ │ │ │ -
474 bool orderVertexFacesAndEdges(Index vIndex);
│ │ │ │ -
475 void populateLocalIndices();
│ │ │ │ -
476
│ │ │ │ -
477 IndexArray shareFaceVertCountsAndOffsets() const;
│ │ │ │ -
478
│ │ │ │ -
479private:
│ │ │ │ -
480 // Refinement classes (including all subclasses) build a Level:
│ │ │ │ -
481 friend class Refinement;
│ │ │ │ -
482 friend class TriRefinement;
│ │ │ │ -
483 friend class QuadRefinement;
│ │ │ │ -
484
│ │ │ │ -
485 //
│ │ │ │ -
486 // A Level is independent of subdivision scheme or options. While it may have been
│ │ │ │ -
487 // affected by them in its construction, they are not associated with it -- a Level
│ │ │ │ -
488 // is pure topology and any subdivision parameters are external.
│ │ │ │ -
489 //
│ │ │ │ -
490
│ │ │ │ -
491 // Simple members for inventory, etc.
│ │ │ │ -
492 int _faceCount;
│ │ │ │ -
493 int _edgeCount;
│ │ │ │ -
494 int _vertCount;
│ │ │ │ -
495
│ │ │ │ -
496 // The "depth" member is clearly useful in both the topological splitting and the
│ │ │ │ -
497 // stencil queries, but arguably it ties the Level to a hierarchy which counters
│ │ │ │ -
498 // the idea of it being independent.
│ │ │ │ -
499 int _depth;
│ │ │ │ -
500
│ │ │ │ -
501 // Maxima to help clients manage sizing of data buffers. Given "max valence",
│ │ │ │ -
502 // the "max edge faces" is strictly redundant as it will always be less, but
│ │ │ │ -
503 // since it will typically be so much less (i.e. 2) it is kept for now.
│ │ │ │ -
504 int _maxEdgeFaces;
│ │ │ │ -
505 int _maxValence;
│ │ │ │ -
506
│ │ │ │ -
507 //
│ │ │ │ -
508 // Topology vectors:
│ │ │ │ -
509 // Note that of all of these, only data for the face-edge relation is not
│ │ │ │ -
510 // stored in the osd::FarTables in any form. The FarTable vectors combine
│ │ │ │ -
511 // the edge-vert and edge-face relations. The eventual goal is that this
│ │ │ │ -
512 // data be part of the osd::Far classes and be a superset of the FarTable
│ │ │ │ -
513 // vectors, i.e. no data duplication or conversion. The fact that FarTable
│ │ │ │ -
514 // already stores 5 of the 6 possible relations should make the topology
│ │ │ │ -
515 // storage as a whole a non-issue.
│ │ │ │ -
516 //
│ │ │ │ -
517 // The vert-face-child and vert-edge-child indices are also arguably not
│ │ │ │ -
518 // a topology relation but more one for parent/child relations. But it is
│ │ │ │ -
519 // a topological relationship, and if named differently would not likely
│ │ │ │ -
520 // raise this. It has been named with "child" in the name as it does play
│ │ │ │ -
521 // a more significant role during subdivision in mapping between parent
│ │ │ │ -
522 // and child components, and so has been named to reflect that more clearly.
│ │ │ │ -
523 //
│ │ │ │ -
524
│ │ │ │ -
525 // Per-face:
│ │ │ │ -
526 std::vector<Index> _faceVertCountsAndOffsets; // 2 per face, redundant after level 0
│ │ │ │ -
527 std::vector<Index> _faceVertIndices; // 3 or 4 per face, variable at level 0
│ │ │ │ -
528 std::vector<Index> _faceEdgeIndices; // matches face-vert indices
│ │ │ │ -
529 std::vector<FTag> _faceTags; // 1 per face: includes "hole" tag
│ │ │ │ -
530
│ │ │ │ -
531 // Per-edge:
│ │ │ │ -
532 std::vector<Index> _edgeVertIndices; // 2 per edge
│ │ │ │ -
533 std::vector<Index> _edgeFaceCountsAndOffsets; // 2 per edge
│ │ │ │ -
534 std::vector<Index> _edgeFaceIndices; // varies with faces per edge
│ │ │ │ -
535 std::vector<LocalIndex> _edgeFaceLocalIndices; // varies with faces per edge
│ │ │ │ -
536
│ │ │ │ -
537 std::vector<float> _edgeSharpness; // 1 per edge
│ │ │ │ -
538 std::vector<ETag> _edgeTags; // 1 per edge: manifold, boundary, etc.
│ │ │ │ -
539
│ │ │ │ -
540 // Per-vertex:
│ │ │ │ -
541 std::vector<Index> _vertFaceCountsAndOffsets; // 2 per vertex
│ │ │ │ -
542 std::vector<Index> _vertFaceIndices; // varies with valence
│ │ │ │ -
543 std::vector<LocalIndex> _vertFaceLocalIndices; // varies with valence, 8-bit for now
│ │ │ │ -
544
│ │ │ │ -
545 std::vector<Index> _vertEdgeCountsAndOffsets; // 2 per vertex
│ │ │ │ -
546 std::vector<Index> _vertEdgeIndices; // varies with valence
│ │ │ │ -
547 std::vector<LocalIndex> _vertEdgeLocalIndices; // varies with valence, 8-bit for now
│ │ │ │ -
548
│ │ │ │ -
549 std::vector<float> _vertSharpness; // 1 per vertex
│ │ │ │ -
550 std::vector<VTag> _vertTags; // 1 per vertex: manifold, Sdc::Rule, etc.
│ │ │ │ -
551
│ │ │ │ -
552 // Face-varying channels:
│ │ │ │ -
553 std::vector<FVarLevel*> _fvarChannels;
│ │ │ │ -
554};
│ │ │ │ -
555
│ │ │ │ -
556//
│ │ │ │ -
557// Access/modify the vertices incident a given face:
│ │ │ │ -
558//
│ │ │ │ -
559inline ConstIndexArray
│ │ │ │ -
560Level::getFaceVertices(Index faceIndex) const {
│ │ │ │ -
561 return ConstIndexArray(&_faceVertIndices[_faceVertCountsAndOffsets[faceIndex*2+1]],
│ │ │ │ -
562 _faceVertCountsAndOffsets[faceIndex*2]);
│ │ │ │ -
563}
│ │ │ │ -
564inline IndexArray
│ │ │ │ -
565Level::getFaceVertices(Index faceIndex) {
│ │ │ │ -
566 return IndexArray(&_faceVertIndices[_faceVertCountsAndOffsets[faceIndex*2+1]],
│ │ │ │ -
567 _faceVertCountsAndOffsets[faceIndex*2]);
│ │ │ │ -
568}
│ │ │ │ -
569
│ │ │ │ -
570inline void
│ │ │ │ -
571Level::resizeFaceVertices(Index faceIndex, int count) {
│ │ │ │ -
572
│ │ │ │ -
573 int* countOffsetPair = &_faceVertCountsAndOffsets[faceIndex*2];
│ │ │ │ -
574
│ │ │ │ -
575 countOffsetPair[0] = count;
│ │ │ │ -
576 countOffsetPair[1] = (faceIndex == 0) ? 0 : (countOffsetPair[-2] + countOffsetPair[-1]);
│ │ │ │ -
577
│ │ │ │ -
578 _maxValence = std::max(_maxValence, count);
│ │ │ │ -
579}
│ │ │ │ -
580
│ │ │ │ -
581inline ConstIndexArray
│ │ │ │ -
582Level::getFaceVertices() const {
│ │ │ │ -
583 return ConstIndexArray(&_faceVertIndices[0], (int)_faceVertIndices.size());
│ │ │ │ -
584}
│ │ │ │ -
585
│ │ │ │ -
586//
│ │ │ │ -
587// Access/modify the edges incident a given face:
│ │ │ │ -
588//
│ │ │ │ -
589inline ConstIndexArray
│ │ │ │ -
590Level::getFaceEdges(Index faceIndex) const {
│ │ │ │ -
591 return ConstIndexArray(&_faceEdgeIndices[_faceVertCountsAndOffsets[faceIndex*2+1]],
│ │ │ │ -
592 _faceVertCountsAndOffsets[faceIndex*2]);
│ │ │ │ -
593}
│ │ │ │ -
594inline IndexArray
│ │ │ │ -
595Level::getFaceEdges(Index faceIndex) {
│ │ │ │ -
596 return IndexArray(&_faceEdgeIndices[_faceVertCountsAndOffsets[faceIndex*2+1]],
│ │ │ │ -
597 _faceVertCountsAndOffsets[faceIndex*2]);
│ │ │ │ -
598}
│ │ │ │ -
599
│ │ │ │ -
600//
│ │ │ │ -
601// Access/modify the faces incident a given vertex:
│ │ │ │ -
602//
│ │ │ │ -
603inline ConstIndexArray
│ │ │ │ -
604Level::getVertexFaces(Index vertIndex) const {
│ │ │ │ -
605 return ConstIndexArray( (&_vertFaceIndices[0]) + _vertFaceCountsAndOffsets[vertIndex*2+1],
│ │ │ │ -
606 _vertFaceCountsAndOffsets[vertIndex*2]);
│ │ │ │ -
607}
│ │ │ │ -
608inline IndexArray
│ │ │ │ -
609Level::getVertexFaces(Index vertIndex) {
│ │ │ │ -
610 return IndexArray( (&_vertFaceIndices[0]) + _vertFaceCountsAndOffsets[vertIndex*2+1],
│ │ │ │ -
611 _vertFaceCountsAndOffsets[vertIndex*2]);
│ │ │ │ -
612}
│ │ │ │ -
613
│ │ │ │ - │ │ │ │ -
615Level::getVertexFaceLocalIndices(Index vertIndex) const {
│ │ │ │ -
616 return ConstLocalIndexArray( (&_vertFaceLocalIndices[0]) + _vertFaceCountsAndOffsets[vertIndex*2+1],
│ │ │ │ -
617 _vertFaceCountsAndOffsets[vertIndex*2]);
│ │ │ │ -
618}
│ │ │ │ -
619inline LocalIndexArray
│ │ │ │ -
620Level::getVertexFaceLocalIndices(Index vertIndex) {
│ │ │ │ -
621 return LocalIndexArray( (&_vertFaceLocalIndices[0]) + _vertFaceCountsAndOffsets[vertIndex*2+1],
│ │ │ │ -
622 _vertFaceCountsAndOffsets[vertIndex*2]);
│ │ │ │ -
623}
│ │ │ │ -
624
│ │ │ │ -
625inline void
│ │ │ │ -
626Level::resizeVertexFaces(Index vertIndex, int count) {
│ │ │ │ -
627 int* countOffsetPair = &_vertFaceCountsAndOffsets[vertIndex*2];
│ │ │ │ -
628
│ │ │ │ -
629 countOffsetPair[0] = count;
│ │ │ │ -
630 countOffsetPair[1] = (vertIndex == 0) ? 0 : (countOffsetPair[-2] + countOffsetPair[-1]);
│ │ │ │ -
631}
│ │ │ │ -
632inline void
│ │ │ │ -
633Level::trimVertexFaces(Index vertIndex, int count) {
│ │ │ │ -
634 _vertFaceCountsAndOffsets[vertIndex*2] = count;
│ │ │ │ -
635}
│ │ │ │ -
636
│ │ │ │ -
637//
│ │ │ │ -
638// Access/modify the edges incident a given vertex:
│ │ │ │ -
639//
│ │ │ │ -
640inline ConstIndexArray
│ │ │ │ -
641Level::getVertexEdges(Index vertIndex) const {
│ │ │ │ -
642 return ConstIndexArray( (&_vertEdgeIndices[0]) +_vertEdgeCountsAndOffsets[vertIndex*2+1],
│ │ │ │ -
643 _vertEdgeCountsAndOffsets[vertIndex*2]);
│ │ │ │ -
644}
│ │ │ │ -
645inline IndexArray
│ │ │ │ -
646Level::getVertexEdges(Index vertIndex) {
│ │ │ │ -
647 return IndexArray( (&_vertEdgeIndices[0]) +_vertEdgeCountsAndOffsets[vertIndex*2+1],
│ │ │ │ -
648 _vertEdgeCountsAndOffsets[vertIndex*2]);
│ │ │ │ -
649}
│ │ │ │ -
650
│ │ │ │ - │ │ │ │ -
652Level::getVertexEdgeLocalIndices(Index vertIndex) const {
│ │ │ │ -
653 return ConstLocalIndexArray( (&_vertEdgeLocalIndices[0]) + _vertEdgeCountsAndOffsets[vertIndex*2+1],
│ │ │ │ -
654 _vertEdgeCountsAndOffsets[vertIndex*2]);
│ │ │ │ -
655}
│ │ │ │ -
656inline LocalIndexArray
│ │ │ │ -
657Level::getVertexEdgeLocalIndices(Index vertIndex) {
│ │ │ │ -
658 return LocalIndexArray( (&_vertEdgeLocalIndices[0]) + _vertEdgeCountsAndOffsets[vertIndex*2+1],
│ │ │ │ -
659 _vertEdgeCountsAndOffsets[vertIndex*2]);
│ │ │ │ -
660}
│ │ │ │ -
661
│ │ │ │ -
662inline void
│ │ │ │ -
663Level::resizeVertexEdges(Index vertIndex, int count) {
│ │ │ │ -
664 int* countOffsetPair = &_vertEdgeCountsAndOffsets[vertIndex*2];
│ │ │ │ -
665
│ │ │ │ -
666 countOffsetPair[0] = count;
│ │ │ │ -
667 countOffsetPair[1] = (vertIndex == 0) ? 0 : (countOffsetPair[-2] + countOffsetPair[-1]);
│ │ │ │ -
668
│ │ │ │ -
669 _maxValence = std::max(_maxValence, count);
│ │ │ │ -
670}
│ │ │ │ -
671inline void
│ │ │ │ -
672Level::trimVertexEdges(Index vertIndex, int count) {
│ │ │ │ -
673 _vertEdgeCountsAndOffsets[vertIndex*2] = count;
│ │ │ │ -
674}
│ │ │ │ -
675
│ │ │ │ -
676inline void
│ │ │ │ -
677Level::setMaxValence(int valence) {
│ │ │ │ -
678 _maxValence = valence;
│ │ │ │ -
679}
│ │ │ │ -
680
│ │ │ │ -
681//
│ │ │ │ -
682// Access/modify the vertices incident a given edge:
│ │ │ │ -
683//
│ │ │ │ -
684inline ConstIndexArray
│ │ │ │ -
685Level::getEdgeVertices(Index edgeIndex) const {
│ │ │ │ -
686 return ConstIndexArray(&_edgeVertIndices[edgeIndex*2], 2);
│ │ │ │ -
687}
│ │ │ │ -
688inline IndexArray
│ │ │ │ -
689Level::getEdgeVertices(Index edgeIndex) {
│ │ │ │ -
690 return IndexArray(&_edgeVertIndices[edgeIndex*2], 2);
│ │ │ │ -
691}
│ │ │ │ -
692
│ │ │ │ -
693//
│ │ │ │ -
694// Access/modify the faces incident a given edge:
│ │ │ │ -
695//
│ │ │ │ -
696inline ConstIndexArray
│ │ │ │ -
697Level::getEdgeFaces(Index edgeIndex) const {
│ │ │ │ -
698 return ConstIndexArray(&_edgeFaceIndices[0] +
│ │ │ │ -
699 _edgeFaceCountsAndOffsets[edgeIndex*2+1],
│ │ │ │ -
700 _edgeFaceCountsAndOffsets[edgeIndex*2]);
│ │ │ │ -
701}
│ │ │ │ -
702inline IndexArray
│ │ │ │ -
703Level::getEdgeFaces(Index edgeIndex) {
│ │ │ │ -
704 return IndexArray(&_edgeFaceIndices[0] +
│ │ │ │ -
705 _edgeFaceCountsAndOffsets[edgeIndex*2+1],
│ │ │ │ -
706 _edgeFaceCountsAndOffsets[edgeIndex*2]);
│ │ │ │ -
707}
│ │ │ │ -
708
│ │ │ │ - │ │ │ │ -
710Level::getEdgeFaceLocalIndices(Index edgeIndex) const {
│ │ │ │ -
711 return ConstLocalIndexArray(&_edgeFaceLocalIndices[0] +
│ │ │ │ -
712 _edgeFaceCountsAndOffsets[edgeIndex*2+1],
│ │ │ │ -
713 _edgeFaceCountsAndOffsets[edgeIndex*2]);
│ │ │ │ -
714}
│ │ │ │ -
715inline LocalIndexArray
│ │ │ │ -
716Level::getEdgeFaceLocalIndices(Index edgeIndex) {
│ │ │ │ -
717 return LocalIndexArray(&_edgeFaceLocalIndices[0] +
│ │ │ │ -
718 _edgeFaceCountsAndOffsets[edgeIndex*2+1],
│ │ │ │ -
719 _edgeFaceCountsAndOffsets[edgeIndex*2]);
│ │ │ │ -
720}
│ │ │ │ -
721
│ │ │ │ -
722inline void
│ │ │ │ -
723Level::resizeEdgeFaces(Index edgeIndex, int count) {
│ │ │ │ -
724 int* countOffsetPair = &_edgeFaceCountsAndOffsets[edgeIndex*2];
│ │ │ │ -
725
│ │ │ │ -
726 countOffsetPair[0] = count;
│ │ │ │ -
727 countOffsetPair[1] = (edgeIndex == 0) ? 0 : (countOffsetPair[-2] + countOffsetPair[-1]);
│ │ │ │ -
728
│ │ │ │ -
729 _maxEdgeFaces = std::max(_maxEdgeFaces, count);
│ │ │ │ -
730}
│ │ │ │ -
731inline void
│ │ │ │ -
732Level::trimEdgeFaces(Index edgeIndex, int count) {
│ │ │ │ -
733 _edgeFaceCountsAndOffsets[edgeIndex*2] = count;
│ │ │ │ -
734}
│ │ │ │ -
735
│ │ │ │ -
736//
│ │ │ │ -
737// Access/modify sharpness values:
│ │ │ │ -
738//
│ │ │ │ -
739inline float
│ │ │ │ -
740Level::getEdgeSharpness(Index edgeIndex) const {
│ │ │ │ -
741 return _edgeSharpness[edgeIndex];
│ │ │ │ -
742}
│ │ │ │ -
743inline float&
│ │ │ │ -
744Level::getEdgeSharpness(Index edgeIndex) {
│ │ │ │ -
745 return _edgeSharpness[edgeIndex];
│ │ │ │ -
746}
│ │ │ │ -
747
│ │ │ │ -
748inline float
│ │ │ │ -
749Level::getVertexSharpness(Index vertIndex) const {
│ │ │ │ -
750 return _vertSharpness[vertIndex];
│ │ │ │ -
751}
│ │ │ │ -
752inline float&
│ │ │ │ -
753Level::getVertexSharpness(Index vertIndex) {
│ │ │ │ -
754 return _vertSharpness[vertIndex];
│ │ │ │ -
755}
│ │ │ │ -
756
│ │ │ │ - │ │ │ │ -
758Level::getVertexRule(Index vertIndex) const {
│ │ │ │ -
759 return (Sdc::Crease::Rule) _vertTags[vertIndex]._rule;
│ │ │ │ -
760}
│ │ │ │ -
761
│ │ │ │ -
762//
│ │ │ │ -
763// Access/modify hole tag:
│ │ │ │ -
764//
│ │ │ │ -
765inline void
│ │ │ │ -
766Level::setFaceHole(Index faceIndex, bool b) {
│ │ │ │ -
767 _faceTags[faceIndex]._hole = b;
│ │ │ │ -
768}
│ │ │ │ -
769inline bool
│ │ │ │ -
770Level::isFaceHole(Index faceIndex) const {
│ │ │ │ -
771 return _faceTags[faceIndex]._hole;
│ │ │ │ -
772}
│ │ │ │ -
773
│ │ │ │ -
774//
│ │ │ │ -
775// Access/modify non-manifold tags:
│ │ │ │ -
776//
│ │ │ │ -
777inline void
│ │ │ │ -
778Level::setEdgeNonManifold(Index edgeIndex, bool b) {
│ │ │ │ -
779 _edgeTags[edgeIndex]._nonManifold = b;
│ │ │ │ -
780}
│ │ │ │ -
781inline bool
│ │ │ │ -
782Level::isEdgeNonManifold(Index edgeIndex) const {
│ │ │ │ -
783 return _edgeTags[edgeIndex]._nonManifold;
│ │ │ │ -
784}
│ │ │ │ -
785
│ │ │ │ -
786inline void
│ │ │ │ -
787Level::setVertexNonManifold(Index vertIndex, bool b) {
│ │ │ │ -
788 _vertTags[vertIndex]._nonManifold = b;
│ │ │ │ -
789}
│ │ │ │ -
790inline bool
│ │ │ │ -
791Level::isVertexNonManifold(Index vertIndex) const {
│ │ │ │ -
792 return _vertTags[vertIndex]._nonManifold;
│ │ │ │ -
793}
│ │ │ │ -
794
│ │ │ │ -
795//
│ │ │ │ -
796// Sizing methods to allocate space:
│ │ │ │ -
797//
│ │ │ │ -
798inline void
│ │ │ │ -
799Level::resizeFaces(int faceCount) {
│ │ │ │ -
800 _faceCount = faceCount;
│ │ │ │ -
801 _faceVertCountsAndOffsets.resize(2 * faceCount);
│ │ │ │ -
802
│ │ │ │ -
803 _faceTags.resize(faceCount);
│ │ │ │ -
804 std::memset((void*) &_faceTags[0], 0, _faceCount * sizeof(FTag));
│ │ │ │ -
805}
│ │ │ │ -
806inline void
│ │ │ │ -
807Level::resizeFaceVertices(int totalFaceVertCount) {
│ │ │ │ -
808 _faceVertIndices.resize(totalFaceVertCount);
│ │ │ │ -
809}
│ │ │ │ -
810inline void
│ │ │ │ -
811Level::resizeFaceEdges(int totalFaceEdgeCount) {
│ │ │ │ -
812 _faceEdgeIndices.resize(totalFaceEdgeCount);
│ │ │ │ -
813}
│ │ │ │ -
814
│ │ │ │ -
815inline void
│ │ │ │ -
816Level::resizeEdges(int edgeCount) {
│ │ │ │ -
817
│ │ │ │ -
818 _edgeCount = edgeCount;
│ │ │ │ -
819 _edgeFaceCountsAndOffsets.resize(2 * edgeCount);
│ │ │ │ -
820
│ │ │ │ -
821 _edgeSharpness.resize(edgeCount);
│ │ │ │ -
822 _edgeTags.resize(edgeCount);
│ │ │ │ -
823
│ │ │ │ -
824 if (edgeCount>0) {
│ │ │ │ -
825 std::memset((void*) &_edgeTags[0], 0, _edgeCount * sizeof(ETag));
│ │ │ │ -
826 }
│ │ │ │ -
827}
│ │ │ │ -
828inline void
│ │ │ │ -
829Level::resizeEdgeVertices() {
│ │ │ │ -
830
│ │ │ │ -
831 _edgeVertIndices.resize(2 * _edgeCount);
│ │ │ │ -
832}
│ │ │ │ -
833inline void
│ │ │ │ -
834Level::resizeEdgeFaces(int totalEdgeFaceCount) {
│ │ │ │ -
835
│ │ │ │ -
836 _edgeFaceIndices.resize(totalEdgeFaceCount);
│ │ │ │ -
837 _edgeFaceLocalIndices.resize(totalEdgeFaceCount);
│ │ │ │ -
838}
│ │ │ │ -
839
│ │ │ │ -
840inline void
│ │ │ │ -
841Level::resizeVertices(int vertCount) {
│ │ │ │ -
842
│ │ │ │ -
843 _vertCount = vertCount;
│ │ │ │ -
844 _vertFaceCountsAndOffsets.resize(2 * vertCount);
│ │ │ │ -
845 _vertEdgeCountsAndOffsets.resize(2 * vertCount);
│ │ │ │ -
846
│ │ │ │ -
847 _vertSharpness.resize(vertCount);
│ │ │ │ -
848 _vertTags.resize(vertCount);
│ │ │ │ -
849 std::memset((void*) &_vertTags[0], 0, _vertCount * sizeof(VTag));
│ │ │ │ -
850}
│ │ │ │ -
851inline void
│ │ │ │ -
852Level::resizeVertexFaces(int totalVertFaceCount) {
│ │ │ │ -
853
│ │ │ │ -
854 _vertFaceIndices.resize(totalVertFaceCount);
│ │ │ │ -
855 _vertFaceLocalIndices.resize(totalVertFaceCount);
│ │ │ │ -
856}
│ │ │ │ -
857inline void
│ │ │ │ -
858Level::resizeVertexEdges(int totalVertEdgeCount) {
│ │ │ │ -
859
│ │ │ │ -
860 _vertEdgeIndices.resize(totalVertEdgeCount);
│ │ │ │ -
861 _vertEdgeLocalIndices.resize(totalVertEdgeCount);
│ │ │ │ -
862}
│ │ │ │ -
863
│ │ │ │ -
864inline IndexArray
│ │ │ │ -
865Level::shareFaceVertCountsAndOffsets() const {
│ │ │ │ -
866 // XXXX manuelk we have to force const casting here (classes don't 'share'
│ │ │ │ -
867 // members usually...)
│ │ │ │ -
868 return IndexArray(const_cast<Index *>(&_faceVertCountsAndOffsets[0]),
│ │ │ │ -
869 (int)_faceVertCountsAndOffsets.size());
│ │ │ │ -
870}
│ │ │ │ -
871
│ │ │ │ -
872} // end namespace internal
│ │ │ │ -
873} // end namespace Vtr
│ │ │ │ -
874
│ │ │ │ -
875} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
876using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
877} // end namespace OpenSubdiv
│ │ │ │ -
878
│ │ │ │ -
879#endif /* OPENSUBDIV3_VTR_LEVEL_H */
│ │ │ │ - │ │ │ │ -
ConstArray< LocalIndex > ConstLocalIndexArray
Definition types.h:83
│ │ │ │ -
Array< LocalIndex > LocalIndexArray
Definition types.h:82
│ │ │ │ +
456#endif /* OPENSUBDIV3_VTR_REFINEMENT_H */
│ │ │ │ + │ │ │ │ │ │ │ │ +
std::vector< Index > IndexVector
Definition types.h:77
│ │ │ │
ConstArray< Index > ConstIndexArray
Definition types.h:80
│ │ │ │ - │ │ │ │ │ │ │ │ - │ │ │ │ +
Split
Enumerated type for all face splitting schemes.
Definition types.h:47
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -level.h │ │ │ │ │ +refinement.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -23,986 +23,545 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_VTR_LEVEL_H │ │ │ │ │ -25#define OPENSUBDIV3_VTR_LEVEL_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_VTR_REFINEMENT_H │ │ │ │ │ +25#define OPENSUBDIV3_VTR_REFINEMENT_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ 29#include "../sdc/types.h" │ │ │ │ │ -30#include "../sdc/crease.h" │ │ │ │ │ -31#include "../sdc/options.h" │ │ │ │ │ -32#include "../vtr/types.h" │ │ │ │ │ +30#include "../sdc/options.h" │ │ │ │ │ +31#include "../vtr/types.h" │ │ │ │ │ +32#include "../vtr/level.h" │ │ │ │ │ 33 │ │ │ │ │ -34#include │ │ │ │ │ -35#include │ │ │ │ │ -36#include │ │ │ │ │ -37#include │ │ │ │ │ -38 │ │ │ │ │ -39 │ │ │ │ │ -40namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -41namespace OPENSUBDIV_VERSION { │ │ │ │ │ -42 │ │ │ │ │ -43namespace Vtr { │ │ │ │ │ -44namespace internal { │ │ │ │ │ -45 │ │ │ │ │ -46class Refinement; │ │ │ │ │ -47class TriRefinement; │ │ │ │ │ -48class QuadRefinement; │ │ │ │ │ -49class FVarRefinement; │ │ │ │ │ -50class FVarLevel; │ │ │ │ │ -51 │ │ │ │ │ -52// │ │ │ │ │ -53// Level: │ │ │ │ │ -54// A refinement level includes a vectorized representation of the topology │ │ │ │ │ -55// for a particular subdivision level. The topology is "complete" in that any │ │ │ │ │ -56// level can be used as the base level of another subdivision hierarchy and │ │ │ │ │ -can │ │ │ │ │ -57// be considered a complete mesh independent of its ancestors. It currently │ │ │ │ │ -58// does contain a "depth" member -- as some inferences can then be made about │ │ │ │ │ -59// the topology (i.e. all quads or all tris if not level 0). │ │ │ │ │ +34#include │ │ │ │ │ +35 │ │ │ │ │ +36// │ │ │ │ │ +37// Declaration for the main refinement class (Refinement) and its pre- │ │ │ │ │ +requisites: │ │ │ │ │ +38// │ │ │ │ │ +39namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +40namespace OPENSUBDIV_VERSION { │ │ │ │ │ +41 │ │ │ │ │ +42namespace Vtr { │ │ │ │ │ +43namespace internal { │ │ │ │ │ +44 │ │ │ │ │ +45class FVarRefinement; │ │ │ │ │ +46 │ │ │ │ │ +47// │ │ │ │ │ +48// Refinement: │ │ │ │ │ +49// A refinement is a mapping between two levels -- relating the components in │ │ │ │ │ +the original │ │ │ │ │ +50// (parent) level to the one refined (child). The refinement may be complete │ │ │ │ │ +(uniform) or sparse │ │ │ │ │ +51// (adaptive or otherwise selective), so not all components in the parent │ │ │ │ │ +level will spawn │ │ │ │ │ +52// components in the child level. │ │ │ │ │ +53// │ │ │ │ │ +54// Refinement is an abstract class and expects subclasses corresponding to │ │ │ │ │ +the different types │ │ │ │ │ +55// of topological splits that the supported subdivision schemes collectively │ │ │ │ │ +require, i.e. those │ │ │ │ │ +56// listed in Sdc::SplitType. Note the virtual requirements expected of the │ │ │ │ │ +subclasses in the list │ │ │ │ │ +57// of protected methods -- they differ mainly in the topology that is created │ │ │ │ │ +in the child Level │ │ │ │ │ +58// and not the propagation of tags through refinement, subdivision of │ │ │ │ │ +sharpness values or the │ │ │ │ │ +59// treatment of face-varying data. The primary subclasses are QuadRefinement │ │ │ │ │ +and TriRefinement. │ │ │ │ │ 60// │ │ │ │ │ -61// This class is intended for private use within the library. There are still │ │ │ │ │ -62// opportunities to specialize levels -- e.g. those supporting N-sided faces │ │ │ │ │ -vs │ │ │ │ │ -63// those that are purely quads or tris -- so we prefer to insulate it from │ │ │ │ │ -public │ │ │ │ │ -64// access. │ │ │ │ │ -65// │ │ │ │ │ -66// The representation of topology here is to store six topological │ │ │ │ │ -relationships │ │ │ │ │ -67// in tables of integers. Each is stored in its own array(s) so the result is │ │ │ │ │ -68// a SOA representation of the topology. The six relations are: │ │ │ │ │ -69// │ │ │ │ │ -70// - face-verts: vertices incident/comprising a face │ │ │ │ │ -71// - face-edges: edges incident a face │ │ │ │ │ -72// - edge-verts: vertices incident/comprising an edge │ │ │ │ │ -73// - edge-faces: faces incident an edge │ │ │ │ │ -74// - vert-faces: faces incident a vertex │ │ │ │ │ -75// - vert-edges: edges incident a vertex │ │ │ │ │ -76// │ │ │ │ │ -77// There is some redundancy here but the intent is not that this be a minimal │ │ │ │ │ -78// representation, the intent is that it be amenable to refinement. Classes │ │ │ │ │ -in │ │ │ │ │ -79// the Far layer essentially store 5 of these 6 in a permuted form -- we add │ │ │ │ │ -80// the face-edges here to simplify refinement. │ │ │ │ │ -81// │ │ │ │ │ +61// At a high level, all that is necessary in terms of interface is to │ │ │ │ │ +construct, initialize │ │ │ │ │ +62// (linking the two levels), optionally select components for sparse │ │ │ │ │ +refinement (via use of the │ │ │ │ │ +63// SparseSelector) and call the refine() method. This usage is expected of │ │ │ │ │ +Far::TopologyRefiner. │ │ │ │ │ +64// │ │ │ │ │ +65// Since we really want this class to be restricted from public access │ │ │ │ │ +eventually, all methods │ │ │ │ │ +66// begin with lower case (as is the convention for protected methods) and the │ │ │ │ │ +list of friends │ │ │ │ │ +67// will be maintained more strictly. │ │ │ │ │ +68// │ │ │ │ │ +69class Refinement { │ │ │ │ │ +70 │ │ │ │ │ +71public: │ │ │ │ │ +72 Refinement(Level const & parent, Level & child, Sdc::Options const& │ │ │ │ │ +schemeOptions); │ │ │ │ │ +73 virtual ~Refinement(); │ │ │ │ │ +74 │ │ │ │ │ +75 Level const& parent() const { return *_parent; } │ │ │ │ │ +76 Level const& child() const { return *_child; } │ │ │ │ │ +77 Level& child() { return *_child; } │ │ │ │ │ +78 │ │ │ │ │ +79 _S_d_c_:_:_S_p_l_i_t getSplitType() const { return _splitType; } │ │ │ │ │ +80 int getRegularFaceSize() const { return _regFaceSize; } │ │ │ │ │ +81 Sdc::Options getOptions() const { return _options; } │ │ │ │ │ 82 │ │ │ │ │ -83class Level { │ │ │ │ │ -84 │ │ │ │ │ -85public: │ │ │ │ │ -86 // │ │ │ │ │ -87 // Simple nested types to hold the tags for each component type -- some of │ │ │ │ │ -88 // which are user-specified features (e.g. whether a face is a hole or not) │ │ │ │ │ -89 // while others indicate the topological nature of the component, how it │ │ │ │ │ -90 // is affected by creasing in its neighborhood, etc. │ │ │ │ │ -91 // │ │ │ │ │ -92 // Most of these properties are passed down to child components during │ │ │ │ │ -93 // refinement, but some -- notably the designation of a component as semi- │ │ │ │ │ -94 // sharp -- require re-determination as sharpness values are reduced at each │ │ │ │ │ -95 // level. │ │ │ │ │ -96 // │ │ │ │ │ -97 struct VTag { │ │ │ │ │ -98 VTag() { } │ │ │ │ │ -99 │ │ │ │ │ -100 // When cleared, the VTag ALMOST represents a smooth, regular, interior │ │ │ │ │ -101 // vertex -- the Type enum requires a bit be explicitly set for Smooth, │ │ │ │ │ -102 // so that must be done explicitly if desired on initialization. │ │ │ │ │ -103 void clear() { std::memset((void*) this, 0, sizeof(VTag)); } │ │ │ │ │ -104 │ │ │ │ │ -105 typedef unsigned short VTagSize; │ │ │ │ │ -106 │ │ │ │ │ -107 VTagSize _nonManifold : 1; // fixed │ │ │ │ │ -108 VTagSize _xordinary : 1; // fixed │ │ │ │ │ -109 VTagSize _boundary : 1; // fixed │ │ │ │ │ -110 VTagSize _corner : 1; // fixed │ │ │ │ │ -111 VTagSize _infSharp : 1; // fixed │ │ │ │ │ -112 VTagSize _semiSharp : 1; // variable │ │ │ │ │ -113 VTagSize _semiSharpEdges : 1; // variable │ │ │ │ │ -114 VTagSize _rule : 4; // variable when _semiSharp │ │ │ │ │ -115 │ │ │ │ │ -116 // These next to tags are complementary -- the "incomplete" tag is only │ │ │ │ │ -117 // relevant for refined levels while the "incident an irregular face" tag │ │ │ │ │ -118 // is only relevant for the base level. They could be combined as both │ │ │ │ │ -119 // indicate "no full regular ring" around a vertex │ │ │ │ │ -120 VTagSize _incomplete : 1; // variable only set in refined levels │ │ │ │ │ -121 VTagSize _incidIrregFace : 1; // variable only set in base level │ │ │ │ │ +83 // Face-varying: │ │ │ │ │ +84 int getNumFVarChannels() const { return (int) _fvarChannels.size(); } │ │ │ │ │ +85 │ │ │ │ │ +86 FVarRefinement const & getFVarRefinement(int c) const { return │ │ │ │ │ +*_fvarChannels[c]; } │ │ │ │ │ +87 │ │ │ │ │ +88 // │ │ │ │ │ +89 // Options associated with the actual refinement operation, which may end up │ │ │ │ │ +90 // quite involved if we want to allow for the refinement of data that is not │ │ │ │ │ +91 // of interest to be suppressed. For now we have: │ │ │ │ │ +92 // │ │ │ │ │ +93 // "sparse": the alternative to uniform refinement, which requires that │ │ │ │ │ +94 // components be previously selected/marked to be included. │ │ │ │ │ +95 // │ │ │ │ │ +96 // "minimal topology": this is one that may get broken down into a finer │ │ │ │ │ +97 // set of options. It suppresses "full topology" in the child level │ │ │ │ │ +98 // and only generates what is minimally necessary for interpolation -- │ │ │ │ │ +99 // which requires at least the face-vertices for faces, but also the │ │ │ │ │ +100 // vertex-faces for any face-varying channels present. So it will │ │ │ │ │ +101 // generate one or two of the six possible topological relations. │ │ │ │ │ +102 // │ │ │ │ │ +103 // These are strictly controlled right now, e.g. for sparse refinement, we │ │ │ │ │ +104 // currently enforce full topology at the finest level to allow for │ │ │ │ │ +subsequent │ │ │ │ │ +105 // patch construction. │ │ │ │ │ +106 // │ │ │ │ │ +107 struct Options { │ │ │ │ │ +108 Options() : _sparse(false), │ │ │ │ │ +109 _faceVertsFirst(false), │ │ │ │ │ +110 _minimalTopology(false) │ │ │ │ │ +111 { } │ │ │ │ │ +112 │ │ │ │ │ +113 unsigned int _sparse : 1; │ │ │ │ │ +114 unsigned int _faceVertsFirst : 1; │ │ │ │ │ +115 unsigned int _minimalTopology : 1; │ │ │ │ │ +116 │ │ │ │ │ +117 // Still under consideration: │ │ │ │ │ +118 //unsigned int _childToParentMap : 1; │ │ │ │ │ +119 }; │ │ │ │ │ +120 │ │ │ │ │ +121 void refine(Options options = Options()); │ │ │ │ │ 122 │ │ │ │ │ -123 // Tags indicating incident infinitely-sharp (permanent) features │ │ │ │ │ -124 VTagSize _infSharpEdges : 1; // fixed │ │ │ │ │ -125 VTagSize _infSharpCrease : 1; // fixed │ │ │ │ │ -126 VTagSize _infIrregular : 1; // fixed │ │ │ │ │ -127 │ │ │ │ │ -128 // Alternate constructor and accessor for dealing with integer bits │ │ │ │ │ -directly: │ │ │ │ │ -129 explicit VTag(VTagSize bits) { │ │ │ │ │ -130 std::memcpy(this, &bits, sizeof(bits)); │ │ │ │ │ -131 } │ │ │ │ │ -132 VTagSize getBits() const { │ │ │ │ │ -133 VTagSize bits; │ │ │ │ │ -134 std::memcpy(&bits, this, sizeof(bits)); │ │ │ │ │ -135 return bits; │ │ │ │ │ -136 } │ │ │ │ │ -137 │ │ │ │ │ -138 static VTag BitwiseOr(VTag const vTags[], int size = 4); │ │ │ │ │ -139 }; │ │ │ │ │ -140 struct ETag { │ │ │ │ │ -141 ETag() { } │ │ │ │ │ -142 │ │ │ │ │ -143 // When cleared, the ETag represents a smooth, manifold, interior edge │ │ │ │ │ -144 void clear() { std::memset((void*) this, 0, sizeof(ETag)); } │ │ │ │ │ -145 │ │ │ │ │ -146 typedef unsigned char ETagSize; │ │ │ │ │ +123 bool hasFaceVerticesFirst() const { return _faceVertsFirst; } │ │ │ │ │ +124 │ │ │ │ │ +125public: │ │ │ │ │ +126 // │ │ │ │ │ +127 // Access to members -- some testing classes (involving vertex │ │ │ │ │ +interpolation) │ │ │ │ │ +128 // currently make use of these: │ │ │ │ │ +129 // │ │ │ │ │ +130 int getNumChildFacesFromFaces() const { return _childFaceFromFaceCount; } │ │ │ │ │ +131 int getNumChildEdgesFromFaces() const { return _childEdgeFromFaceCount; } │ │ │ │ │ +132 int getNumChildEdgesFromEdges() const { return _childEdgeFromEdgeCount; } │ │ │ │ │ +133 int getNumChildVerticesFromFaces() const { return _childVertFromFaceCount; │ │ │ │ │ +} │ │ │ │ │ +134 int getNumChildVerticesFromEdges() const { return _childVertFromEdgeCount; │ │ │ │ │ +} │ │ │ │ │ +135 int getNumChildVerticesFromVertices() const { return │ │ │ │ │ +_childVertFromVertCount; } │ │ │ │ │ +136 │ │ │ │ │ +137 _I_n_d_e_x getFirstChildFaceFromFaces() const { return _firstChildFaceFromFace; │ │ │ │ │ +} │ │ │ │ │ +138 _I_n_d_e_x getFirstChildEdgeFromFaces() const { return _firstChildEdgeFromFace; │ │ │ │ │ +} │ │ │ │ │ +139 _I_n_d_e_x getFirstChildEdgeFromEdges() const { return _firstChildEdgeFromEdge; │ │ │ │ │ +} │ │ │ │ │ +140 _I_n_d_e_x getFirstChildVertexFromFaces() const { return │ │ │ │ │ +_firstChildVertFromFace; } │ │ │ │ │ +141 _I_n_d_e_x getFirstChildVertexFromEdges() const { return │ │ │ │ │ +_firstChildVertFromEdge; } │ │ │ │ │ +142 _I_n_d_e_x getFirstChildVertexFromVertices() const { return │ │ │ │ │ +_firstChildVertFromVert; } │ │ │ │ │ +143 │ │ │ │ │ +144 _I_n_d_e_x getFaceChildVertex(_I_n_d_e_x f) const { return _faceChildVertIndex[f]; } │ │ │ │ │ +145 _I_n_d_e_x getEdgeChildVertex(_I_n_d_e_x e) const { return _edgeChildVertIndex[e]; } │ │ │ │ │ +146 _I_n_d_e_x getVertexChildVertex(_I_n_d_e_x v) const { return _vertChildVertIndex[v]; │ │ │ │ │ +} │ │ │ │ │ 147 │ │ │ │ │ -148 ETagSize _nonManifold : 1; // fixed │ │ │ │ │ -149 ETagSize _boundary : 1; // fixed │ │ │ │ │ -150 ETagSize _infSharp : 1; // fixed │ │ │ │ │ -151 ETagSize _semiSharp : 1; // variable │ │ │ │ │ -152 │ │ │ │ │ -153 // Alternate constructor and accessor for dealing with integer bits │ │ │ │ │ -directly: │ │ │ │ │ -154 explicit ETag(ETagSize bits) { │ │ │ │ │ -155 std::memcpy(this, &bits, sizeof(bits)); │ │ │ │ │ -156 } │ │ │ │ │ -157 ETagSize getBits() const { │ │ │ │ │ -158 ETagSize bits; │ │ │ │ │ -159 std::memcpy(&bits, this, sizeof(bits)); │ │ │ │ │ -160 return bits; │ │ │ │ │ -161 } │ │ │ │ │ -162 │ │ │ │ │ -163 static ETag BitwiseOr(ETag const eTags[], int size = 4); │ │ │ │ │ -164 }; │ │ │ │ │ -165 struct FTag { │ │ │ │ │ -166 FTag() { } │ │ │ │ │ -167 │ │ │ │ │ -168 void clear() { std::memset((void*) this, 0, sizeof(FTag)); } │ │ │ │ │ -169 │ │ │ │ │ -170 typedef unsigned char FTagSize; │ │ │ │ │ -171 │ │ │ │ │ -172 FTagSize _hole : 1; // fixed │ │ │ │ │ -173 │ │ │ │ │ -174 // On deck -- coming soon... │ │ │ │ │ -175 //FTagSize _hasEdits : 1; // variable │ │ │ │ │ -176 }; │ │ │ │ │ -177 │ │ │ │ │ -178 // Additional simple struct to identify a "span" around a vertex, i.e. a │ │ │ │ │ -179 // subset of the faces around a vertex delimited by some property (e.g. a │ │ │ │ │ -180 // face-varying discontinuity, an inf-sharp edge, etc.) │ │ │ │ │ -181 // │ │ │ │ │ -182 // The span requires an "origin" and a "size" to fully define its extent. │ │ │ │ │ -183 // Use of the size is required over a leading/trailing pair as the valence │ │ │ │ │ -184 // around a non-manifold vertex cannot be trivially determined from two │ │ │ │ │ -185 // extremeties. Similarly a start face is chosen over an edge as starting │ │ │ │ │ -186 // with a manifold edge is ambiguous. Additional tags also support │ │ │ │ │ -187 // non-manifold cases, e.g. periodic spans at the apex of a double cone. │ │ │ │ │ +148 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceChildFaces(_I_n_d_e_x parentFace) const; │ │ │ │ │ +149 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceChildEdges(_I_n_d_e_x parentFace) const; │ │ │ │ │ +150 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getEdgeChildEdges(_I_n_d_e_x parentEdge) const; │ │ │ │ │ +151 │ │ │ │ │ +152 // Child-to-parent relationships │ │ │ │ │ +153 bool isChildVertexComplete(_I_n_d_e_x v) const { return ! _childVertexTag │ │ │ │ │ +[v]._incomplete; } │ │ │ │ │ +154 │ │ │ │ │ +155 _I_n_d_e_x getChildFaceParentFace(_I_n_d_e_x f) const { return _childFaceParentIndex │ │ │ │ │ +[f]; } │ │ │ │ │ +156 int getChildFaceInParentFace(_I_n_d_e_x f) const { return _childFaceTag │ │ │ │ │ +[f]._indexInParent; } │ │ │ │ │ +157 │ │ │ │ │ +158 _I_n_d_e_x getChildEdgeParentIndex(_I_n_d_e_x e) const { return _childEdgeParentIndex │ │ │ │ │ +[e]; } │ │ │ │ │ +159 │ │ │ │ │ +160 _I_n_d_e_x getChildVertexParentIndex(_I_n_d_e_x v) const { return │ │ │ │ │ +_childVertexParentIndex[v]; } │ │ │ │ │ +161 │ │ │ │ │ +162// │ │ │ │ │ +163// Modifiers intended for internal/protected use: │ │ │ │ │ +164// │ │ │ │ │ +165public: │ │ │ │ │ +166 │ │ │ │ │ +167 _I_n_d_e_x_A_r_r_a_y getFaceChildFaces(_I_n_d_e_x parentFace); │ │ │ │ │ +168 _I_n_d_e_x_A_r_r_a_y getFaceChildEdges(_I_n_d_e_x parentFace); │ │ │ │ │ +169 _I_n_d_e_x_A_r_r_a_y getEdgeChildEdges(_I_n_d_e_x parentEdge); │ │ │ │ │ +170 │ │ │ │ │ +171public: │ │ │ │ │ +172 // │ │ │ │ │ +173 // Tags have now been added per-component in Level, but there is additional │ │ │ │ │ +need to tag │ │ │ │ │ +174 // components within Refinement -- we can't tag the parent level components │ │ │ │ │ +for any │ │ │ │ │ +175 // refinement (in order to keep it const) and tags associated with children │ │ │ │ │ +that are │ │ │ │ │ +176 // specific to the child-to-parent mapping may not be warranted in the │ │ │ │ │ +child level. │ │ │ │ │ +177 // │ │ │ │ │ +178 // Parent tags are only required for sparse refinement. The main property │ │ │ │ │ +to tag is │ │ │ │ │ +179 // whether a component was selected, and so a single SparseTag is used for │ │ │ │ │ +all three │ │ │ │ │ +180 // component types. Tagging if a component is "transitional" is also │ │ │ │ │ +useful. This may │ │ │ │ │ +181 // only be necessary for edges but is currently packed into a mask per-edge │ │ │ │ │ +for faces, │ │ │ │ │ +182 // which could be deferred, in which case "transitional" could be a single │ │ │ │ │ +bit. │ │ │ │ │ +183 // │ │ │ │ │ +184 // Child tags are part of the child-to-parent mapping, which consists of │ │ │ │ │ +the parent │ │ │ │ │ +185 // component index for each child component, plus a tag for the child │ │ │ │ │ +indicating more │ │ │ │ │ +186 // about its relationship to its parent, e.g. is it completely defined, │ │ │ │ │ +what the parent │ │ │ │ │ +187 // component type is, what is the index of the child within its parent, │ │ │ │ │ +etc. │ │ │ │ │ 188 // │ │ │ │ │ -189 // Currently setting the size to 0 or leaving the span "unassigned" is an │ │ │ │ │ -190 // indication to use the full neighborhood rather than a subset -- prefer │ │ │ │ │ -191 // use of the const method here to direct inspection of the member. │ │ │ │ │ -192 // │ │ │ │ │ -193 struct VSpan { │ │ │ │ │ -194 VSpan() { std::memset((void*) this, 0, sizeof(VSpan)); } │ │ │ │ │ +189 struct SparseTag { │ │ │ │ │ +190 SparseTag() : _selected(0), _transitional(0) { } │ │ │ │ │ +191 │ │ │ │ │ +192 unsigned char _selected : 1; // component specifically selected for │ │ │ │ │ +refinement │ │ │ │ │ +193 unsigned char _transitional : 4; // adjacent to a refined component (4-bits │ │ │ │ │ +for face) │ │ │ │ │ +194 }; │ │ │ │ │ 195 │ │ │ │ │ -196 void clear() { std::memset((void*) this, 0, sizeof(VSpan)); } │ │ │ │ │ -197 bool isAssigned() const { return _numFaces > 0; } │ │ │ │ │ +196 struct ChildTag { │ │ │ │ │ +197 ChildTag() { } │ │ │ │ │ 198 │ │ │ │ │ -199 _L_o_c_a_l_I_n_d_e_x _numFaces; │ │ │ │ │ -200 _L_o_c_a_l_I_n_d_e_x _startFace; │ │ │ │ │ -201 _L_o_c_a_l_I_n_d_e_x _cornerInSpan; │ │ │ │ │ -202 │ │ │ │ │ -203 unsigned short _periodic : 1; │ │ │ │ │ -204 unsigned short _sharp : 1; │ │ │ │ │ -205 }; │ │ │ │ │ -206 │ │ │ │ │ -207public: │ │ │ │ │ -208 Level(); │ │ │ │ │ -209 ~Level(); │ │ │ │ │ -210 │ │ │ │ │ -211 // Simple accessors: │ │ │ │ │ -212 int getDepth() const { return _depth; } │ │ │ │ │ -213 │ │ │ │ │ -214 int getNumVertices() const { return _vertCount; } │ │ │ │ │ -215 int getNumFaces() const { return _faceCount; } │ │ │ │ │ -216 int getNumEdges() const { return _edgeCount; } │ │ │ │ │ -217 │ │ │ │ │ -218 // More global sizes may prove useful... │ │ │ │ │ -219 int getNumFaceVerticesTotal() const { return (int) _faceVertIndices.size(); │ │ │ │ │ +199 unsigned char _incomplete : 1; // incomplete neighborhood to represent │ │ │ │ │ +limit of parent │ │ │ │ │ +200 unsigned char _parentType : 2; // type of parent component: vertex, edge or │ │ │ │ │ +face │ │ │ │ │ +201 unsigned char _indexInParent : 2; // index of child wrt parent: 0-3, or │ │ │ │ │ +iterative if N > 4 │ │ │ │ │ +202 }; │ │ │ │ │ +203 │ │ │ │ │ +204 // Methods to access and modify tags: │ │ │ │ │ +205 SparseTag const & getParentFaceSparseTag( _I_n_d_e_x f) const { return │ │ │ │ │ +_parentFaceTag[f]; } │ │ │ │ │ +206 SparseTag const & getParentEdgeSparseTag( _I_n_d_e_x e) const { return │ │ │ │ │ +_parentEdgeTag[e]; } │ │ │ │ │ +207 SparseTag const & getParentVertexSparseTag(_I_n_d_e_x v) const { return │ │ │ │ │ +_parentVertexTag[v]; } │ │ │ │ │ +208 │ │ │ │ │ +209 SparseTag & getParentFaceSparseTag( _I_n_d_e_x f) { return _parentFaceTag[f]; } │ │ │ │ │ +210 SparseTag & getParentEdgeSparseTag( _I_n_d_e_x e) { return _parentEdgeTag[e]; } │ │ │ │ │ +211 SparseTag & getParentVertexSparseTag(_I_n_d_e_x v) { return _parentVertexTag[v]; │ │ │ │ │ } │ │ │ │ │ -220 int getNumFaceEdgesTotal() const { return (int) _faceEdgeIndices.size(); } │ │ │ │ │ -221 int getNumEdgeVerticesTotal() const { return (int) _edgeVertIndices.size(); │ │ │ │ │ +212 │ │ │ │ │ +213 ChildTag const & getChildFaceTag( _I_n_d_e_x f) const { return _childFaceTag[f]; │ │ │ │ │ } │ │ │ │ │ -222 int getNumEdgeFacesTotal() const { return (int) _edgeFaceIndices.size(); } │ │ │ │ │ -223 int getNumVertexFacesTotal() const { return (int) _vertFaceIndices.size(); │ │ │ │ │ +214 ChildTag const & getChildEdgeTag( _I_n_d_e_x e) const { return _childEdgeTag[e]; │ │ │ │ │ } │ │ │ │ │ -224 int getNumVertexEdgesTotal() const { return (int) _vertEdgeIndices.size(); │ │ │ │ │ -} │ │ │ │ │ -225 │ │ │ │ │ -226 int getMaxValence() const { return _maxValence; } │ │ │ │ │ -227 int getMaxEdgeFaces() const { return _maxEdgeFaces; } │ │ │ │ │ -228 │ │ │ │ │ -229 // Methods to access the relation tables/indices -- note that for some │ │ │ │ │ -relations │ │ │ │ │ -230 // (i.e. those where a component is "contained by" a neighbor, or more │ │ │ │ │ -generally │ │ │ │ │ -231 // when the neighbor is a simplex of higher dimension) we store an │ │ │ │ │ -additional │ │ │ │ │ -232 // "local index", e.g. for the case of vert-faces if one of the faces F[i] │ │ │ │ │ -is │ │ │ │ │ -233 // incident a vertex V, then L[i] is the "local index" in F[i] of vertex V. │ │ │ │ │ -234 // Once have only quads (or tris), this local index need only occupy two │ │ │ │ │ -bits │ │ │ │ │ -235 // and could conceivably be packed into the same integer as the face index, │ │ │ │ │ -but │ │ │ │ │ -236 // for now, given the need to support faces of potentially high valence │ │ │ │ │ -we'll │ │ │ │ │ -237 // use an 8- or 16-bit integer. │ │ │ │ │ -238 // │ │ │ │ │ -239 // Methods to access the six topological relations: │ │ │ │ │ -240 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceVertices(_I_n_d_e_x faceIndex) const; │ │ │ │ │ -241 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceEdges(_I_n_d_e_x faceIndex) const; │ │ │ │ │ -242 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getEdgeVertices(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ -243 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getEdgeFaces(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ -244 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getVertexFaces(_I_n_d_e_x vertIndex) const; │ │ │ │ │ -245 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getVertexEdges(_I_n_d_e_x vertIndex) const; │ │ │ │ │ -246 │ │ │ │ │ -247 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getEdgeFaceLocalIndices(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ -248 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getVertexFaceLocalIndices(_I_n_d_e_x vertIndex) const; │ │ │ │ │ -249 _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getVertexEdgeLocalIndices(_I_n_d_e_x vertIndex) const; │ │ │ │ │ +215 ChildTag const & getChildVertexTag(_I_n_d_e_x v) const { return _childVertexTag │ │ │ │ │ +[v]; } │ │ │ │ │ +216 │ │ │ │ │ +217 ChildTag & getChildFaceTag( _I_n_d_e_x f) { return _childFaceTag[f]; } │ │ │ │ │ +218 ChildTag & getChildEdgeTag( _I_n_d_e_x e) { return _childEdgeTag[e]; } │ │ │ │ │ +219 ChildTag & getChildVertexTag(_I_n_d_e_x v) { return _childVertexTag[v]; } │ │ │ │ │ +220 │ │ │ │ │ +221// Remaining methods should really be protected -- for use by subclasses... │ │ │ │ │ +222public: │ │ │ │ │ +223 // │ │ │ │ │ +224 // Methods involved in constructing the parent-to-child mapping -- when the │ │ │ │ │ +225 // refinement is sparse, additional methods are needed to identify the │ │ │ │ │ +selection: │ │ │ │ │ +226 // │ │ │ │ │ +227 void populateParentToChildMapping(); │ │ │ │ │ +228 void populateParentChildIndices(); │ │ │ │ │ +229 void printParentToChildMapping() const; │ │ │ │ │ +230 │ │ │ │ │ +231 virtual void allocateParentChildIndices() = 0; │ │ │ │ │ +232 │ │ │ │ │ +233 // Supporting method for sparse refinement: │ │ │ │ │ +234 void initializeSparseSelectionTags(); │ │ │ │ │ +235 void markSparseChildComponentIndices(); │ │ │ │ │ +236 void markSparseVertexChildren(); │ │ │ │ │ +237 void markSparseEdgeChildren(); │ │ │ │ │ +238 │ │ │ │ │ +239 virtual void markSparseFaceChildren() = 0; │ │ │ │ │ +240 │ │ │ │ │ +241 void initializeChildComponentCounts(); │ │ │ │ │ +242 │ │ │ │ │ +243 // │ │ │ │ │ +244 // Methods involved in constructing the child-to-parent mapping: │ │ │ │ │ +245 // │ │ │ │ │ +246 void populateChildToParentMapping(); │ │ │ │ │ +247 │ │ │ │ │ +248 void populateFaceParentVectors(ChildTag const initialChildTags[2][4]); │ │ │ │ │ +249 void populateFaceParentFromParentFaces(ChildTag const initialChildTags[2] │ │ │ │ │ +[4]); │ │ │ │ │ 250 │ │ │ │ │ -251 // Replace these with access to sharpness buffers/arrays rather than │ │ │ │ │ -elements: │ │ │ │ │ -252 float getEdgeSharpness(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ -253 float getVertexSharpness(_I_n_d_e_x vertIndex) const; │ │ │ │ │ -254 _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e getVertexRule(_I_n_d_e_x vertIndex) const; │ │ │ │ │ -255 │ │ │ │ │ -256 _I_n_d_e_x findEdge(_I_n_d_e_x v0Index, _I_n_d_e_x v1Index) const; │ │ │ │ │ -257 │ │ │ │ │ -258 // Holes │ │ │ │ │ -259 void setFaceHole(_I_n_d_e_x faceIndex, bool b); │ │ │ │ │ -260 bool isFaceHole(_I_n_d_e_x faceIndex) const; │ │ │ │ │ -261 │ │ │ │ │ -262 // Face-varying │ │ │ │ │ -263 Sdc::Options getFVarOptions(int channel) const; │ │ │ │ │ -264 int getNumFVarChannels() const { return (int) _fvarChannels.size(); } │ │ │ │ │ -265 int getNumFVarValues(int channel) const; │ │ │ │ │ -266 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceFVarValues(_I_n_d_e_x faceIndex, int channel) const; │ │ │ │ │ +251 void populateEdgeParentVectors(ChildTag const initialChildTags[2][4]); │ │ │ │ │ +252 void populateEdgeParentFromParentFaces(ChildTag const initialChildTags[2] │ │ │ │ │ +[4]); │ │ │ │ │ +253 void populateEdgeParentFromParentEdges(ChildTag const initialChildTags[2] │ │ │ │ │ +[4]); │ │ │ │ │ +254 │ │ │ │ │ +255 void populateVertexParentVectors(ChildTag const initialChildTags[2][4]); │ │ │ │ │ +256 void populateVertexParentFromParentFaces(ChildTag const initialChildTags[2] │ │ │ │ │ +[4]); │ │ │ │ │ +257 void populateVertexParentFromParentEdges(ChildTag const initialChildTags[2] │ │ │ │ │ +[4]); │ │ │ │ │ +258 void populateVertexParentFromParentVertices(ChildTag const initialChildTags │ │ │ │ │ +[2][4]); │ │ │ │ │ +259 │ │ │ │ │ +260 // │ │ │ │ │ +261 // Methods involved in propagating component tags from parent to child: │ │ │ │ │ +262 // │ │ │ │ │ +263 void propagateComponentTags(); │ │ │ │ │ +264 │ │ │ │ │ +265 void populateFaceTagVectors(); │ │ │ │ │ +266 void populateFaceTagsFromParentFaces(); │ │ │ │ │ 267 │ │ │ │ │ -268 FVarLevel & getFVarLevel(int channel) { return *_fvarChannels[channel]; } │ │ │ │ │ -269 FVarLevel const & getFVarLevel(int channel) const { return *_fvarChannels │ │ │ │ │ -[channel]; } │ │ │ │ │ -270 │ │ │ │ │ -271 // Manifold/non-manifold tags: │ │ │ │ │ -272 void setEdgeNonManifold(_I_n_d_e_x edgeIndex, bool b); │ │ │ │ │ -273 bool isEdgeNonManifold(_I_n_d_e_x edgeIndex) const; │ │ │ │ │ -274 │ │ │ │ │ -275 void setVertexNonManifold(_I_n_d_e_x vertIndex, bool b); │ │ │ │ │ -276 bool isVertexNonManifold(_I_n_d_e_x vertIndex) const; │ │ │ │ │ -277 │ │ │ │ │ -278 // General access to all component tags: │ │ │ │ │ -279 VTag const & getVertexTag(_I_n_d_e_x vertIndex) const { return _vertTags │ │ │ │ │ -[vertIndex]; } │ │ │ │ │ -280 ETag const & getEdgeTag(_I_n_d_e_x edgeIndex) const { return _edgeTags │ │ │ │ │ -[edgeIndex]; } │ │ │ │ │ -281 FTag const & getFaceTag(_I_n_d_e_x faceIndex) const { return _faceTags │ │ │ │ │ -[faceIndex]; } │ │ │ │ │ -282 │ │ │ │ │ -283 VTag & getVertexTag(_I_n_d_e_x vertIndex) { return _vertTags[vertIndex]; } │ │ │ │ │ -284 ETag & getEdgeTag(_I_n_d_e_x edgeIndex) { return _edgeTags[edgeIndex]; } │ │ │ │ │ -285 FTag & getFaceTag(_I_n_d_e_x faceIndex) { return _faceTags[faceIndex]; } │ │ │ │ │ -286 │ │ │ │ │ -287public: │ │ │ │ │ +268 void populateEdgeTagVectors(); │ │ │ │ │ +269 void populateEdgeTagsFromParentFaces(); │ │ │ │ │ +270 void populateEdgeTagsFromParentEdges(); │ │ │ │ │ +271 │ │ │ │ │ +272 void populateVertexTagVectors(); │ │ │ │ │ +273 void populateVertexTagsFromParentFaces(); │ │ │ │ │ +274 void populateVertexTagsFromParentEdges(); │ │ │ │ │ +275 void populateVertexTagsFromParentVertices(); │ │ │ │ │ +276 │ │ │ │ │ +277 // │ │ │ │ │ +278 // Methods (and types) involved in subdividing the topology -- though not │ │ │ │ │ +279 // fully exploited, any subset of the 6 relations can be generated: │ │ │ │ │ +280 // │ │ │ │ │ +281 struct Relations { │ │ │ │ │ +282 unsigned int _faceVertices : 1; │ │ │ │ │ +283 unsigned int _faceEdges : 1; │ │ │ │ │ +284 unsigned int _edgeVertices : 1; │ │ │ │ │ +285 unsigned int _edgeFaces : 1; │ │ │ │ │ +286 unsigned int _vertexFaces : 1; │ │ │ │ │ +287 unsigned int _vertexEdges : 1; │ │ │ │ │ 288 │ │ │ │ │ -289 // Debugging aides: │ │ │ │ │ -290 enum TopologyError { │ │ │ │ │ -291 TOPOLOGY_MISSING_EDGE_FACES=0, │ │ │ │ │ -292 TOPOLOGY_MISSING_EDGE_VERTS, │ │ │ │ │ -293 TOPOLOGY_MISSING_FACE_EDGES, │ │ │ │ │ -294 TOPOLOGY_MISSING_FACE_VERTS, │ │ │ │ │ -295 TOPOLOGY_MISSING_VERT_FACES, │ │ │ │ │ -296 TOPOLOGY_MISSING_VERT_EDGES, │ │ │ │ │ -297 │ │ │ │ │ -298 TOPOLOGY_FAILED_CORRELATION_EDGE_FACE, │ │ │ │ │ -299 TOPOLOGY_FAILED_CORRELATION_FACE_VERT, │ │ │ │ │ -300 TOPOLOGY_FAILED_CORRELATION_FACE_EDGE, │ │ │ │ │ -301 │ │ │ │ │ -302 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_EDGE, │ │ │ │ │ -303 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_FACE, │ │ │ │ │ -304 TOPOLOGY_FAILED_ORIENTATION_INCIDENT_FACES_EDGES, │ │ │ │ │ -305 │ │ │ │ │ -306 TOPOLOGY_DEGENERATE_EDGE, │ │ │ │ │ -307 TOPOLOGY_NON_MANIFOLD_EDGE, │ │ │ │ │ -308 │ │ │ │ │ -309 TOPOLOGY_INVALID_CREASE_EDGE, │ │ │ │ │ -310 TOPOLOGY_INVALID_CREASE_VERT │ │ │ │ │ -311 }; │ │ │ │ │ +289 void setAll(bool enable) { │ │ │ │ │ +290 _faceVertices = enable; │ │ │ │ │ +291 _faceEdges = enable; │ │ │ │ │ +292 _edgeVertices = enable; │ │ │ │ │ +293 _edgeFaces = enable; │ │ │ │ │ +294 _vertexFaces = enable; │ │ │ │ │ +295 _vertexEdges = enable; │ │ │ │ │ +296 } │ │ │ │ │ +297 }; │ │ │ │ │ +298 │ │ │ │ │ +299 void subdivideTopology(Relations const& relationsToSubdivide); │ │ │ │ │ +300 │ │ │ │ │ +301 virtual void populateFaceVertexRelation() = 0; │ │ │ │ │ +302 virtual void populateFaceEdgeRelation() = 0; │ │ │ │ │ +303 virtual void populateEdgeVertexRelation() = 0; │ │ │ │ │ +304 virtual void populateEdgeFaceRelation() = 0; │ │ │ │ │ +305 virtual void populateVertexFaceRelation() = 0; │ │ │ │ │ +306 virtual void populateVertexEdgeRelation() = 0; │ │ │ │ │ +307 │ │ │ │ │ +308 // │ │ │ │ │ +309 // Methods involved in subdividing and inspecting sharpness values: │ │ │ │ │ +310 // │ │ │ │ │ +311 void subdivideSharpnessValues(); │ │ │ │ │ 312 │ │ │ │ │ -313 static char const * getTopologyErrorString(TopologyError errCode); │ │ │ │ │ -314 │ │ │ │ │ -315 typedef void (* ValidationCallback)(TopologyError errCode, char const * │ │ │ │ │ -msg, void const * clientData); │ │ │ │ │ +313 void subdivideVertexSharpness(); │ │ │ │ │ +314 void subdivideEdgeSharpness(); │ │ │ │ │ +315 void reclassifySemisharpVertices(); │ │ │ │ │ 316 │ │ │ │ │ -317 bool validateTopology(ValidationCallback callback=0, void const * │ │ │ │ │ -clientData=0) const; │ │ │ │ │ -318 │ │ │ │ │ -319 void print(const Refinement* parentRefinement = 0) const; │ │ │ │ │ -320 │ │ │ │ │ -321public: │ │ │ │ │ -322 // High-level topology queries -- these may be moved elsewhere: │ │ │ │ │ -323 │ │ │ │ │ -324 bool isSingleCreasePatch(_I_n_d_e_x face, float* sharpnessOut=NULL, int* │ │ │ │ │ -rotationOut=NULL) const; │ │ │ │ │ +317 // │ │ │ │ │ +318 // Methods involved in subdividing face-varying topology: │ │ │ │ │ +319 // │ │ │ │ │ +320 void subdivideFVarChannels(); │ │ │ │ │ +321 │ │ │ │ │ +322protected: │ │ │ │ │ +323 // A debug method of Level prints a Refinement (should really change this) │ │ │ │ │ +324 friend void Level::print(const Refinement *) const; │ │ │ │ │ 325 │ │ │ │ │ 326 // │ │ │ │ │ -327 // When inspecting topology, the component tags -- particularly VTag and │ │ │ │ │ -ETag -- are most │ │ │ │ │ -328 // often inspected in groups for the face to which they belong. They are │ │ │ │ │ -designed to be │ │ │ │ │ -329 // bitwise OR'd (the result then referred to as a "composite" tag) to make │ │ │ │ │ -quick decisions │ │ │ │ │ -330 // about the face as a whole to avoid tedious topological inspection. │ │ │ │ │ -331 // │ │ │ │ │ -332 // The same logic can be applied to topology in a FVar channel when tags │ │ │ │ │ -specific to that │ │ │ │ │ -333 // channel are used. Note that the VTags apply to the FVar values assigned │ │ │ │ │ -to the corners │ │ │ │ │ -334 // of the face and not the vertex as a whole. The "composite" face-varying │ │ │ │ │ -VTag for a │ │ │ │ │ -335 // vertex is the union of VTags of all distinct FVar values for that │ │ │ │ │ -vertex. │ │ │ │ │ -336 // │ │ │ │ │ -337 bool doesVertexFVarTopologyMatch(_I_n_d_e_x vIndex, int fvarChannel) const; │ │ │ │ │ -338 bool doesFaceFVarTopologyMatch( _I_n_d_e_x fIndex, int fvarChannel) const; │ │ │ │ │ -339 bool doesEdgeFVarTopologyMatch( _I_n_d_e_x eIndex, int fvarChannel) const; │ │ │ │ │ -340 │ │ │ │ │ -341 void getFaceVTags(_I_n_d_e_x fIndex, VTag vTags[], int fvarChannel = -1) const; │ │ │ │ │ -342 void getFaceETags(_I_n_d_e_x fIndex, ETag eTags[], int fvarChannel = -1) const; │ │ │ │ │ +327 // Data members -- the logical grouping of some of these (and methods that │ │ │ │ │ +make use │ │ │ │ │ +328 // of them) may lead to grouping them into a few utility classes or │ │ │ │ │ +structs... │ │ │ │ │ +329 // │ │ │ │ │ +330 │ │ │ │ │ +331 // Defined on construction: │ │ │ │ │ +332 Level const * _parent; │ │ │ │ │ +333 Level * _child; │ │ │ │ │ +334 Sdc::Options _options; │ │ │ │ │ +335 │ │ │ │ │ +336 // Defined by the subclass: │ │ │ │ │ +337 _S_d_c_:_:_S_p_l_i_t _splitType; │ │ │ │ │ +338 int _regFaceSize; │ │ │ │ │ +339 │ │ │ │ │ +340 // Determined by the refinement options: │ │ │ │ │ +341 bool _uniform; │ │ │ │ │ +342 bool _faceVertsFirst; │ │ │ │ │ 343 │ │ │ │ │ -344 VTag getFaceCompositeVTag(_I_n_d_e_x fIndex, int fvarChannel = -1) const; │ │ │ │ │ -345 VTag getFaceCompositeVTag(_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y & fVerts) const; │ │ │ │ │ -346 │ │ │ │ │ -347 VTag getVertexCompositeFVarVTag(_I_n_d_e_x vIndex, int fvarChannel) const; │ │ │ │ │ -348 │ │ │ │ │ -349 // │ │ │ │ │ -350 // When gathering "patch points" we may want the indices of the vertices or │ │ │ │ │ -the corresponding │ │ │ │ │ -351 // FVar values for a particular channel. Both are represented and equally │ │ │ │ │ -accessible within │ │ │ │ │ -352 // the faces, so we allow all to be returned through these methods. Setting │ │ │ │ │ -the optional FVar │ │ │ │ │ -353 // channel to -1 will retrieve indices of vertices instead of FVar values: │ │ │ │ │ -354 // │ │ │ │ │ -355 int gatherQuadLinearPatchPoints(_I_n_d_e_x fIndex, _I_n_d_e_x patchPoints[], int │ │ │ │ │ -rotation = 0, │ │ │ │ │ -356 int fvarChannel = -1) const; │ │ │ │ │ -357 │ │ │ │ │ -358 int gatherQuadRegularInteriorPatchPoints(_I_n_d_e_x fIndex, _I_n_d_e_x patchPoints[], │ │ │ │ │ -int rotation = 0, │ │ │ │ │ -359 int fvarChannel = -1) const; │ │ │ │ │ -360 int gatherQuadRegularBoundaryPatchPoints(_I_n_d_e_x fIndex, _I_n_d_e_x patchPoints[], │ │ │ │ │ -int boundaryEdgeInFace, │ │ │ │ │ -361 int fvarChannel = -1) const; │ │ │ │ │ -362 int gatherQuadRegularCornerPatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchPoints[], │ │ │ │ │ -int cornerVertInFace, │ │ │ │ │ -363 int fvarChannel = -1) const; │ │ │ │ │ -364 │ │ │ │ │ -365 int gatherQuadRegularRingAroundVertex(_I_n_d_e_x vIndex, _I_n_d_e_x ringPoints[], │ │ │ │ │ -366 int fvarChannel = -1) const; │ │ │ │ │ -367 int gatherQuadRegularPartialRingAroundVertex(_I_n_d_e_x vIndex, VSpan const & │ │ │ │ │ -span, _I_n_d_e_x ringPoints[], │ │ │ │ │ -368 int fvarChannel = -1) const; │ │ │ │ │ -369 │ │ │ │ │ -370 // WIP -- for future use, need to extend for face-varying... │ │ │ │ │ -371 int gatherTriRegularInteriorPatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchVerts[], │ │ │ │ │ -int rotation = 0) const; │ │ │ │ │ -372 int gatherTriRegularBoundaryVertexPatchPoints(_I_n_d_e_x fIndex, _I_n_d_e_x │ │ │ │ │ -patchVerts[], int boundaryVertInFace) const; │ │ │ │ │ -373 int gatherTriRegularBoundaryEdgePatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchVerts │ │ │ │ │ -[], int boundaryEdgeInFace) const; │ │ │ │ │ -374 int gatherTriRegularCornerVertexPatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchVerts │ │ │ │ │ -[], int cornerVertInFace) const; │ │ │ │ │ -375 int gatherTriRegularCornerEdgePatchPoints( _I_n_d_e_x fIndex, _I_n_d_e_x patchVerts │ │ │ │ │ -[], int cornerEdgeInFace) const; │ │ │ │ │ +344 // │ │ │ │ │ +345 // Inventory and ordering of the types of child components: │ │ │ │ │ +346 // │ │ │ │ │ +347 int _childFaceFromFaceCount; // arguably redundant (all faces originate │ │ │ │ │ +from faces) │ │ │ │ │ +348 int _childEdgeFromFaceCount; │ │ │ │ │ +349 int _childEdgeFromEdgeCount; │ │ │ │ │ +350 int _childVertFromFaceCount; │ │ │ │ │ +351 int _childVertFromEdgeCount; │ │ │ │ │ +352 int _childVertFromVertCount; │ │ │ │ │ +353 │ │ │ │ │ +354 int _firstChildFaceFromFace; // arguably redundant (all faces originate │ │ │ │ │ +from faces) │ │ │ │ │ +355 int _firstChildEdgeFromFace; │ │ │ │ │ +356 int _firstChildEdgeFromEdge; │ │ │ │ │ +357 int _firstChildVertFromFace; │ │ │ │ │ +358 int _firstChildVertFromEdge; │ │ │ │ │ +359 int _firstChildVertFromVert; │ │ │ │ │ +360 │ │ │ │ │ +361 // │ │ │ │ │ +362 // The parent-to-child mapping: │ │ │ │ │ +363 // These are vectors sized according to the number of parent components │ │ │ │ │ +(and │ │ │ │ │ +364 // their topology) that contain references/indices to the child components │ │ │ │ │ +that │ │ │ │ │ +365 // result from them by refinement. When refinement is sparse, parent │ │ │ │ │ +components │ │ │ │ │ +366 // that have not spawned all child components will have their missing │ │ │ │ │ +children │ │ │ │ │ +367 // marked as invalid. │ │ │ │ │ +368 // │ │ │ │ │ +369 // NOTE the "Array" members here. Often vectors within the Level can be │ │ │ │ │ +shared │ │ │ │ │ +370 // with the Refinement, and an Array instance is used to do so. If not │ │ │ │ │ +shared │ │ │ │ │ +371 // the subclass just initializes the Array members after allocating its own │ │ │ │ │ +local │ │ │ │ │ +372 // vector members. │ │ │ │ │ +373 // │ │ │ │ │ +374 _I_n_d_e_x_A_r_r_a_y _faceChildFaceCountsAndOffsets; │ │ │ │ │ +375 _I_n_d_e_x_A_r_r_a_y _faceChildEdgeCountsAndOffsets; │ │ │ │ │ 376 │ │ │ │ │ -377public: │ │ │ │ │ -378 // Sizing methods used to construct a level to populate: │ │ │ │ │ -379 void resizeFaces( int numFaces); │ │ │ │ │ -380 void resizeFaceVertices(int numFaceVertsTotal); │ │ │ │ │ -381 void resizeFaceEdges( int numFaceEdgesTotal); │ │ │ │ │ -382 │ │ │ │ │ -383 void resizeEdges( int numEdges); │ │ │ │ │ -384 void resizeEdgeVertices(); // always 2*edgeCount │ │ │ │ │ -385 void resizeEdgeFaces(int numEdgeFacesTotal); │ │ │ │ │ -386 │ │ │ │ │ -387 void resizeVertices( int numVertices); │ │ │ │ │ -388 void resizeVertexFaces(int numVertexFacesTotal); │ │ │ │ │ -389 void resizeVertexEdges(int numVertexEdgesTotal); │ │ │ │ │ -390 │ │ │ │ │ -391 void setMaxValence(int maxValence); │ │ │ │ │ +377 _I_n_d_e_x_V_e_c_t_o_r _faceChildFaceIndices; // *cannot* always use face-vert counts/ │ │ │ │ │ +offsets │ │ │ │ │ +378 _I_n_d_e_x_V_e_c_t_o_r _faceChildEdgeIndices; // can use face-vert counts/offsets │ │ │ │ │ +379 _I_n_d_e_x_V_e_c_t_o_r _faceChildVertIndex; │ │ │ │ │ +380 │ │ │ │ │ +381 _I_n_d_e_x_V_e_c_t_o_r _edgeChildEdgeIndices; // trivial/corresponding pair for each │ │ │ │ │ +382 _I_n_d_e_x_V_e_c_t_o_r _edgeChildVertIndex; │ │ │ │ │ +383 │ │ │ │ │ +384 _I_n_d_e_x_V_e_c_t_o_r _vertChildVertIndex; │ │ │ │ │ +385 │ │ │ │ │ +386 // │ │ │ │ │ +387 // The child-to-parent mapping: │ │ │ │ │ +388 // │ │ │ │ │ +389 _I_n_d_e_x_V_e_c_t_o_r _childFaceParentIndex; │ │ │ │ │ +390 _I_n_d_e_x_V_e_c_t_o_r _childEdgeParentIndex; │ │ │ │ │ +391 _I_n_d_e_x_V_e_c_t_o_r _childVertexParentIndex; │ │ │ │ │ 392 │ │ │ │ │ -393 // Modifiers to populate the relations for each component: │ │ │ │ │ -394 _I_n_d_e_x_A_r_r_a_y getFaceVertices(_I_n_d_e_x faceIndex); │ │ │ │ │ -395 _I_n_d_e_x_A_r_r_a_y getFaceEdges(_I_n_d_e_x faceIndex); │ │ │ │ │ -396 _I_n_d_e_x_A_r_r_a_y getEdgeVertices(_I_n_d_e_x edgeIndex); │ │ │ │ │ -397 _I_n_d_e_x_A_r_r_a_y getEdgeFaces(_I_n_d_e_x edgeIndex); │ │ │ │ │ -398 _I_n_d_e_x_A_r_r_a_y getVertexFaces(_I_n_d_e_x vertIndex); │ │ │ │ │ -399 _I_n_d_e_x_A_r_r_a_y getVertexEdges(_I_n_d_e_x vertIndex); │ │ │ │ │ -400 │ │ │ │ │ -401 _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getEdgeFaceLocalIndices(_I_n_d_e_x edgeIndex); │ │ │ │ │ -402 _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getVertexFaceLocalIndices(_I_n_d_e_x vertIndex); │ │ │ │ │ -403 _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y getVertexEdgeLocalIndices(_I_n_d_e_x vertIndex); │ │ │ │ │ -404 │ │ │ │ │ -405 // Replace these with access to sharpness buffers/arrays rather than │ │ │ │ │ -elements: │ │ │ │ │ -406 float& getEdgeSharpness(_I_n_d_e_x edgeIndex); │ │ │ │ │ -407 float& getVertexSharpness(_I_n_d_e_x vertIndex); │ │ │ │ │ -408 │ │ │ │ │ -409 // Create, destroy and populate face-varying channels: │ │ │ │ │ -410 int createFVarChannel(int fvarValueCount, Sdc::Options const& options); │ │ │ │ │ -411 void destroyFVarChannel(int channel); │ │ │ │ │ +393 std::vector _childFaceTag; │ │ │ │ │ +394 std::vector _childEdgeTag; │ │ │ │ │ +395 std::vector _childVertexTag; │ │ │ │ │ +396 │ │ │ │ │ +397 // │ │ │ │ │ +398 // Tags for sparse selection of components: │ │ │ │ │ +399 // │ │ │ │ │ +400 std::vector _parentFaceTag; │ │ │ │ │ +401 std::vector _parentEdgeTag; │ │ │ │ │ +402 std::vector _parentVertexTag; │ │ │ │ │ +403 │ │ │ │ │ +404 // │ │ │ │ │ +405 // Refinement data for face-varying channels present in the Levels being │ │ │ │ │ +refined: │ │ │ │ │ +406 // │ │ │ │ │ +407 std::vector _fvarChannels; │ │ │ │ │ +408}; │ │ │ │ │ +409 │ │ │ │ │ +410inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +411Refinement::getFaceChildFaces(_I_n_d_e_x parentFace) const { │ │ │ │ │ 412 │ │ │ │ │ -413 _I_n_d_e_x_A_r_r_a_y getFaceFVarValues(_I_n_d_e_x faceIndex, int channel); │ │ │ │ │ -414 │ │ │ │ │ -415 void completeFVarChannelTopology(int channel, int regBoundaryValence); │ │ │ │ │ +413 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceChildFaceIndices │ │ │ │ │ +[_faceChildFaceCountsAndOffsets[2*parentFace+1]], │ │ │ │ │ +414 _faceChildFaceCountsAndOffsets[2*parentFace]); │ │ │ │ │ +415} │ │ │ │ │ 416 │ │ │ │ │ -417 // Counts and offsets for all relation types: │ │ │ │ │ -418 // - these may be unwarranted if we let Refinement access members │ │ │ │ │ -directly... │ │ │ │ │ -419 int getNumFaceVertices( _I_n_d_e_x faceIndex) const { return │ │ │ │ │ -_faceVertCountsAndOffsets[2*faceIndex]; } │ │ │ │ │ -420 int getOffsetOfFaceVertices(_I_n_d_e_x faceIndex) const { return │ │ │ │ │ -_faceVertCountsAndOffsets[2*faceIndex + 1]; } │ │ │ │ │ -421 │ │ │ │ │ -422 int getNumFaceEdges( _I_n_d_e_x faceIndex) const { return getNumFaceVertices │ │ │ │ │ -(faceIndex); } │ │ │ │ │ -423 int getOffsetOfFaceEdges(_I_n_d_e_x faceIndex) const { return │ │ │ │ │ -getOffsetOfFaceVertices(faceIndex); } │ │ │ │ │ -424 │ │ │ │ │ -425 int getNumEdgeVertices( _I_n_d_e_x ) const { return 2; } │ │ │ │ │ -426 int getOffsetOfEdgeVertices(_I_n_d_e_x edgeIndex) const { return 2 * edgeIndex; │ │ │ │ │ -} │ │ │ │ │ -427 │ │ │ │ │ -428 int getNumEdgeFaces( _I_n_d_e_x edgeIndex) const { return │ │ │ │ │ -_edgeFaceCountsAndOffsets[2*edgeIndex]; } │ │ │ │ │ -429 int getOffsetOfEdgeFaces(_I_n_d_e_x edgeIndex) const { return │ │ │ │ │ -_edgeFaceCountsAndOffsets[2*edgeIndex + 1]; } │ │ │ │ │ -430 │ │ │ │ │ -431 int getNumVertexFaces( _I_n_d_e_x vertIndex) const { return │ │ │ │ │ -_vertFaceCountsAndOffsets[2*vertIndex]; } │ │ │ │ │ -432 int getOffsetOfVertexFaces(_I_n_d_e_x vertIndex) const { return │ │ │ │ │ -_vertFaceCountsAndOffsets[2*vertIndex + 1]; } │ │ │ │ │ -433 │ │ │ │ │ -434 int getNumVertexEdges( _I_n_d_e_x vertIndex) const { return │ │ │ │ │ -_vertEdgeCountsAndOffsets[2*vertIndex]; } │ │ │ │ │ -435 int getOffsetOfVertexEdges(_I_n_d_e_x vertIndex) const { return │ │ │ │ │ -_vertEdgeCountsAndOffsets[2*vertIndex + 1]; } │ │ │ │ │ +417inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +418Refinement::getFaceChildFaces(_I_n_d_e_x parentFace) { │ │ │ │ │ +419 │ │ │ │ │ +420 return _I_n_d_e_x_A_r_r_a_y(&_faceChildFaceIndices[_faceChildFaceCountsAndOffsets │ │ │ │ │ +[2*parentFace+1]], │ │ │ │ │ +421 _faceChildFaceCountsAndOffsets[2*parentFace]); │ │ │ │ │ +422} │ │ │ │ │ +423 │ │ │ │ │ +424inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +425Refinement::getFaceChildEdges(_I_n_d_e_x parentFace) const { │ │ │ │ │ +426 │ │ │ │ │ +427 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceChildEdgeIndices │ │ │ │ │ +[_faceChildEdgeCountsAndOffsets[2*parentFace+1]], │ │ │ │ │ +428 _faceChildEdgeCountsAndOffsets[2*parentFace]); │ │ │ │ │ +429} │ │ │ │ │ +430inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +431Refinement::getFaceChildEdges(_I_n_d_e_x parentFace) { │ │ │ │ │ +432 │ │ │ │ │ +433 return _I_n_d_e_x_A_r_r_a_y(&_faceChildEdgeIndices[_faceChildEdgeCountsAndOffsets │ │ │ │ │ +[2*parentFace+1]], │ │ │ │ │ +434 _faceChildEdgeCountsAndOffsets[2*parentFace]); │ │ │ │ │ +435} │ │ │ │ │ 436 │ │ │ │ │ -437 _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y getFaceVertices() const; │ │ │ │ │ -438 │ │ │ │ │ -439 // │ │ │ │ │ -440 // Note that for some relations, the size of the relations for a child │ │ │ │ │ -component │ │ │ │ │ -441 // can vary radically from its parent due to the sparsity of the │ │ │ │ │ -refinement. So │ │ │ │ │ -442 // in these cases a few additional utilities are provided to help define │ │ │ │ │ -the set │ │ │ │ │ -443 // of incident components. Assuming adequate memory has been allocated, the │ │ │ │ │ -444 // "resize" methods here initialize the set of incident components by │ │ │ │ │ -setting │ │ │ │ │ -445 // both the size and the appropriate offset, while "trim" is use to quickly │ │ │ │ │ -lower │ │ │ │ │ -446 // the size from an upper bound and nothing else. │ │ │ │ │ -447 // │ │ │ │ │ -448 void resizeFaceVertices(_I_n_d_e_x FaceIndex, int count); │ │ │ │ │ -449 │ │ │ │ │ -450 void resizeEdgeFaces(_I_n_d_e_x edgeIndex, int count); │ │ │ │ │ -451 void trimEdgeFaces( _I_n_d_e_x edgeIndex, int count); │ │ │ │ │ -452 │ │ │ │ │ -453 void resizeVertexFaces(_I_n_d_e_x vertIndex, int count); │ │ │ │ │ -454 void trimVertexFaces( _I_n_d_e_x vertIndex, int count); │ │ │ │ │ +437inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +438Refinement::getEdgeChildEdges(_I_n_d_e_x parentEdge) const { │ │ │ │ │ +439 │ │ │ │ │ +440 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_edgeChildEdgeIndices[parentEdge*2], 2); │ │ │ │ │ +441} │ │ │ │ │ +442 │ │ │ │ │ +443inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ +444Refinement::getEdgeChildEdges(_I_n_d_e_x parentEdge) { │ │ │ │ │ +445 │ │ │ │ │ +446 return _I_n_d_e_x_A_r_r_a_y(&_edgeChildEdgeIndices[parentEdge*2], 2); │ │ │ │ │ +447} │ │ │ │ │ +448 │ │ │ │ │ +449} // end namespace internal │ │ │ │ │ +450} // end namespace Vtr │ │ │ │ │ +451 │ │ │ │ │ +452} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +453using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +454} // end namespace OpenSubdiv │ │ │ │ │ 455 │ │ │ │ │ -456 void resizeVertexEdges(_I_n_d_e_x vertIndex, int count); │ │ │ │ │ -457 void trimVertexEdges( _I_n_d_e_x vertIndex, int count); │ │ │ │ │ -458 │ │ │ │ │ -459public: │ │ │ │ │ -460 // │ │ │ │ │ -461 // Initial plans were to have a few specific classes properly construct the │ │ │ │ │ -462 // topology from scratch, e.g. the Refinement class and a Factory class for │ │ │ │ │ -463 // the base level, by populating all topological relations. The need to │ │ │ │ │ -have │ │ │ │ │ -464 // a class construct full topology given only a simple face-vertex list, │ │ │ │ │ -made │ │ │ │ │ -465 // it necessary to write code to define and orient all relations -- and │ │ │ │ │ -most │ │ │ │ │ -466 // of that seemed best placed here. │ │ │ │ │ -467 // │ │ │ │ │ -468 bool completeTopologyFromFaceVertices(); │ │ │ │ │ -469 _I_n_d_e_x findEdge(_I_n_d_e_x v0, _I_n_d_e_x v1, _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y v0Edges) const; │ │ │ │ │ -470 │ │ │ │ │ -471 // Methods supporting the above: │ │ │ │ │ -472 void orientIncidentComponents(); │ │ │ │ │ -473 bool orderVertexFacesAndEdges(_I_n_d_e_x vIndex, _I_n_d_e_x* vFaces, _I_n_d_e_x* vEdges) │ │ │ │ │ -const; │ │ │ │ │ -474 bool orderVertexFacesAndEdges(_I_n_d_e_x vIndex); │ │ │ │ │ -475 void populateLocalIndices(); │ │ │ │ │ -476 │ │ │ │ │ -477 _I_n_d_e_x_A_r_r_a_y shareFaceVertCountsAndOffsets() const; │ │ │ │ │ -478 │ │ │ │ │ -479private: │ │ │ │ │ -480 // Refinement classes (including all subclasses) build a Level: │ │ │ │ │ -481 friend class Refinement; │ │ │ │ │ -482 friend class TriRefinement; │ │ │ │ │ -483 friend class QuadRefinement; │ │ │ │ │ -484 │ │ │ │ │ -485 // │ │ │ │ │ -486 // A Level is independent of subdivision scheme or options. While it may │ │ │ │ │ -have been │ │ │ │ │ -487 // affected by them in its construction, they are not associated with it - │ │ │ │ │ -- a Level │ │ │ │ │ -488 // is pure topology and any subdivision parameters are external. │ │ │ │ │ -489 // │ │ │ │ │ -490 │ │ │ │ │ -491 // Simple members for inventory, etc. │ │ │ │ │ -492 int _faceCount; │ │ │ │ │ -493 int _edgeCount; │ │ │ │ │ -494 int _vertCount; │ │ │ │ │ -495 │ │ │ │ │ -496 // The "depth" member is clearly useful in both the topological splitting │ │ │ │ │ -and the │ │ │ │ │ -497 // stencil queries, but arguably it ties the Level to a hierarchy which │ │ │ │ │ -counters │ │ │ │ │ -498 // the idea of it being independent. │ │ │ │ │ -499 int _depth; │ │ │ │ │ -500 │ │ │ │ │ -501 // Maxima to help clients manage sizing of data buffers. Given "max │ │ │ │ │ -valence", │ │ │ │ │ -502 // the "max edge faces" is strictly redundant as it will always be less, │ │ │ │ │ -but │ │ │ │ │ -503 // since it will typically be so much less (i.e. 2) it is kept for now. │ │ │ │ │ -504 int _maxEdgeFaces; │ │ │ │ │ -505 int _maxValence; │ │ │ │ │ -506 │ │ │ │ │ -507 // │ │ │ │ │ -508 // Topology vectors: │ │ │ │ │ -509 // Note that of all of these, only data for the face-edge relation is not │ │ │ │ │ -510 // stored in the osd::FarTables in any form. The FarTable vectors combine │ │ │ │ │ -511 // the edge-vert and edge-face relations. The eventual goal is that this │ │ │ │ │ -512 // data be part of the osd::Far classes and be a superset of the FarTable │ │ │ │ │ -513 // vectors, i.e. no data duplication or conversion. The fact that FarTable │ │ │ │ │ -514 // already stores 5 of the 6 possible relations should make the topology │ │ │ │ │ -515 // storage as a whole a non-issue. │ │ │ │ │ -516 // │ │ │ │ │ -517 // The vert-face-child and vert-edge-child indices are also arguably not │ │ │ │ │ -518 // a topology relation but more one for parent/child relations. But it is │ │ │ │ │ -519 // a topological relationship, and if named differently would not likely │ │ │ │ │ -520 // raise this. It has been named with "child" in the name as it does play │ │ │ │ │ -521 // a more significant role during subdivision in mapping between parent │ │ │ │ │ -522 // and child components, and so has been named to reflect that more │ │ │ │ │ -clearly. │ │ │ │ │ -523 // │ │ │ │ │ -524 │ │ │ │ │ -525 // Per-face: │ │ │ │ │ -526 std::vector _faceVertCountsAndOffsets; // 2 per face, redundant │ │ │ │ │ -after level 0 │ │ │ │ │ -527 std::vector _faceVertIndices; // 3 or 4 per face, variable at level │ │ │ │ │ -0 │ │ │ │ │ -528 std::vector _faceEdgeIndices; // matches face-vert indices │ │ │ │ │ -529 std::vector _faceTags; // 1 per face: includes "hole" tag │ │ │ │ │ -530 │ │ │ │ │ -531 // Per-edge: │ │ │ │ │ -532 std::vector _edgeVertIndices; // 2 per edge │ │ │ │ │ -533 std::vector _edgeFaceCountsAndOffsets; // 2 per edge │ │ │ │ │ -534 std::vector _edgeFaceIndices; // varies with faces per edge │ │ │ │ │ -535 std::vector _edgeFaceLocalIndices; // varies with faces per │ │ │ │ │ -edge │ │ │ │ │ -536 │ │ │ │ │ -537 std::vector _edgeSharpness; // 1 per edge │ │ │ │ │ -538 std::vector _edgeTags; // 1 per edge: manifold, boundary, etc. │ │ │ │ │ -539 │ │ │ │ │ -540 // Per-vertex: │ │ │ │ │ -541 std::vector _vertFaceCountsAndOffsets; // 2 per vertex │ │ │ │ │ -542 std::vector _vertFaceIndices; // varies with valence │ │ │ │ │ -543 std::vector _vertFaceLocalIndices; // varies with valence, 8- │ │ │ │ │ -bit for now │ │ │ │ │ -544 │ │ │ │ │ -545 std::vector _vertEdgeCountsAndOffsets; // 2 per vertex │ │ │ │ │ -546 std::vector _vertEdgeIndices; // varies with valence │ │ │ │ │ -547 std::vector _vertEdgeLocalIndices; // varies with valence, 8- │ │ │ │ │ -bit for now │ │ │ │ │ -548 │ │ │ │ │ -549 std::vector _vertSharpness; // 1 per vertex │ │ │ │ │ -550 std::vector _vertTags; // 1 per vertex: manifold, Sdc::Rule, etc. │ │ │ │ │ -551 │ │ │ │ │ -552 // Face-varying channels: │ │ │ │ │ -553 std::vector _fvarChannels; │ │ │ │ │ -554}; │ │ │ │ │ -555 │ │ │ │ │ -556// │ │ │ │ │ -557// Access/modify the vertices incident a given face: │ │ │ │ │ -558// │ │ │ │ │ -559inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -560Level::getFaceVertices(_I_n_d_e_x faceIndex) const { │ │ │ │ │ -561 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceVertIndices[_faceVertCountsAndOffsets │ │ │ │ │ -[faceIndex*2+1]], │ │ │ │ │ -562 _faceVertCountsAndOffsets[faceIndex*2]); │ │ │ │ │ -563} │ │ │ │ │ -564inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -565Level::getFaceVertices(_I_n_d_e_x faceIndex) { │ │ │ │ │ -566 return _I_n_d_e_x_A_r_r_a_y(&_faceVertIndices[_faceVertCountsAndOffsets │ │ │ │ │ -[faceIndex*2+1]], │ │ │ │ │ -567 _faceVertCountsAndOffsets[faceIndex*2]); │ │ │ │ │ -568} │ │ │ │ │ -569 │ │ │ │ │ -570inline void │ │ │ │ │ -571Level::resizeFaceVertices(_I_n_d_e_x faceIndex, int count) { │ │ │ │ │ -572 │ │ │ │ │ -573 int* countOffsetPair = &_faceVertCountsAndOffsets[faceIndex*2]; │ │ │ │ │ -574 │ │ │ │ │ -575 countOffsetPair[0] = count; │ │ │ │ │ -576 countOffsetPair[1] = (faceIndex == 0) ? 0 : (countOffsetPair[-2] + │ │ │ │ │ -countOffsetPair[-1]); │ │ │ │ │ -577 │ │ │ │ │ -578 _maxValence = std::max(_maxValence, count); │ │ │ │ │ -579} │ │ │ │ │ -580 │ │ │ │ │ -581inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -582Level::getFaceVertices() const { │ │ │ │ │ -583 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceVertIndices[0], (int)_faceVertIndices.size()); │ │ │ │ │ -584} │ │ │ │ │ -585 │ │ │ │ │ -586// │ │ │ │ │ -587// Access/modify the edges incident a given face: │ │ │ │ │ -588// │ │ │ │ │ -589inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -590Level::getFaceEdges(_I_n_d_e_x faceIndex) const { │ │ │ │ │ -591 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_faceEdgeIndices[_faceVertCountsAndOffsets │ │ │ │ │ -[faceIndex*2+1]], │ │ │ │ │ -592 _faceVertCountsAndOffsets[faceIndex*2]); │ │ │ │ │ -593} │ │ │ │ │ -594inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -595Level::getFaceEdges(_I_n_d_e_x faceIndex) { │ │ │ │ │ -596 return _I_n_d_e_x_A_r_r_a_y(&_faceEdgeIndices[_faceVertCountsAndOffsets │ │ │ │ │ -[faceIndex*2+1]], │ │ │ │ │ -597 _faceVertCountsAndOffsets[faceIndex*2]); │ │ │ │ │ -598} │ │ │ │ │ -599 │ │ │ │ │ -600// │ │ │ │ │ -601// Access/modify the faces incident a given vertex: │ │ │ │ │ -602// │ │ │ │ │ -603inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -604Level::getVertexFaces(_I_n_d_e_x vertIndex) const { │ │ │ │ │ -605 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y( (&_vertFaceIndices[0]) + _vertFaceCountsAndOffsets │ │ │ │ │ -[vertIndex*2+1], │ │ │ │ │ -606 _vertFaceCountsAndOffsets[vertIndex*2]); │ │ │ │ │ -607} │ │ │ │ │ -608inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -609Level::getVertexFaces(_I_n_d_e_x vertIndex) { │ │ │ │ │ -610 return _I_n_d_e_x_A_r_r_a_y( (&_vertFaceIndices[0]) + _vertFaceCountsAndOffsets │ │ │ │ │ -[vertIndex*2+1], │ │ │ │ │ -611 _vertFaceCountsAndOffsets[vertIndex*2]); │ │ │ │ │ -612} │ │ │ │ │ -613 │ │ │ │ │ -614inline _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -615Level::getVertexFaceLocalIndices(_I_n_d_e_x vertIndex) const { │ │ │ │ │ -616 return _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y( (&_vertFaceLocalIndices[0]) + │ │ │ │ │ -_vertFaceCountsAndOffsets[vertIndex*2+1], │ │ │ │ │ -617 _vertFaceCountsAndOffsets[vertIndex*2]); │ │ │ │ │ -618} │ │ │ │ │ -619inline _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -620Level::getVertexFaceLocalIndices(_I_n_d_e_x vertIndex) { │ │ │ │ │ -621 return _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y( (&_vertFaceLocalIndices[0]) + │ │ │ │ │ -_vertFaceCountsAndOffsets[vertIndex*2+1], │ │ │ │ │ -622 _vertFaceCountsAndOffsets[vertIndex*2]); │ │ │ │ │ -623} │ │ │ │ │ -624 │ │ │ │ │ -625inline void │ │ │ │ │ -626Level::resizeVertexFaces(_I_n_d_e_x vertIndex, int count) { │ │ │ │ │ -627 int* countOffsetPair = &_vertFaceCountsAndOffsets[vertIndex*2]; │ │ │ │ │ -628 │ │ │ │ │ -629 countOffsetPair[0] = count; │ │ │ │ │ -630 countOffsetPair[1] = (vertIndex == 0) ? 0 : (countOffsetPair[-2] + │ │ │ │ │ -countOffsetPair[-1]); │ │ │ │ │ -631} │ │ │ │ │ -632inline void │ │ │ │ │ -633Level::trimVertexFaces(_I_n_d_e_x vertIndex, int count) { │ │ │ │ │ -634 _vertFaceCountsAndOffsets[vertIndex*2] = count; │ │ │ │ │ -635} │ │ │ │ │ -636 │ │ │ │ │ -637// │ │ │ │ │ -638// Access/modify the edges incident a given vertex: │ │ │ │ │ -639// │ │ │ │ │ -640inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -641Level::getVertexEdges(_I_n_d_e_x vertIndex) const { │ │ │ │ │ -642 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y( (&_vertEdgeIndices[0]) +_vertEdgeCountsAndOffsets │ │ │ │ │ -[vertIndex*2+1], │ │ │ │ │ -643 _vertEdgeCountsAndOffsets[vertIndex*2]); │ │ │ │ │ -644} │ │ │ │ │ -645inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -646Level::getVertexEdges(_I_n_d_e_x vertIndex) { │ │ │ │ │ -647 return _I_n_d_e_x_A_r_r_a_y( (&_vertEdgeIndices[0]) +_vertEdgeCountsAndOffsets │ │ │ │ │ -[vertIndex*2+1], │ │ │ │ │ -648 _vertEdgeCountsAndOffsets[vertIndex*2]); │ │ │ │ │ -649} │ │ │ │ │ -650 │ │ │ │ │ -651inline _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -652Level::getVertexEdgeLocalIndices(_I_n_d_e_x vertIndex) const { │ │ │ │ │ -653 return _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y( (&_vertEdgeLocalIndices[0]) + │ │ │ │ │ -_vertEdgeCountsAndOffsets[vertIndex*2+1], │ │ │ │ │ -654 _vertEdgeCountsAndOffsets[vertIndex*2]); │ │ │ │ │ -655} │ │ │ │ │ -656inline _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -657Level::getVertexEdgeLocalIndices(_I_n_d_e_x vertIndex) { │ │ │ │ │ -658 return _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y( (&_vertEdgeLocalIndices[0]) + │ │ │ │ │ -_vertEdgeCountsAndOffsets[vertIndex*2+1], │ │ │ │ │ -659 _vertEdgeCountsAndOffsets[vertIndex*2]); │ │ │ │ │ -660} │ │ │ │ │ -661 │ │ │ │ │ -662inline void │ │ │ │ │ -663Level::resizeVertexEdges(_I_n_d_e_x vertIndex, int count) { │ │ │ │ │ -664 int* countOffsetPair = &_vertEdgeCountsAndOffsets[vertIndex*2]; │ │ │ │ │ -665 │ │ │ │ │ -666 countOffsetPair[0] = count; │ │ │ │ │ -667 countOffsetPair[1] = (vertIndex == 0) ? 0 : (countOffsetPair[-2] + │ │ │ │ │ -countOffsetPair[-1]); │ │ │ │ │ -668 │ │ │ │ │ -669 _maxValence = std::max(_maxValence, count); │ │ │ │ │ -670} │ │ │ │ │ -671inline void │ │ │ │ │ -672Level::trimVertexEdges(_I_n_d_e_x vertIndex, int count) { │ │ │ │ │ -673 _vertEdgeCountsAndOffsets[vertIndex*2] = count; │ │ │ │ │ -674} │ │ │ │ │ -675 │ │ │ │ │ -676inline void │ │ │ │ │ -677Level::setMaxValence(int valence) { │ │ │ │ │ -678 _maxValence = valence; │ │ │ │ │ -679} │ │ │ │ │ -680 │ │ │ │ │ -681// │ │ │ │ │ -682// Access/modify the vertices incident a given edge: │ │ │ │ │ -683// │ │ │ │ │ -684inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -685Level::getEdgeVertices(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ -686 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_edgeVertIndices[edgeIndex*2], 2); │ │ │ │ │ -687} │ │ │ │ │ -688inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -689Level::getEdgeVertices(_I_n_d_e_x edgeIndex) { │ │ │ │ │ -690 return _I_n_d_e_x_A_r_r_a_y(&_edgeVertIndices[edgeIndex*2], 2); │ │ │ │ │ -691} │ │ │ │ │ -692 │ │ │ │ │ -693// │ │ │ │ │ -694// Access/modify the faces incident a given edge: │ │ │ │ │ -695// │ │ │ │ │ -696inline _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -697Level::getEdgeFaces(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ -698 return _C_o_n_s_t_I_n_d_e_x_A_r_r_a_y(&_edgeFaceIndices[0] + │ │ │ │ │ -699 _edgeFaceCountsAndOffsets[edgeIndex*2+1], │ │ │ │ │ -700 _edgeFaceCountsAndOffsets[edgeIndex*2]); │ │ │ │ │ -701} │ │ │ │ │ -702inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -703Level::getEdgeFaces(_I_n_d_e_x edgeIndex) { │ │ │ │ │ -704 return _I_n_d_e_x_A_r_r_a_y(&_edgeFaceIndices[0] + │ │ │ │ │ -705 _edgeFaceCountsAndOffsets[edgeIndex*2+1], │ │ │ │ │ -706 _edgeFaceCountsAndOffsets[edgeIndex*2]); │ │ │ │ │ -707} │ │ │ │ │ -708 │ │ │ │ │ -709inline _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -710Level::getEdgeFaceLocalIndices(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ -711 return _C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y(&_edgeFaceLocalIndices[0] + │ │ │ │ │ -712 _edgeFaceCountsAndOffsets[edgeIndex*2+1], │ │ │ │ │ -713 _edgeFaceCountsAndOffsets[edgeIndex*2]); │ │ │ │ │ -714} │ │ │ │ │ -715inline _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -716Level::getEdgeFaceLocalIndices(_I_n_d_e_x edgeIndex) { │ │ │ │ │ -717 return _L_o_c_a_l_I_n_d_e_x_A_r_r_a_y(&_edgeFaceLocalIndices[0] + │ │ │ │ │ -718 _edgeFaceCountsAndOffsets[edgeIndex*2+1], │ │ │ │ │ -719 _edgeFaceCountsAndOffsets[edgeIndex*2]); │ │ │ │ │ -720} │ │ │ │ │ -721 │ │ │ │ │ -722inline void │ │ │ │ │ -723Level::resizeEdgeFaces(_I_n_d_e_x edgeIndex, int count) { │ │ │ │ │ -724 int* countOffsetPair = &_edgeFaceCountsAndOffsets[edgeIndex*2]; │ │ │ │ │ -725 │ │ │ │ │ -726 countOffsetPair[0] = count; │ │ │ │ │ -727 countOffsetPair[1] = (edgeIndex == 0) ? 0 : (countOffsetPair[-2] + │ │ │ │ │ -countOffsetPair[-1]); │ │ │ │ │ -728 │ │ │ │ │ -729 _maxEdgeFaces = std::max(_maxEdgeFaces, count); │ │ │ │ │ -730} │ │ │ │ │ -731inline void │ │ │ │ │ -732Level::trimEdgeFaces(_I_n_d_e_x edgeIndex, int count) { │ │ │ │ │ -733 _edgeFaceCountsAndOffsets[edgeIndex*2] = count; │ │ │ │ │ -734} │ │ │ │ │ -735 │ │ │ │ │ -736// │ │ │ │ │ -737// Access/modify sharpness values: │ │ │ │ │ -738// │ │ │ │ │ -739inline float │ │ │ │ │ -740Level::getEdgeSharpness(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ -741 return _edgeSharpness[edgeIndex]; │ │ │ │ │ -742} │ │ │ │ │ -743inline float& │ │ │ │ │ -744Level::getEdgeSharpness(_I_n_d_e_x edgeIndex) { │ │ │ │ │ -745 return _edgeSharpness[edgeIndex]; │ │ │ │ │ -746} │ │ │ │ │ -747 │ │ │ │ │ -748inline float │ │ │ │ │ -749Level::getVertexSharpness(_I_n_d_e_x vertIndex) const { │ │ │ │ │ -750 return _vertSharpness[vertIndex]; │ │ │ │ │ -751} │ │ │ │ │ -752inline float& │ │ │ │ │ -753Level::getVertexSharpness(_I_n_d_e_x vertIndex) { │ │ │ │ │ -754 return _vertSharpness[vertIndex]; │ │ │ │ │ -755} │ │ │ │ │ -756 │ │ │ │ │ -757inline _S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ -758Level::getVertexRule(_I_n_d_e_x vertIndex) const { │ │ │ │ │ -759 return (_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e) _vertTags[vertIndex]._rule; │ │ │ │ │ -760} │ │ │ │ │ -761 │ │ │ │ │ -762// │ │ │ │ │ -763// Access/modify hole tag: │ │ │ │ │ -764// │ │ │ │ │ -765inline void │ │ │ │ │ -766Level::setFaceHole(_I_n_d_e_x faceIndex, bool b) { │ │ │ │ │ -767 _faceTags[faceIndex]._hole = b; │ │ │ │ │ -768} │ │ │ │ │ -769inline bool │ │ │ │ │ -770Level::isFaceHole(_I_n_d_e_x faceIndex) const { │ │ │ │ │ -771 return _faceTags[faceIndex]._hole; │ │ │ │ │ -772} │ │ │ │ │ -773 │ │ │ │ │ -774// │ │ │ │ │ -775// Access/modify non-manifold tags: │ │ │ │ │ -776// │ │ │ │ │ -777inline void │ │ │ │ │ -778Level::setEdgeNonManifold(_I_n_d_e_x edgeIndex, bool b) { │ │ │ │ │ -779 _edgeTags[edgeIndex]._nonManifold = b; │ │ │ │ │ -780} │ │ │ │ │ -781inline bool │ │ │ │ │ -782Level::isEdgeNonManifold(_I_n_d_e_x edgeIndex) const { │ │ │ │ │ -783 return _edgeTags[edgeIndex]._nonManifold; │ │ │ │ │ -784} │ │ │ │ │ -785 │ │ │ │ │ -786inline void │ │ │ │ │ -787Level::setVertexNonManifold(_I_n_d_e_x vertIndex, bool b) { │ │ │ │ │ -788 _vertTags[vertIndex]._nonManifold = b; │ │ │ │ │ -789} │ │ │ │ │ -790inline bool │ │ │ │ │ -791Level::isVertexNonManifold(_I_n_d_e_x vertIndex) const { │ │ │ │ │ -792 return _vertTags[vertIndex]._nonManifold; │ │ │ │ │ -793} │ │ │ │ │ -794 │ │ │ │ │ -795// │ │ │ │ │ -796// Sizing methods to allocate space: │ │ │ │ │ -797// │ │ │ │ │ -798inline void │ │ │ │ │ -799Level::resizeFaces(int faceCount) { │ │ │ │ │ -800 _faceCount = faceCount; │ │ │ │ │ -801 _faceVertCountsAndOffsets.resize(2 * faceCount); │ │ │ │ │ -802 │ │ │ │ │ -803 _faceTags.resize(faceCount); │ │ │ │ │ -804 std::memset((void*) &_faceTags[0], 0, _faceCount * sizeof(FTag)); │ │ │ │ │ -805} │ │ │ │ │ -806inline void │ │ │ │ │ -807Level::resizeFaceVertices(int totalFaceVertCount) { │ │ │ │ │ -808 _faceVertIndices.resize(totalFaceVertCount); │ │ │ │ │ -809} │ │ │ │ │ -810inline void │ │ │ │ │ -811Level::resizeFaceEdges(int totalFaceEdgeCount) { │ │ │ │ │ -812 _faceEdgeIndices.resize(totalFaceEdgeCount); │ │ │ │ │ -813} │ │ │ │ │ -814 │ │ │ │ │ -815inline void │ │ │ │ │ -816Level::resizeEdges(int edgeCount) { │ │ │ │ │ -817 │ │ │ │ │ -818 _edgeCount = edgeCount; │ │ │ │ │ -819 _edgeFaceCountsAndOffsets.resize(2 * edgeCount); │ │ │ │ │ -820 │ │ │ │ │ -821 _edgeSharpness.resize(edgeCount); │ │ │ │ │ -822 _edgeTags.resize(edgeCount); │ │ │ │ │ -823 │ │ │ │ │ -824 if (edgeCount>0) { │ │ │ │ │ -825 std::memset((void*) &_edgeTags[0], 0, _edgeCount * sizeof(ETag)); │ │ │ │ │ -826 } │ │ │ │ │ -827} │ │ │ │ │ -828inline void │ │ │ │ │ -829Level::resizeEdgeVertices() { │ │ │ │ │ -830 │ │ │ │ │ -831 _edgeVertIndices.resize(2 * _edgeCount); │ │ │ │ │ -832} │ │ │ │ │ -833inline void │ │ │ │ │ -834Level::resizeEdgeFaces(int totalEdgeFaceCount) { │ │ │ │ │ -835 │ │ │ │ │ -836 _edgeFaceIndices.resize(totalEdgeFaceCount); │ │ │ │ │ -837 _edgeFaceLocalIndices.resize(totalEdgeFaceCount); │ │ │ │ │ -838} │ │ │ │ │ -839 │ │ │ │ │ -840inline void │ │ │ │ │ -841Level::resizeVertices(int vertCount) { │ │ │ │ │ -842 │ │ │ │ │ -843 _vertCount = vertCount; │ │ │ │ │ -844 _vertFaceCountsAndOffsets.resize(2 * vertCount); │ │ │ │ │ -845 _vertEdgeCountsAndOffsets.resize(2 * vertCount); │ │ │ │ │ -846 │ │ │ │ │ -847 _vertSharpness.resize(vertCount); │ │ │ │ │ -848 _vertTags.resize(vertCount); │ │ │ │ │ -849 std::memset((void*) &_vertTags[0], 0, _vertCount * sizeof(VTag)); │ │ │ │ │ -850} │ │ │ │ │ -851inline void │ │ │ │ │ -852Level::resizeVertexFaces(int totalVertFaceCount) { │ │ │ │ │ -853 │ │ │ │ │ -854 _vertFaceIndices.resize(totalVertFaceCount); │ │ │ │ │ -855 _vertFaceLocalIndices.resize(totalVertFaceCount); │ │ │ │ │ -856} │ │ │ │ │ -857inline void │ │ │ │ │ -858Level::resizeVertexEdges(int totalVertEdgeCount) { │ │ │ │ │ -859 │ │ │ │ │ -860 _vertEdgeIndices.resize(totalVertEdgeCount); │ │ │ │ │ -861 _vertEdgeLocalIndices.resize(totalVertEdgeCount); │ │ │ │ │ -862} │ │ │ │ │ -863 │ │ │ │ │ -864inline _I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -865Level::shareFaceVertCountsAndOffsets() const { │ │ │ │ │ -866 // XXXX manuelk we have to force const casting here (classes don't 'share' │ │ │ │ │ -867 // members usually...) │ │ │ │ │ -868 return _I_n_d_e_x_A_r_r_a_y(const_cast<_I_n_d_e_x *>(&_faceVertCountsAndOffsets[0]), │ │ │ │ │ -869 (int)_faceVertCountsAndOffsets.size()); │ │ │ │ │ -870} │ │ │ │ │ -871 │ │ │ │ │ -872} // end namespace internal │ │ │ │ │ -873} // end namespace Vtr │ │ │ │ │ -874 │ │ │ │ │ -875} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -876using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -877} // end namespace OpenSubdiv │ │ │ │ │ -878 │ │ │ │ │ -879#endif /* OPENSUBDIV3_VTR_LEVEL_H */ │ │ │ │ │ +456#endif /* OPENSUBDIV3_VTR_REFINEMENT_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -ConstArray< LocalIndex > ConstLocalIndexArray │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_8_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_L_o_c_a_l_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ -Array< LocalIndex > LocalIndexArray │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_8_2 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x │ │ │ │ │ int Index │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x_V_e_c_t_o_r │ │ │ │ │ +std::vector< Index > IndexVector │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_7_7 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_C_o_n_s_t_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ ConstArray< Index > ConstIndexArray │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_8_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_L_o_c_a_l_I_n_d_e_x │ │ │ │ │ -unsigned short LocalIndex │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_6_6 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_V_t_r_:_:_I_n_d_e_x_A_r_r_a_y │ │ │ │ │ Array< Index > IndexArray │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_7_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ -Rule │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_p_l_i_t │ │ │ │ │ +Split │ │ │ │ │ +Enumerated type for all face splitting schemes. │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _v_t_r │ │ │ │ │ - * _l_e_v_e_l_._h │ │ │ │ │ + * _r_e_f_i_n_e_m_e_n_t_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00758.html │ │ │ │ @@ -94,17 +94,17 @@ │ │ │ │
│ │ │ │ Namespaces
│ │ │ │
fvarRefinement.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include "../sdc/types.h"
│ │ │ │ -#include "../sdc/crease.h"
│ │ │ │ +#include "../sdc/crease.h"
│ │ │ │ #include "../vtr/types.h"
│ │ │ │ -#include "../vtr/refinement.h"
│ │ │ │ +#include "../vtr/refinement.h"
│ │ │ │ #include "../vtr/fvarLevel.h"
│ │ │ │ #include <vector>
│ │ │ │ #include <cassert>
│ │ │ │ #include <cstring>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00758_source.html │ │ │ │ @@ -212,15 +212,15 @@ │ │ │ │
111} // end namespace Vtr
│ │ │ │
112
│ │ │ │
113} // end namespace OPENSUBDIV_VERSION
│ │ │ │
114using namespace OPENSUBDIV_VERSION;
│ │ │ │
115} // end namespace OpenSubdiv
│ │ │ │
116
│ │ │ │
117#endif /* OPENSUBDIV3_VTR_FVAR_REFINEMENT_H */
│ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include "../sdc/types.h"
│ │ │ │ -#include "../sdc/crease.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ +#include "../sdc/crease.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │ #include "../vtr/types.h"
│ │ │ │ -#include "../vtr/level.h"
│ │ │ │ +#include "../vtr/level.h"
│ │ │ │ #include <vector>
│ │ │ │ #include <cassert>
│ │ │ │ #include <cstring>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00761_source.html │ │ │ │ @@ -534,23 +534,23 @@ │ │ │ │
433} // end namespace Vtr
│ │ │ │
434
│ │ │ │
435} // end namespace OPENSUBDIV_VERSION
│ │ │ │
436using namespace OPENSUBDIV_VERSION;
│ │ │ │
437} // end namespace OpenSubdiv
│ │ │ │
438
│ │ │ │
439#endif /* OPENSUBDIV3_VTR_FVAR_LEVEL_H */
│ │ │ │ - │ │ │ │ + │ │ │ │
ConstArray< LocalIndex > ConstLocalIndexArray
Definition types.h:83
│ │ │ │
Array< LocalIndex > LocalIndexArray
Definition types.h:82
│ │ │ │ │ │ │ │
ConstArray< Index > ConstIndexArray
Definition types.h:80
│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include "../sdc/types.h"
│ │ │ │ -#include "../sdc/crease.h"
│ │ │ │ +#include "../sdc/crease.h"
│ │ │ │ #include "../vtr/types.h"
│ │ │ │ #include "../vtr/stackBuffer.h"
│ │ │ │ #include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00764_source.html │ │ │ │ @@ -253,15 +253,15 @@ │ │ │ │
152} // end namespace Vtr
│ │ │ │
153
│ │ │ │
154} // end namespace OPENSUBDIV_VERSION
│ │ │ │
155using namespace OPENSUBDIV_VERSION;
│ │ │ │
156} // end namespace OpenSubdiv
│ │ │ │
157
│ │ │ │
158#endif /* OPENSUBDIV3_VTR_COMPONENT_INTERFACES_H */
│ │ │ │ - │ │ │ │ + │ │ │ │
ConstArray< Index > ConstIndexArray
Definition types.h:80
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ +Classes | │ │ │ │ Namespaces
│ │ │ │ -
loopScheme.h File Reference
│ │ │ │ +
scheme.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/scheme.h"
│ │ │ │ +#include "../sdc/types.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │ +#include "../sdc/crease.h"
│ │ │ │ #include <cassert>
│ │ │ │ -#include <cmath>
│ │ │ │ +#include <cstdlib>
│ │ │ │ +#include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +

│ │ │ │ +Classes

class  Scheme< SCHEME_TYPE >
 Scheme is a class template which provides all implementation for the subdivision schemes supported by OpenSubdiv through specializations of the methods of each. An instance of Scheme<SCHEME_TYPE> includes a set of Options that will dictate the variable aspects of its behavior.
│ │ │ │ + More...
 
class  Scheme< SCHEME_TYPE >::LocalMask< WEIGHT >
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Sdc
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,22 +1,35 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -_N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -loopScheme.h File Reference │ │ │ │ │ +_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ +scheme.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_s_d_c_/_s_c_h_e_m_e_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_c_r_e_a_s_e_._h" │ │ │ │ │ #include │ │ │ │ │ -#include │ │ │ │ │ +#include │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ +CCllaasssseess │ │ │ │ │ +class   _S_c_h_e_m_e_<_ _S_C_H_E_M_E___T_Y_P_E_ _> │ │ │ │ │ + _S_c_h_e_m_e is a class template which provides all implementation for the │ │ │ │ │ + subdivision schemes supported by _O_p_e_n_S_u_b_d_i_v through specializations of │ │ │ │ │ +  the methods of each. An instance of Scheme includes a set │ │ │ │ │ + of _O_p_t_i_o_n_s that will dictate the variable aspects of its behavior. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +class   _S_c_h_e_m_e_<_ _S_C_H_E_M_E___T_Y_P_E_ _>_:_:_L_o_c_a_l_M_a_s_k_<_ _W_E_I_G_H_T_ _> │ │ │ │ │ +  │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _s_d_c │ │ │ │ │ - * _l_o_o_p_S_c_h_e_m_e_._h │ │ │ │ │ + * _s_c_h_e_m_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00770_source.html │ │ │ │ @@ -22,6257 +22,8471 @@ │ │ │ │ 00000150: 656e 743d 2244 6f78 7967 656e 2031 2e39 ent="Doxygen 1.9 │ │ │ │ 00000160: 2e38 222f 3e0a 3c6d 6574 6120 6e61 6d65 .8"/>..OpenSubdiv: o │ │ │ │ -000001c0: 7065 6e73 7562 6469 762f 7364 632f 6c6f pensubdiv/sdc/lo │ │ │ │ -000001d0: 6f70 5363 6865 6d65 2e68 2053 6f75 7263 opScheme.h Sourc │ │ │ │ -000001e0: 6520 4669 6c65 3c2f 7469 746c 653e 0a3c e File.< │ │ │ │ -000001f0: 6c69 6e6b 2068 7265 663d 2274 6162 732e link href="tabs. │ │ │ │ -00000200: 6373 7322 2072 656c 3d22 7374 796c 6573 css" rel="styles │ │ │ │ -00000210: 6865 6574 2220 7479 7065 3d22 7465 7874 heet" type="text │ │ │ │ -00000220: 2f63 7373 222f 3e0a 3c73 6372 6970 7420 /css"/>. │ │ │ │ -00000260: 0a3c 7363 7269 7074 2074 7970 653d 2274 ..< │ │ │ │ -000002a0: 6c69 6e6b 2068 7265 663d 226e 6176 7472 link href="navtr │ │ │ │ -000002b0: 6565 2e63 7373 2220 7265 6c3d 2273 7479 ee.css" rel="sty │ │ │ │ -000002c0: 6c65 7368 6565 7422 2074 7970 653d 2274 lesheet" type="t │ │ │ │ -000002d0: 6578 742f 6373 7322 2f3e 0a3c 7363 7269 ext/css"/>........< │ │ │ │ -00000490: 6c69 6e6b 2068 7265 663d 2264 6f78 792e link href="doxy. │ │ │ │ -000004a0: 6373 7322 2072 656c 3d22 7374 796c 6573 css" rel="styles │ │ │ │ -000004b0: 6865 6574 2220 7479 7065 3d22 7465 7874 heet" type="text │ │ │ │ -000004c0: 2f63 7373 222f 3e0a 3c2f 6865 6164 3e0a /css"/>.. │ │ │ │ -000004d0: 3c62 6f64 793e 0a3c 6469 7620 6964 3d22 .
.< │ │ │ │ -00000520: 6469 7620 6964 3d22 7469 746c 6561 7265 div id="titleare │ │ │ │ -00000530: 6122 3e0a 3c74 6162 6c65 2063 656c 6c73 a">.. . . . . . │ │ │ │ -00000620: 203c 2f74 626f 6479 3e0a 3c2f 7461 626c .....< │ │ │ │ -00000790: 7363 7269 7074 2074 7970 653d 2274 6578 script type="tex │ │ │ │ -000007a0: 742f 6a61 7661 7363 7269 7074 2220 7372 t/javascript" sr │ │ │ │ -000007b0: 633d 226d 656e 752e 6a73 223e 3c2f 7363 c="menu.js">..
.
Open │ │ │ │ -00000600: 5375 6264 6976 0a20 2020 3c2f 6469 763e Subdiv.
│ │ │ │ -00000610: 0a20 203c 2f74 643e 0a20 3c2f 7472 3e0a .
. │ │ │ │ +00000560: 0a20 3c74 7220 6964 3d22 7072 6f6a 6563 . . . . .
│ │ │ │ +000005c0: 3c2f 7464 3e0a 2020 3c74 6420 6964 3d22 . │ │ │ │ +000005e0: 2020 3c64 6976 2069 643d 2270 726f 6a65
OpenSubd │ │ │ │ +00000600: 6976 0a20 2020 3c2f 6469 763e 0a20 203c iv.
. < │ │ │ │ +00000610: 2f74 643e 0a20 3c2f 7472 3e0a 203c 2f74 /td>.
.< │ │ │ │ +00000630: 2f64 6976 3e0a 3c21 2d2d 2065 6e64 2068 /div>..< │ │ │ │ +00000650: 212d 2d20 4765 6e65 7261 7465 6420 6279 !-- Generated by │ │ │ │ +00000660: 2044 6f78 7967 656e 2031 2e39 2e38 202d Doxygen 1.9.8 - │ │ │ │ +00000670: 2d3e 0a3c 7363 7269 7074 2074 7970 653d ->.. │ │ │ │ +00000750: 3c73 6372 6970 7420 7479 7065 3d22 7465 ...
...
.. │ │ │ │ +00000d00: 3c21 2d2d 2069 6672 616d 6520 7368 6f77 .< │ │ │ │ +00000d40: 6469 7620 6964 3d22 4d53 6561 7263 6852 div id="MSearchR │ │ │ │ +00000d50: 6573 756c 7473 5769 6e64 6f77 223e 0a3c esultsWindow">.< │ │ │ │ +00000d60: 6469 7620 6964 3d22 4d53 6561 7263 6852 div id="MSearchR │ │ │ │ +00000d70: 6573 756c 7473 223e 0a3c 6469 7620 636c esults">.
. │ │ │ │ +00000da0: 0a3c 6469 7620 6964 3d22 5352 5265 7375 .
.
L │ │ │ │ +00000de0: 6f61 6469 6e67 2e2e 2e3c 2f64 6976 3e0a oading...
. │ │ │ │ +00000df0: 3c64 6976 2063 6c61 7373 3d22 5352 5374 .
No │ │ │ │ +00000e50: 4d61 7463 6865 733c 2f64 6976 3e0a 3c2f Matches
..
..
..
. │ │ │ │ +00000e90: 2020 3c64 6976 2063 6c61 7373 3d22 6865
sc │ │ │ │ +00000ec0: 6865 6d65 2e68 3c2f 6469 763e 3c2f 6469 heme.h
.
.
.Go to the do │ │ │ │ +00000f20: 6375 6d65 6e74 6174 696f 6e20 6f66 2074 cumentation of t │ │ │ │ +00000f30: 6869 7320 6669 6c65 2e3c 2f61 3e3c 6469 his file.
1 │ │ │ │ +00000fa0: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 //< │ │ │ │ +00000fc0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ +00000fe0: 6120 6964 3d22 6c30 3030 3032 2220 6e61 a id="l00002" na │ │ │ │ +00000ff0: 6d65 3d22 6c30 3030 3032 223e 3c2f 613e me="l00002"> │ │ │ │ +00001000: 3c73 7061 6e20 636c 6173 733d 226c 696e 2// Copy │ │ │ │ +00001040: 7269 6768 7420 3230 3134 2044 7265 616d right 2014 Dream │ │ │ │ +00001050: 576f 726b 7320 416e 696d 6174 696f 6e20 Works Animation │ │ │ │ +00001060: 4c4c 432e 3c2f 7370 616e 3e3c 2f64 6976 LLC.
.
3< │ │ │ │ +000010c0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>//
.
< │ │ │ │ +00001120: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00001130: 6e6f 223e 2020 2020 343c 2f73 7061 6e3e no"> 4 │ │ │ │ +00001140: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // Licen │ │ │ │ +00001160: 7365 6420 756e 6465 7220 7468 6520 4170 sed under the Ap │ │ │ │ +00001170: 6163 6865 204c 6963 656e 7365 2c20 5665 ache License, Ve │ │ │ │ +00001180: 7273 696f 6e20 322e 3020 2874 6865 2026 rsion 2.0 (the & │ │ │ │ +00001190: 7175 6f74 3b41 7061 6368 6520 4c69 6365 quot;Apache Lice │ │ │ │ +000011a0: 6e73 6526 7175 6f74 3b29 3c2f 7370 616e nse")
.
│ │ │ │ +00001200: 2020 2020 353c 2f73 7061 6e3e 3c73 7061 5// with the │ │ │ │ +00001230: 666f 6c6c 6f77 696e 6720 6d6f 6469 6669 following modifi │ │ │ │ +00001240: 6361 7469 6f6e 3b20 796f 7520 6d61 7920 cation; you may │ │ │ │ +00001250: 6e6f 7420 7573 6520 7468 6973 2066 696c not use this fil │ │ │ │ +00001260: 6520 6578 6365 7074 2069 6e3c 2f73 7061 e except in
.
6// complian │ │ │ │ +000012f0: 6365 2077 6974 6820 7468 6520 4170 6163 ce with the Apac │ │ │ │ +00001300: 6865 204c 6963 656e 7365 2061 6e64 2074 he License and t │ │ │ │ +00001310: 6865 2066 6f6c 6c6f 7769 6e67 206d 6f64 he following mod │ │ │ │ +00001320: 6966 6963 6174 696f 6e20 746f 2069 743a ification to it: │ │ │ │ +00001330: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00001350: 3c61 2069 643d 226c 3030 3030 3722 206e 7// Sec │ │ │ │ +000013b0: 7469 6f6e 2036 2e20 5472 6164 656d 6172 tion 6. Trademar │ │ │ │ +000013c0: 6b73 2e20 6973 2064 656c 6574 6564 2061 ks. is deleted a │ │ │ │ +000013d0: 6e64 2072 6570 6c61 6365 6420 7769 7468 nd replaced with │ │ │ │ +000013e0: 3a3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c :
.< │ │ │ │ +000013f0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00001400: 3e3c 6120 6964 3d22 6c30 3030 3038 2220 > 8//.
9// 6. Trade │ │ │ │ +000014e0: 6d61 726b 732e 2054 6869 7320 4c69 6365 marks. This Lice │ │ │ │ +000014f0: 6e73 6520 646f 6573 206e 6f74 2067 7261 nse does not gra │ │ │ │ +00001500: 6e74 2070 6572 6d69 7373 696f 6e20 746f nt permission to │ │ │ │ +00001510: 2075 7365 2074 6865 2074 7261 6465 3c2f use the trade
.
< │ │ │ │ +00001560: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00001570: 6e6f 223e 2020 2031 303c 2f73 7061 6e3e no"> 10 │ │ │ │ +00001580: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // na │ │ │ │ +000015a0: 6d65 732c 2074 7261 6465 6d61 726b 732c mes, trademarks, │ │ │ │ +000015b0: 2073 6572 7669 6365 206d 6172 6b73 2c20 service marks, │ │ │ │ +000015c0: 6f72 2070 726f 6475 6374 206e 616d 6573 or product names │ │ │ │ +000015d0: 206f 6620 7468 6520 4c69 6365 6e73 6f72 of the Licensor │ │ │ │ +000015e0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00001600: 3c61 2069 643d 226c 3030 3031 3122 206e 11// │ │ │ │ +00001660: 616e 6420 6974 7320 6166 6669 6c69 6174 and its affiliat │ │ │ │ +00001670: 6573 2c20 6578 6365 7074 2061 7320 7265 es, except as re │ │ │ │ +00001680: 7175 6972 6564 2074 6f20 636f 6d70 6c79 quired to comply │ │ │ │ +00001690: 2077 6974 6820 5365 6374 696f 6e20 3428 with Section 4( │ │ │ │ +000016a0: 6329 206f 663c 2f73 7061 6e3e 3c2f 6469 c) of.
12 │ │ │ │ +00001700: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ +00001720: 2020 2020 2074 6865 204c 6963 656e 7365 the License │ │ │ │ +00001730: 2061 6e64 2074 6f20 7265 7072 6f64 7563 and to reproduc │ │ │ │ +00001740: 6520 7468 6520 636f 6e74 656e 7420 6f66 e the content of │ │ │ │ +00001750: 2074 6865 204e 4f54 4943 4520 6669 6c65 the NOTICE file │ │ │ │ +00001760: 2e3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c .
.< │ │ │ │ +00001770: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00001780: 3e3c 6120 6964 3d22 6c30 3030 3133 2220 > 13//.
14// You may │ │ │ │ +00001860: 6f62 7461 696e 2061 2063 6f70 7920 6f66 obtain a copy of │ │ │ │ +00001870: 2074 6865 2041 7061 6368 6520 4c69 6365 the Apache Lice │ │ │ │ +00001880: 6e73 6520 6174 3c2f 7370 616e 3e3c 2f64 nse at.
1 │ │ │ │ +000018e0: 353c 2f73 7061 6e3e 3c73 7061 6e20 636c 5// │ │ │ │ +00001900: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00001920: 3c61 2069 643d 226c 3030 3031 3622 206e 16
// │ │ │ │ +00001980: 2068 7474 703a 2f2f 7777 772e 6170 6163 http://www.apac │ │ │ │ +00001990: 6865 2e6f 7267 2f6c 6963 656e 7365 732f he.org/licenses/ │ │ │ │ +000019a0: 4c49 4345 4e53 452d 322e 303c 2f73 7061 LICENSE-2.0
.
17//.
18 │ │ │ │ +00001a80: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ +00001aa0: 2020 556e 6c65 7373 2072 6571 7569 7265 Unless require │ │ │ │ +00001ab0: 6420 6279 2061 7070 6c69 6361 626c 6520 d by applicable │ │ │ │ +00001ac0: 6c61 7720 6f72 2061 6772 6565 6420 746f law or agreed to │ │ │ │ +00001ad0: 2069 6e20 7772 6974 696e 672c 2073 6f66 in writing, sof │ │ │ │ +00001ae0: 7477 6172 653c 2f73 7061 6e3e 3c2f 6469 tware.
19 │ │ │ │ +00001b40: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ +00001b60: 2020 6469 7374 7269 6275 7465 6420 756e distributed un │ │ │ │ +00001b70: 6465 7220 7468 6520 4170 6163 6865 204c der the Apache L │ │ │ │ +00001b80: 6963 656e 7365 2077 6974 6820 7468 6520 icense with the │ │ │ │ +00001b90: 6162 6f76 6520 6d6f 6469 6669 6361 7469 above modificati │ │ │ │ +00001ba0: 6f6e 2069 733c 2f73 7061 6e3e 3c2f 6469 on is.
20 │ │ │ │ +00001c00: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ +00001c20: 2020 6469 7374 7269 6275 7465 6420 6f6e distributed on │ │ │ │ +00001c30: 2061 6e20 2671 756f 743b 4153 2049 5326 an "AS IS& │ │ │ │ +00001c40: 7175 6f74 3b20 4241 5349 532c 2057 4954 quot; BASIS, WIT │ │ │ │ +00001c50: 484f 5554 2057 4152 5241 4e54 4945 5320 HOUT WARRANTIES │ │ │ │ +00001c60: 4f52 2043 4f4e 4449 5449 4f4e 5320 4f46 OR CONDITIONS OF │ │ │ │ +00001c70: 2041 4e59 3c2f 7370 616e 3e3c 2f64 6976 ANY
.
21< │ │ │ │ +00001cd0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ +00001cf0: 204b 494e 442c 2065 6974 6865 7220 6578 KIND, either ex │ │ │ │ +00001d00: 7072 6573 7320 6f72 2069 6d70 6c69 6564 press or implied │ │ │ │ +00001d10: 2e20 5365 6520 7468 6520 4170 6163 6865 . See the Apache │ │ │ │ +00001d20: 204c 6963 656e 7365 2066 6f72 2074 6865 License for the │ │ │ │ +00001d30: 2073 7065 6369 6669 633c 2f73 7061 6e3e specific │ │ │ │ +00001d40: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00001d90: 2020 3232 3c2f 7370 616e 3e3c 7370 616e 22// language g │ │ │ │ +00001dc0: 6f76 6572 6e69 6e67 2070 6572 6d69 7373 overning permiss │ │ │ │ +00001dd0: 696f 6e73 2061 6e64 206c 696d 6974 6174 ions and limitat │ │ │ │ +00001de0: 696f 6e73 2075 6e64 6572 2074 6865 2041 ions under the A │ │ │ │ +00001df0: 7061 6368 6520 4c69 6365 6e73 652e 3c2f pache License.
.
< │ │ │ │ +00001e40: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00001e50: 6e6f 223e 2020 2032 333c 2f73 7061 6e3e no"> 23 │ │ │ │ +00001e60: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ +00001e80: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00001ed0: 2032 343c 2f73 7061 6e3e 3c73 7061 6e20 24#ifndef OPE │ │ │ │ +00001f00: 4e53 5542 4449 5633 5f53 4443 5f53 4348 NSUBDIV3_SDC_SCH │ │ │ │ +00001f10: 454d 455f 483c 2f73 7061 6e3e 3c2f 6469 EME_H.
25 │ │ │ │ +00001f70: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 #define OPENSU │ │ │ │ +00001fa0: 4244 4956 335f 5344 435f 5343 4845 4d45 BDIV3_SDC_SCHEME │ │ │ │ +00001fb0: 5f48 3c2f 7370 616e 3e3c 2f64 6976 3e0a _H
. │ │ │ │ +00001fc0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ +00002050: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00002060: 6e6f 223e 2020 2032 373c 2f73 7061 6e3e no"> 27 │ │ │ │ +00002070: 3c73 7061 6e20 636c 6173 733d 2270 7265 #incl │ │ │ │ +00002090: 7564 6520 2671 756f 743b 2e2e 2f76 6572 ude "../ver │ │ │ │ +000020a0: 7369 6f6e 2e68 2671 756f 743b 3c2f 7370 sion.h"
.
28 < │ │ │ │ +00002110: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00002160: 2032 393c 2f73 7061 6e3e 3c73 7061 6e20 29#include &q │ │ │ │ +00002190: 756f 743b 2e2e 2f73 6463 2f74 7970 6573 uot;../sdc/types │ │ │ │ +000021a0: 2e68 2671 756f 743b 3c2f 7370 616e 3e3c .h"< │ │ │ │ +000021b0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00002200: 2033 303c 2f73 7061 6e3e 3c73 7061 6e20 30#include &q │ │ │ │ +00002230: 756f 743b 2e2e 2f73 6463 2f6f 7074 696f uot;../sdc/optio │ │ │ │ +00002240: 6e73 2e68 2671 756f 743b 3c2f 7370 616e ns.h"
.
│ │ │ │ +000022a0: 2020 2033 313c 2f73 7061 6e3e 3c73 7061 31#include │ │ │ │ +000022d0: 2671 756f 743b 2e2e 2f73 6463 2f63 7265 "../sdc/cre │ │ │ │ +000022e0: 6173 652e 6826 7175 6f74 3b3c 2f73 7061 ase.h"
.
32 .
│ │ │ │ +000023a0: 3333 3c2f 7370 616e 3e3c 7370 616e 2063 33#include < │ │ │ │ +000023d0: 3b63 6173 7365 7274 2667 743b 3c2f 7370 ;cassert>
.
34#includ │ │ │ │ +00002460: 6520 266c 743b 6373 7464 6c69 6226 6774 e <cstdlib> │ │ │ │ +00002470: 3b3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c ;
.< │ │ │ │ +00002480: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00002490: 3e3c 6120 6964 3d22 6c30 3030 3335 2220 > 35#i │ │ │ │ +000024f0: 6e63 6c75 6465 2026 6c74 3b76 6563 746f nclude <vecto │ │ │ │ +00002500: 7226 6774 3b3c 2f73 7061 6e3e 3c2f 6469 r>.
36 │ │ │ │ +00002560: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ +00002570: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00002580: 3e3c 6120 6964 3d22 6c30 3030 3337 2220 > 37namespa │ │ │ │ +000025e0: 6365 203c 2f73 7061 6e3e 3c61 2063 6c61 ce OpenSu │ │ │ │ +00002620: 6264 6976 3c2f 613e 207b 3c2f 6469 763e bdiv {
│ │ │ │ +00002630: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00002660: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 38names │ │ │ │ +000026a0: 7061 6365 203c 2f73 7061 6e3e 4f50 454e pace OPEN │ │ │ │ +000026b0: 5355 4244 4956 5f56 4552 5349 4f4e 207b SUBDIV_VERSION { │ │ │ │ +000026c0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00002710: 2020 3339 3c2f 7370 616e 3e20 3c2f 6469 39 .
40 │ │ │ │ +00002770: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 nam │ │ │ │ +00002790: 6573 7061 6365 203c 2f73 7061 6e3e 5364 espace Sd │ │ │ │ +000027a0: 6320 7b3c 2f64 6976 3e0a 3c64 6976 2063 c {
.
41 < │ │ │ │ +00002800: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00002850: 2036 353c 2f73 7061 6e3e 3c73 7061 6e20 65 │ │ │ │ +00002870: 7465 6d70 6c61 7465 3c2f 7370 616e 3e20 template │ │ │ │ +00002880: 266c 743b 5363 6865 6d65 5479 7065 2053 <SchemeType S │ │ │ │ +00002890: 4348 454d 455f 5459 5045 2667 743b 3c2f CHEME_TYPE>.
.
< │ │ │ │ +00002920: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00002930: 6e6f 223e 3c61 2063 6c61 7373 3d22 6c69 no"> 66 │ │ │ │ +00002960: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 cla │ │ │ │ +00002980: 7373 203c 2f73 7061 6e3e 3c61 2063 6c61 ss Scheme │ │ │ │ +000029c0: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
67 .
│ │ │ │ +00002a70: 3638 3c2f 7370 616e 3e3c 7370 616e 2063 68p │ │ │ │ +00002a90: 7562 6c69 633c 2f73 7061 6e3e 3a3c 2f64 ublic:.
6 │ │ │ │ +00002af0: 393c 2f73 7061 6e3e 203c 2f64 6976 3e0a 9
. │ │ │ │ +00002b00: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +00002b30: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> │ │ │ │ +00002b90: 3730 3c2f 613e 3c2f 7370 616e 3e20 2020 70 │ │ │ │ +00002ba0: 203c 6120 636c 6173 733d 2263 6f64 6520 Scheme() : │ │ │ │ +00002c00: 205f 6f70 7469 6f6e 7328 2920 7b20 7d3c _options() { }< │ │ │ │ +00002c10: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00002c60: 2037 313c 2f73 7061 6e3e 203c 2f64 6976 71
.
│ │ │ │ +00002d00: 2020 3732 3c2f 613e 3c2f 7370 616e 3e20 72 │ │ │ │ +00002d10: 2020 203c 6120 636c 6173 733d 2263 6f64 Scheme(< │ │ │ │ +00002d70: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00002d80: 5f63 6c61 7373 2220 6872 6566 3d22 6130 _class" href="a0 │ │ │ │ +00002d90: 3133 3337 2e68 746d 6c22 3e4f 7074 696f 1337.html">Optio │ │ │ │ +00002da0: 6e73 3c2f 613e 203c 7370 616e 2063 6c61 ns con │ │ │ │ +00002dc0: 7374 3c2f 7370 616e 3e26 616d 703b 206f st& o │ │ │ │ +00002dd0: 7074 696f 6e73 2920 3a20 5f6f 7074 696f ptions) : _optio │ │ │ │ +00002de0: 6e73 286f 7074 696f 6e73 2920 7b20 7d3c ns(options) { }< │ │ │ │ +00002df0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00002e40: 2037 333c 2f73 7061 6e3e 203c 2f64 6976 73
.
│ │ │ │ +00002ee0: 2020 3734 3c2f 613e 3c2f 7370 616e 3e20 74 │ │ │ │ +00002ef0: 2020 203c 6120 636c 6173 733d 2263 6f64 O │ │ │ │ +00002f20: 7074 696f 6e73 3c2f 613e 203c 6120 636c ptions GetO │ │ │ │ +00002f80: 7074 696f 6e73 3c2f 613e 2829 3c73 7061 ptions() const │ │ │ │ +00002fb0: 7b20 3c73 7061 6e20 636c 6173 733d 226b { retu │ │ │ │ +00002fd0: 726e 3c2f 7370 616e 3e20 5f6f 7074 696f rn _optio │ │ │ │ +00002fe0: 6e73 3b20 7d3c 2f64 6976 3e0a 3c64 6976 ns; }
.
< │ │ │ │ +00003020: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00003030: 6e6f 223e 3c61 2063 6c61 7373 3d22 6c69 no"> 75 void SetOption │ │ │ │ +00003110: 733c 2f61 3e28 3c73 7061 6e20 636c 6173 s(cons │ │ │ │ +00003130: 743c 2f73 7061 6e3e 203c 6120 636c 6173 t Options │ │ │ │ +00003170: 2661 6d70 3b20 6e65 774f 7074 696f 6e73 & newOptions │ │ │ │ +00003180: 2920 7b20 5f6f 7074 696f 6e73 203d 206e ) { _options = n │ │ │ │ +00003190: 6577 4f70 7469 6f6e 733b 207d 3c2f 6469 ewOptions; }.
76 │ │ │ │ +000031f0: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ +00003200: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00003210: 3e3c 6120 6964 3d22 6c30 3030 3830 2220 > 80 tem │ │ │ │ +00003270: 706c 6174 653c 2f73 7061 6e3e 2026 6c74 plate < │ │ │ │ +00003280: 3b3c 7370 616e 2063 6c61 7373 3d22 6b65 ;typename< │ │ │ │ +000032a0: 2f73 7061 6e3e 2046 4143 452c 203c 7370 /span> FACE, typename MASK>
.
81< │ │ │ │ +00003330: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> void │ │ │ │ +00003360: 3c61 2063 6c61 7373 3d22 636f 6465 2068 ComputeFaceVert │ │ │ │ +000033c0: 6578 4d61 736b 3c2f 613e 2846 4143 4520 exMask(FACE │ │ │ │ +000033d0: 3c73 7061 6e20 636c 6173 733d 226b 6579 const& faceNeig │ │ │ │ +00003400: 6862 6f72 686f 6f64 2c20 4d41 534b 2661 hborhood, MASK&a │ │ │ │ +00003410: 6d70 3b20 6661 6365 5665 7274 6578 4d61 mp; faceVertexMa │ │ │ │ +00003420: 736b 2920 3c73 7061 6e20 636c 6173 733d sk) const< │ │ │ │ +00003440: 2f73 7061 6e3e 3b3c 2f64 6976 3e0a 3c64 /span>;
. │ │ │ │ +00003460: 3c61 2069 643d 226c 3030 3038 3222 206e 82
.
98 │ │ │ │ +00003500: 2020 3c73 7061 6e20 636c 6173 733d 226b template │ │ │ │ +00003520: 3c2f 7370 616e 3e20 266c 743b 3c73 7061 <typename EDGE, ty │ │ │ │ +00003570: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ +00003580: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ +000035a0: 6120 6964 3d22 6c30 3030 3939 2220 6e61 a id="l00099" na │ │ │ │ +000035b0: 6d65 3d22 6c30 3030 3939 223e 3c2f 613e me="l00099"> │ │ │ │ +000035c0: 3c73 7061 6e20 636c 6173 733d 226c 696e 99 v │ │ │ │ +00003600: 6f69 643c 2f73 7061 6e3e 203c 6120 636c oid Comp │ │ │ │ +00003660: 7574 6545 6467 6556 6572 7465 784d 6173 uteEdgeVertexMas │ │ │ │ +00003670: 6b3c 2f61 3e28 4544 4745 203c 7370 616e k(EDGE const&am │ │ │ │ +000036a0: 703b 2065 6467 654e 6569 6768 626f 7268 p; edgeNeighborh │ │ │ │ +000036b0: 6f6f 642c 204d 4153 4b26 616d 703b 2065 ood, MASK& e │ │ │ │ +000036c0: 6467 6556 6572 7465 784d 6173 6b2c 3c2f dgeVertexMask,.
1 │ │ │ │ +00003720: 3030 3c2f 7370 616e 3e20 2020 2020 2020 00 │ │ │ │ +00003730: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00003740: 2020 2020 2020 2020 3c61 2063 6c61 7373 Crea │ │ │ │ +000037a0: 7365 3a3a 5275 6c65 3c2f 613e 2070 6172 se::Rule par │ │ │ │ +000037b0: 656e 7452 756c 6520 3d20 3c61 2063 6c61 entRule = Cre │ │ │ │ +00003830: 6173 653a 3a52 554c 455f 554e 4b4e 4f57 ase::RULE_UNKNOW │ │ │ │ +00003840: 4e3c 2f61 3e2c 3c2f 6469 763e 0a3c 6469 N,
.< │ │ │ │ +00003860: 6120 6964 3d22 6c30 3031 3031 2220 6e61 a id="l00101" na │ │ │ │ +00003870: 6d65 3d22 6c30 3031 3031 223e 3c2f 613e me="l00101"> │ │ │ │ +00003880: 3c73 7061 6e20 636c 6173 733d 226c 696e 101 │ │ │ │ +000038b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +000038c0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Crease::Rule │ │ │ │ +00003920: 3c2f 613e 2063 6869 6c64 5275 6c65 203d childRule = │ │ │ │ +00003930: 203c 6120 636c 6173 733d 2263 6f64 6520 Crease::RULE │ │ │ │ +000039b0: 5f55 4e4b 4e4f 574e 3c2f 613e 2920 3c73 _UNKNOWN) const │ │ │ │ +000039e0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +00003a30: 2020 3130 323c 2f73 7061 6e3e 203c 2f64 102 .
11 │ │ │ │ +00003a90: 323c 2f73 7061 6e3e 2020 2020 3c73 7061 2 template <type │ │ │ │ +00003ae0: 6e61 6d65 3c2f 7370 616e 3e20 5645 5254 name VERT │ │ │ │ +00003af0: 4558 2c20 3c73 7061 6e20 636c 6173 733d EX, typena │ │ │ │ +00003b10: 6d65 3c2f 7370 616e 3e20 4d41 534b 2667 me MASK&g │ │ │ │ +00003b20: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
..
114 │ │ │ │ +00003cd0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00003ce0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00003cf0: 203c 6120 636c 6173 733d 2263 6f64 6520 Crease::Rul │ │ │ │ +00003d50: 653c 2f61 3e20 7061 7265 6e74 5275 6c65 e parentRule │ │ │ │ +00003d60: 203d 203c 6120 636c 6173 733d 2263 6f64 = Crease::RU │ │ │ │ +00003de0: 4c45 5f55 4e4b 4e4f 574e 3c2f 613e 2c3c LE_UNKNOWN,< │ │ │ │ +00003df0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00003e40: 3131 353c 2f73 7061 6e3e 2020 2020 2020 115 │ │ │ │ +00003e50: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00003e60: 2020 2020 2020 2020 2020 2020 2020 3c61 Crease::Rule childRule = < │ │ │ │ +00003ee0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00003ef0: 5f65 6e75 6d76 616c 7565 2220 6872 6566 _enumvalue" href │ │ │ │ +00003f00: 3d22 6130 3133 3333 2e68 746d 6c23 6131 ="a01333.html#a1 │ │ │ │ +00003f10: 3166 6364 3531 6566 3836 3131 3866 3635 1fcd51ef86118f65 │ │ │ │ +00003f20: 6536 3033 6331 3437 3433 3737 6137 3861 e603c1474377a78a │ │ │ │ +00003f30: 6232 3939 6165 6662 3236 3031 3361 3739 b299aefb26013a79 │ │ │ │ +00003f40: 6435 3231 3931 6137 3838 3766 6561 3533 d52191a7887fea53 │ │ │ │ +00003f50: 223e 4372 6561 7365 3a3a 5255 4c45 5f55 ">Crease::RULE_U │ │ │ │ +00003f60: 4e4b 4e4f 574e 3c2f 613e 2920 3c73 7061 NKNOWN) const;< │ │ │ │ +00003f90: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00003fe0: 3131 363c 2f73 7061 6e3e 203c 2f64 6976 116
.
141< │ │ │ │ +00004040: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ +00004060: 7465 6d70 6c61 7465 3c2f 7370 616e 3e20 template │ │ │ │ +00004070: 266c 743b 3c73 7061 6e20 636c 6173 733d <typena │ │ │ │ +00004090: 6d65 3c2f 7370 616e 3e20 5645 5254 4558 me VERTEX │ │ │ │ +000040a0: 2c20 3c73 7061 6e20 636c 6173 733d 226b , typename │ │ │ │ +000040c0: 3c2f 7370 616e 3e20 4d41 534b 2667 743b MASK> │ │ │ │ +000040d0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00004120: 2031 3432 3c2f 7370 616e 3e20 2020 203c 142 < │ │ │ │ +00004130: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00004140: 6f72 6474 7970 6522 3e76 6f69 643c 2f73 ordtype">void ComputeVer │ │ │ │ +000041b0: 7465 784c 696d 6974 4d61 736b 3c2f 613e texLimitMask │ │ │ │ +000041c0: 2856 4552 5445 5820 3c73 7061 6e20 636c (VERTEX co │ │ │ │ +000041e0: 6e73 743c 2f73 7061 6e3e 2661 6d70 3b20 nst& │ │ │ │ +000041f0: 7665 7274 6578 4e65 6967 6862 6f72 686f vertexNeighborho │ │ │ │ +00004200: 6f64 2c20 4d41 534b 2661 6d70 3b20 706f od, MASK& po │ │ │ │ +00004210: 7369 7469 6f6e 4d61 736b 2c3c 2f64 6976 sitionMask,
.
143< │ │ │ │ +00004270: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ +00004280: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00004290: 2020 2020 2020 3c61 2063 6c61 7373 3d22 Crease │ │ │ │ +000042f0: 3a3a 5275 6c65 3c2f 613e 2076 6572 7465 ::Rule verte │ │ │ │ +00004300: 7852 756c 6529 203c 7370 616e 2063 6c61 xRule) con │ │ │ │ +00004320: 7374 3c2f 7370 616e 3e3b 3c2f 6469 763e st;
│ │ │ │ +00004330: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ +000043a0: 6120 6964 3d22 6c30 3031 3435 2220 6e61 a id="l00145" na │ │ │ │ +000043b0: 6d65 3d22 6c30 3031 3435 223e 3c2f 613e me="l00145"> │ │ │ │ +000043c0: 3c73 7061 6e20 636c 6173 733d 226c 696e 145 templ │ │ │ │ +00004400: 6174 653c 2f73 7061 6e3e 2026 6c74 3b3c ate << │ │ │ │ +00004410: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00004420: 6f72 6422 3e74 7970 656e 616d 653c 2f73 ord">typename VERTEX, typename MASK>
.
146< │ │ │ │ +000044c0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> void │ │ │ │ +000044f0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 ComputeVertexLi │ │ │ │ +00004550: 6d69 744d 6173 6b3c 2f61 3e28 5645 5254 mitMask(VERT │ │ │ │ +00004560: 4558 203c 7370 616e 2063 6c61 7373 3d22 EX const& verte │ │ │ │ +00004590: 784e 6569 6768 626f 7268 6f6f 642c 204d xNeighborhood, M │ │ │ │ +000045a0: 4153 4b26 616d 703b 2070 6f73 6974 696f ASK& positio │ │ │ │ +000045b0: 6e4d 6173 6b2c 3c2f 6469 763e 0a3c 6469 nMask,
.< │ │ │ │ +000045d0: 6120 6964 3d22 6c30 3031 3437 2220 6e61 a id="l00147" na │ │ │ │ +000045e0: 6d65 3d22 6c30 3031 3437 223e 3c2f 613e me="l00147"> │ │ │ │ +000045f0: 3c73 7061 6e20 636c 6173 733d 226c 696e 147 │ │ │ │ +00004620: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00004630: 204d 4153 4b26 616d 703b 2074 616e 6765 MASK& tange │ │ │ │ +00004640: 6e74 314d 6173 6b2c 204d 4153 4b26 616d nt1Mask, MASK&am │ │ │ │ +00004650: 703b 2074 616e 6765 6e74 324d 6173 6b2c p; tangent2Mask, │ │ │ │ +00004660: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +000046b0: 2031 3438 3c2f 7370 616e 3e20 2020 2020 148 │ │ │ │ +000046c0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +000046d0: 2020 2020 2020 2020 2020 203c 6120 636c C │ │ │ │ +00004730: 7265 6173 653a 3a52 756c 653c 2f61 3e20 rease::Rule │ │ │ │ +00004740: 7665 7274 6578 5275 6c65 2920 3c73 7061 vertexRule) const;< │ │ │ │ +00004770: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +000047c0: 3134 393c 2f73 7061 6e3e 203c 2f64 6976 149
.
150< │ │ │ │ +00004820: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ +00004840: 2f2f 3c2f 7370 616e 3e3c 2f64 6976 3e0a //
. │ │ │ │ +00004850: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
│ │ │ │ +00004950: 2020 3135 323c 2f73 7061 6e3e 2020 2020 152 │ │ │ │ +00004960: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ +00004980: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>..< │ │ │ │ +00004b20: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00004b30: 3e3c 6120 6964 3d22 6c30 3031 3534 2220 > 15 │ │ │ │ +00004bb0: 343c 2f61 3e3c 2f73 7061 6e3e 2020 2020 4 │ │ │ │ +00004bc0: 3c73 7061 6e20 636c 6173 733d 226b 6579 static in │ │ │ │ +00004c00: 743c 2f73 7061 6e3e 2020 203c 6120 636c t GetR │ │ │ │ +00004c60: 6567 756c 6172 4661 6365 5369 7a65 3c2f egularFaceSize();
.. │ │ │ │ +00004df0: 3c61 2069 643d 226c 3030 3135 3622 206e 156 │ │ │ │ +00004e70: 3c2f 613e 3c2f 7370 616e 3e20 2020 203c < │ │ │ │ +00004e80: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00004e90: 6f72 6422 3e73 7461 7469 633c 2f73 7061 ord">static int │ │ │ │ +00004ec0: 3c2f 7370 616e 3e20 2020 3c61 2063 6c61 GetLo │ │ │ │ +00004f20: 6361 6c4e 6569 6768 626f 7268 6f6f 6453 calNeighborhoodS │ │ │ │ +00004f30: 697a 653c 2f61 3e28 293b 3c2f 6469 763e ize();
│ │ │ │ +00004f40: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ +00004fb0: 6120 6964 3d22 6c30 3031 3538 2220 6e61 a id="l00158" na │ │ │ │ +00004fc0: 6d65 3d22 6c30 3031 3538 223e 3c2f 613e me="l00158"> │ │ │ │ +00004fd0: 3c73 7061 6e20 636c 6173 733d 226c 696e 158protected │ │ │ │ +00005010: 3c2f 7370 616e 3e3a 3c2f 6469 763e 0a3c :
.< │ │ │ │ +00005020: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00005030: 3e3c 6120 6964 3d22 6c30 3031 3539 2220 > 159
.
160 │ │ │ │ +000050d0: 2020 203c 7370 616e 2063 6c61 7373 3d22 //
.
161 │ │ │ │ +00005150: 203c 7370 616e 2063 6c61 7373 3d22 636f // Suppo │ │ │ │ +00005170: 7274 696e 6720 696e 7465 726e 616c 206d rting internal m │ │ │ │ +00005180: 6574 686f 6473 202d 2d20 6f70 7469 6f6e ethods -- option │ │ │ │ +00005190: 616c 6c79 2069 6d70 6c65 6d65 6e74 6564 ally implemented │ │ │ │ +000051a0: 2c20 6465 7065 6e64 696e 6720 6f6e 2073 , depending on s │ │ │ │ +000051b0: 7065 6369 616c 697a 6174 696f 6e3a 3c2f pecialization:
.
< │ │ │ │ +00005200: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00005210: 6e6f 223e 2020 3136 323c 2f73 7061 6e3e no"> 162 │ │ │ │ +00005220: 2020 2020 3c73 7061 6e20 636c 6173 733d //
.
163 < │ │ │ │ +000052a0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +000052f0: 3136 343c 2f73 7061 6e3e 2020 2020 3c73 164 // Subdivis │ │ │ │ +00005320: 696f 6e2f 7265 6669 6e65 6d65 6e74 206d ion/refinement m │ │ │ │ +00005330: 6173 6b73 202d 2d20 7477 6f20 666f 7220 asks -- two for │ │ │ │ +00005340: 6564 6765 2d76 6572 7469 6365 7320 616e edge-vertices an │ │ │ │ +00005350: 6420 7468 7265 6520 666f 7220 7665 7274 d three for vert │ │ │ │ +00005360: 6578 2d76 6572 7469 6365 733a 3c2f 7370 ex-vertices:
.
165 │ │ │ │ +000053d0: 2020 3c73 7061 6e20 636c 6173 733d 2263 //
.
│ │ │ │ +00005440: 2020 3136 363c 2f73 7061 6e3e 2020 2020 166 │ │ │ │ +00005450: 3c73 7061 6e20 636c 6173 733d 226b 6579 template < │ │ │ │ +00005490: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ +000054a0: 4544 4745 2c20 3c73 7061 6e20 636c 6173 EDGE, type │ │ │ │ +000054c0: 6e61 6d65 3c2f 7370 616e 3e20 4d41 534b name MASK │ │ │ │ +000054d0: 2667 743b 3c2f 6469 763e 0a3c 6469 7620 >
.
167 │ │ │ │ +00005530: 2020 203c 7370 616e 2063 6c61 7373 3d22 voi │ │ │ │ +00005550: 643c 2f73 7061 6e3e 203c 6120 636c 6173 d assign │ │ │ │ +000055b0: 4372 6561 7365 4d61 736b 466f 7245 6467 CreaseMaskForEdg │ │ │ │ +000055c0: 653c 2f61 3e28 4544 4745 203c 7370 616e e(EDGE const&am │ │ │ │ +000055f0: 703b 2065 6467 652c 204d 4153 4b26 616d p; edge, MASK&am │ │ │ │ +00005600: 703b 206d 6173 6b29 203c 7370 616e 2063 p; mask) c │ │ │ │ +00005620: 6f6e 7374 3c2f 7370 616e 3e3b 3c2f 6469 onst;.
168 │ │ │ │ +00005680: 3c2f 7370 616e 3e20 2020 203c 7370 616e template │ │ │ │ +000056b0: 2026 6c74 3b3c 7370 616e 2063 6c61 7373 <typen │ │ │ │ +000056d0: 616d 653c 2f73 7061 6e3e 2045 4447 452c ame EDGE, │ │ │ │ +000056e0: 203c 7370 616e 2063 6c61 7373 3d22 6b65 typename< │ │ │ │ +00005700: 2f73 7061 6e3e 204d 4153 4b26 6774 3b3c /span> MASK>< │ │ │ │ +00005710: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
169 void as │ │ │ │ +00005830: 7369 676e 536d 6f6f 7468 4d61 736b 466f signSmoothMaskFo │ │ │ │ +00005840: 7245 6467 653c 2f61 3e28 4544 4745 203c rEdge(EDGE < │ │ │ │ +00005850: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00005860: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const& edge, MAS │ │ │ │ +00005880: 4b26 616d 703b 206d 6173 6b29 203c 7370 K& mask) const; │ │ │ │ +000058b0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00005900: 2031 3730 3c2f 7370 616e 3e20 3c2f 6469 170 .
171 │ │ │ │ +00005960: 3c2f 7370 616e 3e20 2020 203c 7370 616e template │ │ │ │ +00005990: 2026 6c74 3b3c 7370 616e 2063 6c61 7373 <typen │ │ │ │ +000059b0: 616d 653c 2f73 7061 6e3e 2056 4552 5445 ame VERTE │ │ │ │ +000059c0: 582c 203c 7370 616e 2063 6c61 7373 3d22 X, typenam │ │ │ │ +000059e0: 653c 2f73 7061 6e3e 204d 4153 4b26 6774 e MASK> │ │ │ │ +000059f0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +00005a40: 2020 3137 323c 2f73 7061 6e3e 2020 2020 172 │ │ │ │ +00005a50: 3c73 7061 6e20 636c 6173 733d 226b 6579 void assignCor │ │ │ │ +00005ad0: 6e65 724d 6173 6b46 6f72 5665 7274 6578 nerMaskForVertex │ │ │ │ +00005ae0: 3c2f 613e 2856 4552 5445 5820 3c73 7061 (VERTEX const&a │ │ │ │ +00005b10: 6d70 3b20 6564 6765 2c20 4d41 534b 2661 mp; edge, MASK&a │ │ │ │ +00005b20: 6d70 3b20 6d61 736b 2920 3c73 7061 6e20 mp; mask) │ │ │ │ +00005b40: 636f 6e73 743c 2f73 7061 6e3e 3b3c 2f64 const;.
17 │ │ │ │ +00005ba0: 333c 2f73 7061 6e3e 2020 2020 3c73 7061 3 template <type │ │ │ │ +00005bf0: 6e61 6d65 3c2f 7370 616e 3e20 5645 5254 name VERT │ │ │ │ +00005c00: 4558 2c20 3c73 7061 6e20 636c 6173 733d EX, typena │ │ │ │ +00005c20: 6d65 3c2f 7370 616e 3e20 4d41 534b 2667 me MASK&g │ │ │ │ +00005c30: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
174< │ │ │ │ +00005cd0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> void │ │ │ │ +00005d00: 3c61 2063 6c61 7373 3d22 636f 6465 2068 assignCreaseMas │ │ │ │ +00005d60: 6b46 6f72 5665 7274 6578 3c2f 613e 2856 kForVertex(V │ │ │ │ +00005d70: 4552 5445 5820 3c73 7061 6e20 636c 6173 ERTEX cons │ │ │ │ +00005d90: 743c 2f73 7061 6e3e 2661 6d70 3b20 6564 t& ed │ │ │ │ +00005da0: 6765 2c20 4d41 534b 2661 6d70 3b20 6d61 ge, MASK& ma │ │ │ │ +00005db0: 736b 2c20 3c73 7061 6e20 636c 6173 733d sk, in │ │ │ │ +00005dd0: 743c 2f73 7061 6e3e 203c 7370 616e 2063 t c │ │ │ │ +00005df0: 6f6e 7374 3c2f 7370 616e 3e20 6372 6561 onst crea │ │ │ │ +00005e00: 7365 456e 6473 5b32 5d29 203c 7370 616e seEnds[2]) const;.
1 │ │ │ │ +00005e80: 3735 3c2f 7370 616e 3e20 2020 203c 7370 75 template <typ │ │ │ │ +00005ed0: 656e 616d 653c 2f73 7061 6e3e 2056 4552 ename VER │ │ │ │ +00005ee0: 5445 582c 203c 7370 616e 2063 6c61 7373 TEX, typen │ │ │ │ +00005f00: 616d 653c 2f73 7061 6e3e 204d 4153 4b26 ame MASK& │ │ │ │ +00005f10: 6774 3b3c 2f64 6976 3e0a 3c64 6976 2063 gt;
.
176 │ │ │ │ +00005fb0: 3c2f 7370 616e 3e20 2020 203c 7370 616e void │ │ │ │ +00005fe0: 203c 6120 636c 6173 733d 2263 6f64 6520 assignSmoothMa │ │ │ │ +00006040: 736b 466f 7256 6572 7465 783c 2f61 3e28 skForVertex( │ │ │ │ +00006050: 5645 5254 4558 203c 7370 616e 2063 6c61 VERTEX con │ │ │ │ +00006070: 7374 3c2f 7370 616e 3e26 616d 703b 2065 st& e │ │ │ │ +00006080: 6467 652c 204d 4153 4b26 616d 703b 206d dge, MASK& m │ │ │ │ +00006090: 6173 6b29 203c 7370 616e 2063 6c61 7373 ask) const │ │ │ │ +000060b0: 3c2f 7370 616e 3e3b 3c2f 6469 763e 0a3c ;
.< │ │ │ │ +000060c0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +000060d0: 3e3c 6120 6964 3d22 6c30 3031 3737 2220 > 177
.
178 │ │ │ │ +00006170: 2020 203c 7370 616e 2063 6c61 7373 3d22 //
.
179 │ │ │ │ +000061f0: 203c 7370 616e 2063 6c61 7373 3d22 636f // Limit │ │ │ │ +00006210: 206d 6173 6b73 2066 6f72 2070 6f73 6974 masks for posit │ │ │ │ +00006220: 696f 6e20 616e 6420 7461 6e67 656e 7473 ion and tangents │ │ │ │ +00006230: 2061 7420 7665 7274 6963 6573 202d 2d20 at vertices -- │ │ │ │ +00006240: 7468 7265 6520 6361 7365 7320 666f 7220 three cases for │ │ │ │ +00006250: 6561 6368 3a3c 2f73 7061 6e3e 3c2f 6469 each:.
180 │ │ │ │ +000062b0: 3c2f 7370 616e 3e20 2020 203c 7370 616e //
│ │ │ │ +000062e0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00006310: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 181 t │ │ │ │ +00006350: 656d 706c 6174 653c 2f73 7061 6e3e 2026 emplate & │ │ │ │ +00006360: 6c74 3b3c 7370 616e 2063 6c61 7373 3d22 lt;typenam │ │ │ │ +00006380: 653c 2f73 7061 6e3e 2056 4552 5445 582c e VERTEX, │ │ │ │ +00006390: 203c 7370 616e 2063 6c61 7373 3d22 6b65 typename< │ │ │ │ +000063b0: 2f73 7061 6e3e 204d 4153 4b26 6774 3b3c /span> MASK>< │ │ │ │ +000063c0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
182 void as │ │ │ │ +000064e0: 7369 676e 436f 726e 6572 4c69 6d69 744d signCornerLimitM │ │ │ │ +000064f0: 6173 6b3c 2f61 3e28 5645 5254 4558 203c ask(VERTEX < │ │ │ │ +00006500: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00006510: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const& vertex, M │ │ │ │ +00006530: 4153 4b26 616d 703b 2070 6f73 2920 3c73 ASK& pos) const │ │ │ │ +00006560: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +000065b0: 2020 3138 333c 2f73 7061 6e3e 2020 2020 183 │ │ │ │ +000065c0: 3c73 7061 6e20 636c 6173 733d 226b 6579 template < │ │ │ │ +00006600: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ +00006610: 5645 5254 4558 2c20 3c73 7061 6e20 636c VERTEX, ty │ │ │ │ +00006630: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ +00006640: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ +00006660: 6120 6964 3d22 6c30 3031 3834 2220 6e61 a id="l00184" na │ │ │ │ +00006670: 6d65 3d22 6c30 3031 3834 223e 3c2f 613e me="l00184"> │ │ │ │ +00006680: 3c73 7061 6e20 636c 6173 733d 226c 696e 184< │ │ │ │ +000066e0: 2f61 3e3c 2f73 7061 6e3e 2020 2020 3c73 /a> void assignCreas │ │ │ │ +00006770: 654c 696d 6974 4d61 736b 3c2f 613e 2856 eLimitMask(V │ │ │ │ +00006780: 4552 5445 5820 3c73 7061 6e20 636c 6173 ERTEX cons │ │ │ │ +000067a0: 743c 2f73 7061 6e3e 2661 6d70 3b20 7665 t& ve │ │ │ │ +000067b0: 7274 6578 2c20 4d41 534b 2661 6d70 3b20 rtex, MASK& │ │ │ │ +000067c0: 706f 732c 203c 7370 616e 2063 6c61 7373 pos, i │ │ │ │ +000067e0: 6e74 3c2f 7370 616e 3e20 3c73 7061 6e20 nt │ │ │ │ +00006800: 636f 6e73 743c 2f73 7061 6e3e 2063 7265 const cre │ │ │ │ +00006810: 6173 6545 6e64 735b 325d 2920 3c73 7061 aseEnds[2]) const
;< │ │ │ │ +00006840: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00006890: 3138 353c 2f73 7061 6e3e 2020 2020 3c73 185 template <ty │ │ │ │ +000068e0: 7065 6e61 6d65 3c2f 7370 616e 3e20 5645 pename VE │ │ │ │ +000068f0: 5254 4558 2c20 3c73 7061 6e20 636c 6173 RTEX, type │ │ │ │ +00006910: 6e61 6d65 3c2f 7370 616e 3e20 4d41 534b name MASK │ │ │ │ +00006920: 2667 743b 3c2f 6469 763e 0a3c 6469 7620 >
.
186 void assignSmoothL │ │ │ │ +00006a50: 696d 6974 4d61 736b 3c2f 613e 2856 4552 imitMask(VER │ │ │ │ +00006a60: 5445 5820 3c73 7061 6e20 636c 6173 733d TEX const< │ │ │ │ +00006a80: 2f73 7061 6e3e 2661 6d70 3b20 7665 7274 /span>& vert │ │ │ │ +00006a90: 6578 2c20 4d41 534b 2661 6d70 3b20 706f ex, MASK& po │ │ │ │ +00006aa0: 7329 203c 7370 616e 2063 6c61 7373 3d22 s) const;
.< │ │ │ │ +00006ae0: 6120 6964 3d22 6c30 3031 3837 2220 6e61 a id="l00187" na │ │ │ │ +00006af0: 6d65 3d22 6c30 3031 3837 223e 3c2f 613e me="l00187"> │ │ │ │ +00006b00: 3c73 7061 6e20 636c 6173 733d 226c 696e 187
.
188 │ │ │ │ +00006b80: 203c 7370 616e 2063 6c61 7373 3d22 6b65 template< │ │ │ │ +00006ba0: 2f73 7061 6e3e 2026 6c74 3b3c 7370 616e /span> <typename │ │ │ │ +00006bd0: 2056 4552 5445 582c 203c 7370 616e 2063 VERTEX, t │ │ │ │ +00006bf0: 7970 656e 616d 653c 2f73 7061 6e3e 204d ypename M │ │ │ │ +00006c00: 4153 4b26 6774 3b3c 2f64 6976 3e0a 3c64 ASK>
. │ │ │ │ +00006c20: 3c61 2069 643d 226c 3030 3138 3922 206e 189 │ │ │ │ +00006ca0: 3c2f 613e 3c2f 7370 616e 3e20 2020 203c < │ │ │ │ +00006cb0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00006cc0: 6f72 6474 7970 6522 3e76 6f69 643c 2f73 ordtype">void
assignCorn │ │ │ │ +00006d30: 6572 4c69 6d69 7454 616e 6765 6e74 4d61 erLimitTangentMa │ │ │ │ +00006d40: 736b 733c 2f61 3e28 5645 5254 4558 203c sks(VERTEX < │ │ │ │ +00006d50: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00006d60: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const& vertex, M │ │ │ │ +00006d80: 4153 4b26 616d 703b 2074 616e 312c 204d ASK& tan1, M │ │ │ │ +00006d90: 4153 4b26 616d 703b 2074 616e 3229 203c ASK& tan2) < │ │ │ │ +00006da0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00006db0: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const;
.
190 │ │ │ │ +00006e20: 203c 7370 616e 2063 6c61 7373 3d22 6b65 template< │ │ │ │ +00006e40: 2f73 7061 6e3e 2026 6c74 3b3c 7370 616e /span> <typename │ │ │ │ +00006e70: 2056 4552 5445 582c 203c 7370 616e 2063 VERTEX, t │ │ │ │ +00006e90: 7970 656e 616d 653c 2f73 7061 6e3e 204d ypename M │ │ │ │ +00006ea0: 4153 4b26 6774 3b3c 2f64 6976 3e0a 3c64 ASK>
. │ │ │ │ +00006ec0: 3c61 2069 643d 226c 3030 3139 3122 206e 191 │ │ │ │ +00006f40: 3c2f 613e 3c2f 7370 616e 3e20 2020 203c < │ │ │ │ +00006f50: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00006f60: 6f72 6474 7970 6522 3e76 6f69 643c 2f73 ordtype">void
assignCrea │ │ │ │ +00006fd0: 7365 4c69 6d69 7454 616e 6765 6e74 4d61 seLimitTangentMa │ │ │ │ +00006fe0: 736b 733c 2f61 3e28 5645 5254 4558 203c sks(VERTEX < │ │ │ │ +00006ff0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00007000: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const& vertex, M │ │ │ │ +00007020: 4153 4b26 616d 703b 2074 616e 312c 204d ASK& tan1, M │ │ │ │ +00007030: 4153 4b26 616d 703b 2074 616e 322c 203c ASK& tan2, < │ │ │ │ +00007040: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00007050: 6f72 6474 7970 6522 3e69 6e74 3c2f 7370 ordtype">int const< │ │ │ │ +00007080: 2f73 7061 6e3e 2063 7265 6173 6545 6e64 /span> creaseEnd │ │ │ │ +00007090: 735b 325d 2920 3c73 7061 6e20 636c 6173 s[2]) cons │ │ │ │ +000070b0: 743c 2f73 7061 6e3e 3b3c 2f64 6976 3e0a t;
. │ │ │ │ +000070c0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +000070f0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 192 te │ │ │ │ +00007130: 6d70 6c61 7465 3c2f 7370 616e 3e20 266c mplate &l │ │ │ │ +00007140: 743b 3c73 7061 6e20 636c 6173 733d 226b t;typename │ │ │ │ +00007160: 3c2f 7370 616e 3e20 5645 5254 4558 2c20 VERTEX, │ │ │ │ +00007170: 3c73 7061 6e20 636c 6173 733d 226b 6579 typename MASK>.
193 │ │ │ │ +00007260: 766f 6964 3c2f 7370 616e 3e20 3c61 2063 void ass │ │ │ │ +000072c0: 6967 6e53 6d6f 6f74 684c 696d 6974 5461 ignSmoothLimitTa │ │ │ │ +000072d0: 6e67 656e 744d 6173 6b73 3c2f 613e 2856 ngentMasks(V │ │ │ │ +000072e0: 4552 5445 5820 3c73 7061 6e20 636c 6173 ERTEX cons │ │ │ │ +00007300: 743c 2f73 7061 6e3e 2661 6d70 3b20 7665 t& ve │ │ │ │ +00007310: 7274 6578 2c20 4d41 534b 2661 6d70 3b20 rtex, MASK& │ │ │ │ +00007320: 7461 6e31 2c20 4d41 534b 2661 6d70 3b20 tan1, MASK& │ │ │ │ +00007330: 7461 6e32 2920 3c73 7061 6e20 636c 6173 tan2) cons │ │ │ │ +00007350: 743c 2f73 7061 6e3e 3b3c 2f64 6976 3e0a t;
. │ │ │ │ +00007360: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ +000073f0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00007400: 6e6f 223e 2020 3139 353c 2f73 7061 6e3e no"> 195 │ │ │ │ +00007410: 3c73 7061 6e20 636c 6173 733d 226b 6579 private:
.
< │ │ │ │ +00007470: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00007480: 6e6f 223e 2020 3139 363c 2f73 7061 6e3e no"> 196 │ │ │ │ +00007490: 2020 2020 3c61 2063 6c61 7373 3d22 636f │ │ │ │ +000074c0: 4f70 7469 6f6e 733c 2f61 3e20 5f6f 7074 Options _opt │ │ │ │ +000074d0: 696f 6e73 3b3c 2f64 6976 3e0a 3c64 6976 ions;
.
< │ │ │ │ +00007510: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00007520: 6e6f 223e 2020 3139 373c 2f73 7061 6e3e no"> 197 │ │ │ │ +00007530: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ +00007580: 2020 3139 383c 2f73 7061 6e3e 3c73 7061 198protected:
.
199 < │ │ │ │ +00007610: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00007660: 3230 303c 2f73 7061 6e3e 2020 2020 3c73 200 //.
20 │ │ │ │ +000076e0: 313c 2f73 7061 6e3e 2020 2020 3c73 7061 1 // Internal i │ │ │ │ +00007710: 6d70 6c65 6d65 6e74 6174 696f 6e20 7375 mplementation su │ │ │ │ +00007720: 7070 6f72 743a 3c2f 7370 616e 3e3c 2f64 pport:.
20 │ │ │ │ +00007780: 323c 2f73 7061 6e3e 2020 2020 3c73 7061 2 //
.
203< │ │ │ │ +00007800: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ +00007820: 2f2f 2020 5765 206e 6565 6420 6120 6c6f // We need a lo │ │ │ │ +00007830: 6361 6c20 2671 756f 743b 6d61 736b 2671 cal "mask&q │ │ │ │ +00007840: 756f 743b 2063 6c61 7373 2074 6f20 6265 uot; class to be │ │ │ │ +00007850: 2064 6563 6c61 7265 6420 6c6f 6361 6c6c declared locall │ │ │ │ +00007860: 7920 7769 7468 696e 2074 6865 2076 6572 y within the ver │ │ │ │ +00007870: 7465 782d 7665 7274 6578 206d 6173 6b20 tex-vertex mask │ │ │ │ +00007880: 7175 6572 793c 2f73 7061 6e3e 3c2f 6469 query.
204 │ │ │ │ +000078e0: 3c2f 7370 616e 3e20 2020 203c 7370 616e // to hold one │ │ │ │ +00007910: 206f 6620 7468 6520 7477 6f20 706f 7373 of the two poss │ │ │ │ +00007920: 6962 6c65 206d 6173 6b73 2072 6571 7569 ible masks requi │ │ │ │ +00007930: 7265 6420 616e 6420 746f 2063 6f6d 6269 red and to combi │ │ │ │ +00007940: 6e65 2074 6865 206c 6f63 616c 206d 6173 ne the local mas │ │ │ │ +00007950: 6b20 7769 7468 2074 6865 206d 6173 6b3c k with the mask< │ │ │ │ +00007960: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ +00007980: 6120 6964 3d22 6c30 3032 3035 2220 6e61 a id="l00205" na │ │ │ │ +00007990: 6d65 3d22 6c30 3032 3035 223e 3c2f 613e me="l00205"> │ │ │ │ +000079a0: 3c73 7061 6e20 636c 6173 733d 226c 696e 205 // t │ │ │ │ +000079e0: 6865 2063 616c 6c65 7220 7072 6f76 6964 he caller provid │ │ │ │ +000079f0: 6573 2e20 2049 7420 6861 7320 6265 656e es. It has been │ │ │ │ +00007a00: 2070 6172 616d 6574 6572 697a 6564 2062 parameterized b │ │ │ │ +00007a10: 7920 266c 743b 5745 4947 4854 2667 743b y <WEIGHT> │ │ │ │ +00007a20: 2073 6f20 7468 6174 2061 2076 6572 7369 so that a versi │ │ │ │ +00007a30: 6f6e 2063 6f6d 7061 7469 626c 653c 2f73 on compatible
.
206 │ │ │ │ +00007aa0: 2020 203c 7370 616e 2063 6c61 7373 3d22 // wit │ │ │ │ +00007ac0: 6820 7468 6520 6361 6c6c 6572 2623 3339 h the caller' │ │ │ │ +00007ad0: 3b73 206d 6173 6b20 636c 6173 7320 6973 ;s mask class is │ │ │ │ +00007ae0: 2063 7265 6174 6564 2e3c 2f73 7061 6e3e created. │ │ │ │ +00007af0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00007b40: 2032 3037 3c2f 7370 616e 3e20 2020 203c 207 < │ │ │ │ +00007b50: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00007b60: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
2 │ │ │ │ +00007bc0: 3038 3c2f 7370 616e 3e20 2020 203c 7370 08 template <typ │ │ │ │ +00007c10: 656e 616d 653c 2f73 7061 6e3e 2057 4549 ename WEI │ │ │ │ +00007c20: 4748 5426 6774 3b3c 2f64 6976 3e0a 3c64 GHT>
..
│ │ │ │ +00007ce0: 2020 3230 393c 2f61 3e3c 2f73 7061 6e3e 209 │ │ │ │ +00007cf0: 2020 2020 3c73 7061 6e20 636c 6173 733d class │ │ │ │ +00007d10: 3c2f 7370 616e 3e3c 6120 636c 6173 733d LocalMask │ │ │ │ +00007d50: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
210 .
2 │ │ │ │ +00007e00: 3131 3c2f 7370 616e 3e20 2020 203c 7370 11 public │ │ │ │ +00007e30: 3a3c 2f64 6976 3e0a 3c64 6976 2063 6c61 :
.
│ │ │ │ +00007e80: 3c61 2063 6c61 7373 3d22 6c69 6e65 2220 212 typedef WEIGHT Weight< │ │ │ │ +00007f60: 2f61 3e3b 3c2f 6469 763e 0a3c 6469 7620 /a>;
.
213 │ │ │ │ +00007fc0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00008010: 2032 3134 3c2f 7370 616e 3e20 2020 203c 214 < │ │ │ │ +00008020: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00008030: 6f72 6422 3e70 7562 6c69 633c 2f73 7061 ord">public:
.
215 │ │ │ │ +000080e0: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ +000080f0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00008100: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ +00008110: 2261 3031 3334 352e 6874 6d6c 2361 6334 "a01345.html#ac4 │ │ │ │ +00008120: 6234 6335 3566 6232 3464 6139 3566 3135 b4c55fb24da95f15 │ │ │ │ +00008130: 3466 3461 3966 3531 3764 6230 3739 223e 4f4a9f517db079"> │ │ │ │ +00008140: 4c6f 6361 6c4d 6173 6b3c 2f61 3e28 3c61 LocalMask(We │ │ │ │ +000081a0: 6967 6874 3c2f 613e 2a20 762c 203c 6120 ight* v, Wei │ │ │ │ +00008200: 6768 743c 2f61 3e2a 2065 2c20 3c61 2063 ght* e, Weig │ │ │ │ +00008260: 6874 3c2f 613e 2a20 6629 203a 205f 7657 ht* f) : _vW │ │ │ │ +00008270: 6569 6768 7473 2876 292c 205f 6557 6569 eights(v), _eWei │ │ │ │ +00008280: 6768 7473 2865 292c 205f 6657 6569 6768 ghts(e), _fWeigh │ │ │ │ +00008290: 7473 2866 2920 7b20 7d3c 2f64 6976 3e0a ts(f) { }
. │ │ │ │ +000082a0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 │ │ │ │ +000083b0: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ +00008420: 6120 6964 3d22 6c30 3032 3138 2220 6e61 a id="l00218" na │ │ │ │ +00008430: 6d65 3d22 6c30 3032 3138 223e 3c2f 613e me="l00218"> │ │ │ │ +00008440: 3c73 7061 6e20 636c 6173 733d 226c 696e 218 publi │ │ │ │ +00008480: 633c 2f73 7061 6e3e 3a3c 2f64 6976 3e0a c:
. │ │ │ │ +00008490: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
< │ │ │ │ +00008520: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00008530: 6e6f 223e 2020 3232 303c 2f73 7061 6e3e no"> 220 │ │ │ │ +00008540: 2020 2020 2020 2020 3c73 7061 6e20 636c // │ │ │ │ +00008560: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00008580: 3c61 2069 643d 226c 3030 3232 3122 206e 221 │ │ │ │ +000085e0: 2f2f 2020 4d65 7468 6f64 7320 7265 7175 // Methods requ │ │ │ │ +000085f0: 6972 6564 2066 6f72 2067 656e 6572 616c ired for general │ │ │ │ +00008600: 206d 6173 6b20 6173 7369 676e 6d65 6e74 mask assignment │ │ │ │ +00008610: 7320 616e 6420 7175 6572 6965 733a 3c2f s and queries:
.
< │ │ │ │ +00008660: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00008670: 6e6f 223e 2020 3232 323c 2f73 7061 6e3e no"> 222 │ │ │ │ +00008680: 2020 2020 2020 2020 3c73 7061 6e20 636c // │ │ │ │ +000086a0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +000086c0: 3c61 2069 643d 226c 3030 3232 3322 206e 223 │ │ │ │ +00008740: 3c2f 613e 3c2f 7370 616e 3e20 2020 2020 │ │ │ │ +00008750: 2020 203c 7370 616e 2063 6c61 7373 3d22 int │ │ │ │ +00008770: 3c2f 7370 616e 3e20 3c61 2063 6c61 7373 GetNumV │ │ │ │ +000087d0: 6572 7465 7857 6569 6768 7473 3c2f 613e ertexWeights │ │ │ │ +000087e0: 2829 3c73 7061 6e20 636c 6173 733d 226b () const < │ │ │ │ +00008800: 2f73 7061 6e3e 7b20 3c73 7061 6e20 636c /span>{ return │ │ │ │ +00008830: 5f76 436f 756e 743b 207d 3c2f 6469 763e _vCount; }
│ │ │ │ +00008840: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00008870: 3c2f 613e 3c73 7061 6e20 636c 6173 733d │ │ │ │ +000088d0: 3232 343c 2f61 3e3c 2f73 7061 6e3e 2020 224 │ │ │ │ +000088e0: 2020 2020 2020 3c73 7061 6e20 636c 6173 │ │ │ │ +00008900: 696e 743c 2f73 7061 6e3e 203c 6120 636c int GetN │ │ │ │ +00008960: 756d 4564 6765 5765 6967 6874 733c 2f61 umEdgeWeights() cons │ │ │ │ +00008990: 7420 3c2f 7370 616e 3e7b 203c 7370 616e t { return _eCount; }.
225 int G │ │ │ │ +00008af0: 6574 4e75 6d46 6163 6557 6569 6768 7473 etNumFaceWeights │ │ │ │ +00008b00: 3c2f 613e 2829 3c73 7061 6e20 636c 6173 () c │ │ │ │ +00008b20: 6f6e 7374 203c 2f73 7061 6e3e 7b20 3c73 onst { return _fCount; } │ │ │ │ +00008b60: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00008bb0: 2032 3236 3c2f 7370 616e 3e20 3c2f 6469 226 .
│ │ │ │ +00008c50: 2020 3232 373c 2f61 3e3c 2f73 7061 6e3e 227 │ │ │ │ +00008c60: 2020 2020 2020 2020 3c73 7061 6e20 636c void S │ │ │ │ +00008ce0: 6574 4e75 6d56 6572 7465 7857 6569 6768 etNumVertexWeigh │ │ │ │ +00008cf0: 7473 3c2f 613e 283c 7370 616e 2063 6c61 ts(int coun │ │ │ │ +00008d20: 7429 207b 205f 7643 6f75 6e74 203d 2063 t) { _vCount = c │ │ │ │ +00008d30: 6f75 6e74 3b20 7d3c 2f64 6976 3e0a 3c64 ount; }
. │ │ │ │ +00008d50: 3c61 2069 643d 226c 3030 3232 3822 206e 228 │ │ │ │ +00008dd0: 3c2f 613e 3c2f 7370 616e 3e20 2020 2020 │ │ │ │ +00008de0: 2020 203c 7370 616e 2063 6c61 7373 3d22 voi │ │ │ │ +00008e00: 643c 2f73 7061 6e3e 203c 6120 636c 6173 d SetNum │ │ │ │ +00008e60: 4564 6765 5765 6967 6874 733c 2f61 3e28 EdgeWeights( │ │ │ │ +00008e70: 2020 3c73 7061 6e20 636c 6173 733d 226b int< │ │ │ │ +00008e90: 2f73 7061 6e3e 2063 6f75 6e74 2920 7b20 /span> count) { │ │ │ │ +00008ea0: 5f65 436f 756e 7420 3d20 636f 756e 743b _eCount = count; │ │ │ │ +00008eb0: 207d 3c2f 6469 763e 0a3c 6469 7620 636c }
.
229< │ │ │ │ +00008f50: 2f73 7061 6e3e 2020 2020 2020 2020 3c73 /span> void SetNumFaceW │ │ │ │ +00008fe0: 6569 6768 7473 3c2f 613e 2820 203c 7370 eights( int count) { _fCou │ │ │ │ +00009020: 6e74 203d 2063 6f75 6e74 3b20 7d3c 2f64 nt = count; }.
23 │ │ │ │ +00009080: 303c 2f73 7061 6e3e 203c 2f64 6976 3e0a 0
. │ │ │ │ +00009090: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +000090c0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 2 │ │ │ │ +00009120: 3331 3c2f 613e 3c2f 7370 616e 3e20 2020 31 │ │ │ │ +00009130: 2020 2020 203c 6120 636c 6173 733d 2263 Weight │ │ │ │ +00009190: 3c73 7061 6e20 636c 6173 733d 226b 6579 const& VertexW │ │ │ │ +00009210: 6569 6768 743c 2f61 3e28 3c73 7061 6e20 eight(int i │ │ │ │ +00009240: 6e64 6578 293c 7370 616e 2063 6c61 7373 ndex) cons │ │ │ │ +00009260: 7420 3c2f 7370 616e 3e7b 203c 7370 616e t { return _vWeights[ind │ │ │ │ +000092a0: 6578 5d3b 207d 3c2f 6469 763e 0a3c 6469 ex]; }
.< │ │ │ │ +000092c0: 6120 6964 3d22 6c30 3032 3332 2220 6e61 a id="l00232" na │ │ │ │ +000092d0: 6d65 3d22 6c30 3032 3332 223e 3c2f 613e me="l00232"> │ │ │ │ +000092e0: 3c73 7061 6e20 636c 6173 733d 226c 696e 232< │ │ │ │ +00009340: 2f61 3e3c 2f73 7061 6e3e 2020 2020 2020 /a> │ │ │ │ +00009350: 2020 3c61 2063 6c61 7373 3d22 636f 6465 Weight const& │ │ │ │ +000093d0: 616d 703b 203c 6120 636c 6173 733d 2263 amp; EdgeWeight │ │ │ │ +00009430: 3c2f 613e 2820 203c 7370 616e 2063 6c61 ( int inde │ │ │ │ +00009460: 7829 3c73 7061 6e20 636c 6173 733d 226b x) const < │ │ │ │ +00009480: 2f73 7061 6e3e 7b20 3c73 7061 6e20 636c /span>{ return │ │ │ │ +000094b0: 5f65 5765 6967 6874 735b 696e 6465 785d _eWeights[index] │ │ │ │ +000094c0: 3b20 7d3c 2f64 6976 3e0a 3c64 6976 2063 ; }
.
233 │ │ │ │ +00009560: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ +00009570: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00009580: 5f74 7970 6564 6566 2220 6872 6566 3d22 _typedef" href=" │ │ │ │ +00009590: 6130 3133 3435 2e68 746d 6c23 6131 3733 a01345.html#a173 │ │ │ │ +000095a0: 6539 3865 3064 3162 3364 3135 6635 6333 e98e0d1b3d15f5c3 │ │ │ │ +000095b0: 6164 3433 3664 3066 6564 3430 3122 3e57 ad436d0fed401">W │ │ │ │ +000095c0: 6569 6768 743c 2f61 3e20 3c73 7061 6e20 eight │ │ │ │ +000095e0: 636f 6e73 743c 2f73 7061 6e3e 2661 6d70 const& │ │ │ │ +000095f0: 3b20 3c61 2063 6c61 7373 3d22 636f 6465 ; FaceWeight( in │ │ │ │ +00009670: 743c 2f73 7061 6e3e 2069 6e64 6578 293c t index)< │ │ │ │ +00009680: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00009690: 6f72 6422 3e20 636f 6e73 7420 3c2f 7370 ord"> const { r │ │ │ │ +000096c0: 6574 7572 6e3c 2f73 7061 6e3e 205f 6657 eturn _fW │ │ │ │ +000096d0: 6569 6768 7473 5b69 6e64 6578 5d3b 207d eights[index]; } │ │ │ │ +000096e0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00009730: 2032 3334 3c2f 7370 616e 3e20 3c2f 6469 234 .
│ │ │ │ +000097d0: 2020 3233 353c 2f61 3e3c 2f73 7061 6e3e 235 │ │ │ │ +000097e0: 2020 2020 2020 2020 3c61 2063 6c61 7373 Weight& VertexW │ │ │ │ +000098a0: 6569 6768 743c 2f61 3e28 3c73 7061 6e20 eight(int i │ │ │ │ +000098d0: 6e64 6578 2920 7b20 3c73 7061 6e20 636c ndex) { return │ │ │ │ +00009900: 5f76 5765 6967 6874 735b 696e 6465 785d _vWeights[index] │ │ │ │ +00009910: 3b20 7d3c 2f64 6976 3e0a 3c64 6976 2063 ; }
.
236 │ │ │ │ +000099b0: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ +000099c0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +000099d0: 5f74 7970 6564 6566 2220 6872 6566 3d22 _typedef" href=" │ │ │ │ +000099e0: 6130 3133 3435 2e68 746d 6c23 6131 3733 a01345.html#a173 │ │ │ │ +000099f0: 6539 3865 3064 3162 3364 3135 6635 6333 e98e0d1b3d15f5c3 │ │ │ │ +00009a00: 6164 3433 3664 3066 6564 3430 3122 3e57 ad436d0fed401">W │ │ │ │ +00009a10: 6569 6768 743c 2f61 3e26 616d 703b 203c eight& < │ │ │ │ +00009a20: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00009a30: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ +00009a40: 2261 3031 3334 352e 6874 6d6c 2361 3533 "a01345.html#a53 │ │ │ │ +00009a50: 3364 6261 3332 6139 3436 3835 3463 3366 3dba32a946854c3f │ │ │ │ +00009a60: 3235 6532 3762 3532 3165 6637 6466 223e 25e27b521ef7df"> │ │ │ │ +00009a70: 4564 6765 5765 6967 6874 3c2f 613e 2820 EdgeWeight( │ │ │ │ +00009a80: 203c 7370 616e 2063 6c61 7373 3d22 6b65 int index) { < │ │ │ │ +00009ab0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00009ac0: 6f72 6466 6c6f 7722 3e72 6574 7572 6e3c ordflow">return< │ │ │ │ +00009ad0: 2f73 7061 6e3e 205f 6557 6569 6768 7473 /span> _eWeights │ │ │ │ +00009ae0: 5b69 6e64 6578 5d3b 207d 3c2f 6469 763e [index]; }
│ │ │ │ +00009af0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00009b20: 3c2f 613e 3c73 7061 6e20 636c 6173 733d │ │ │ │ +00009b80: 3233 373c 2f61 3e3c 2f73 7061 6e3e 2020 237 │ │ │ │ +00009b90: 2020 2020 2020 3c61 2063 6c61 7373 3d22 Weight │ │ │ │ +00009bf0: 2661 6d70 3b20 3c61 2063 6c61 7373 3d22 & FaceWeigh │ │ │ │ +00009c50: 743c 2f61 3e28 2020 3c73 7061 6e20 636c t( int ind │ │ │ │ +00009c80: 6578 2920 7b20 3c73 7061 6e20 636c 6173 ex) { │ │ │ │ +00009ca0: 7265 7475 726e 3c2f 7370 616e 3e20 5f66 return _f │ │ │ │ +00009cb0: 5765 6967 6874 735b 696e 6465 785d 3b20 Weights[index]; │ │ │ │ +00009cc0: 7d3c 2f64 6976 3e0a 3c64 6976 2063 6c61 }
.
│ │ │ │ +00009d10: 2020 3233 383c 2f73 7061 6e3e 203c 2f64 238 .
239 bool < │ │ │ │ +00009df0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00009e00: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ +00009e10: 2261 3031 3334 352e 6874 6d6c 2361 3335 "a01345.html#a35 │ │ │ │ +00009e20: 3139 6535 6530 3536 3331 3032 3666 6164 19e5e05631026fad │ │ │ │ +00009e30: 3934 6337 3631 3666 3565 3065 3637 223e 94c7616f5e0e67"> │ │ │ │ +00009e40: 4172 6546 6163 6557 6569 6768 7473 466f AreFaceWeightsFo │ │ │ │ +00009e50: 7246 6163 6543 656e 7465 7273 3c2f 613e rFaceCenters │ │ │ │ +00009e60: 2829 3c73 7061 6e20 636c 6173 733d 226b () const │ │ │ │ +00009e80: 3c2f 7370 616e 3e7b 203c 7370 616e 2063 { return │ │ │ │ +00009eb0: 205f 6657 6569 6768 7473 466f 7243 656e _fWeightsForCen │ │ │ │ +00009ec0: 7465 7273 3b20 7d3c 2f64 6976 3e0a 3c64 ters; }
. │ │ │ │ +00009ee0: 3c61 2069 643d 226c 3030 3234 3022 206e 240 │ │ │ │ +00009f60: 3c2f 613e 3c2f 7370 616e 3e20 2020 2020 │ │ │ │ +00009f70: 2020 203c 7370 616e 2063 6c61 7373 3d22 voi │ │ │ │ +00009f90: 643c 2f73 7061 6e3e 203c 6120 636c 6173 d SetFac │ │ │ │ +00009ff0: 6557 6569 6768 7473 466f 7246 6163 6543 eWeightsForFaceC │ │ │ │ +0000a000: 656e 7465 7273 3c2f 613e 283c 7370 616e enters(bool │ │ │ │ +0000a030: 206f 6e29 207b 205f 6657 6569 6768 7473 on) { _fWeights │ │ │ │ +0000a040: 466f 7243 656e 7465 7273 203d 206f 6e3b ForCenters = on; │ │ │ │ +0000a050: 207d 3c2f 6469 763e 0a3c 6469 7620 636c }
.
241 .
2 │ │ │ │ +0000a100: 3432 3c2f 7370 616e 3e20 2020 203c 7370 42 public │ │ │ │ +0000a130: 3a3c 2f64 6976 3e0a 3c64 6976 2063 6c61 :
.
│ │ │ │ +0000a180: 2020 3234 333c 2f73 7061 6e3e 203c 2f64 243 .
24 │ │ │ │ +0000a1e0: 343c 2f73 7061 6e3e 2020 2020 2020 2020 4 │ │ │ │ +0000a1f0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ +0000a210: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0000a260: 3234 353c 2f73 7061 6e3e 2020 2020 2020 245 │ │ │ │ +0000a270: 2020 3c73 7061 6e20 636c 6173 733d 2263 // Addi │ │ │ │ +0000a290: 7469 6f6e 616c 206d 6574 686f 6473 202d tional methods - │ │ │ │ +0000a2a0: 2d20 6d61 696e 6c79 2074 6865 2062 6c65 - mainly the ble │ │ │ │ +0000a2b0: 6e64 696e 6720 6d65 7468 6f64 2066 6f72 nding method for │ │ │ │ +0000a2c0: 2076 6572 7465 782d 7665 7274 6578 206d vertex-vertex m │ │ │ │ +0000a2d0: 6173 6b73 3a3c 2f73 7061 6e3e 3c2f 6469 asks:.
246 │ │ │ │ +0000a330: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ +0000a340: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +0000a350: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
2 │ │ │ │ +0000a3b0: 3437 3c2f 7370 616e 3e20 2020 2020 2020 47 │ │ │ │ +0000a3c0: 203c 7370 616e 2063 6c61 7373 3d22 6b65 template< │ │ │ │ +0000a3e0: 2f73 7061 6e3e 2026 6c74 3b3c 7370 616e /span> <typename │ │ │ │ +0000a410: 2055 5345 525f 4d41 534b 2667 743b 3c2f USER_MASK>.
2 │ │ │ │ +0000a470: 3438 3c2f 7370 616e 3e20 2020 2020 2020 48 │ │ │ │ +0000a480: 203c 7370 616e 2063 6c61 7373 3d22 6b65 inline v │ │ │ │ +0000a4c0: 6f69 643c 2f73 7061 6e3e 3c2f 6469 763e oid
│ │ │ │ +0000a4d0: 0a3c 6469 7620 636c 6173 733d 2266 6f6c .
.
< │ │ │ │ +0000a560: 6120 636c 6173 733d 226c 696e 6522 2068 a class="line" h │ │ │ │ +0000a570: 7265 663d 2261 3031 3334 352e 6874 6d6c ref="a01345.html │ │ │ │ +0000a580: 2361 3565 6438 3030 6539 6437 3032 6635 #a5ed800e9d702f5 │ │ │ │ +0000a590: 3761 6539 3738 6665 3630 6261 3261 3337 7ae978fe60ba2a37 │ │ │ │ +0000a5a0: 6463 223e 2020 3234 393c 2f61 3e3c 2f73 dc"> 249 Com │ │ │ │ +0000a610: 6269 6e65 5665 7274 6578 5665 7274 6578 bineVertexVertex │ │ │ │ +0000a620: 4d61 736b 733c 2f61 3e28 3c61 2063 6c61 Masks(Weight │ │ │ │ +0000a680: 3c2f 613e 2074 6869 7343 6f65 6666 2c20 thisCoeff, │ │ │ │ +0000a690: 3c61 2063 6c61 7373 3d22 636f 6465 2068 │ │ │ │ +0000a6e0: 5765 6967 6874 3c2f 613e 2064 7374 436f Weight dstCo │ │ │ │ +0000a6f0: 6566 662c 2055 5345 525f 4d41 534b 2661 eff, USER_MASK&a │ │ │ │ +0000a700: 6d70 3b20 6473 7429 3c73 7061 6e20 636c mp; dst) c │ │ │ │ +0000a720: 6f6e 7374 203c 2f73 7061 6e3e 7b3c 2f64 onst {.
25 │ │ │ │ +0000a780: 303c 2f73 7061 6e3e 203c 2f64 6976 3e0a 0
. │ │ │ │ +0000a790: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +0000a7c0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 251 │ │ │ │ +0000a7f0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ +0000a810: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0000a860: 3235 323c 2f73 7061 6e3e 2020 2020 2020 252 │ │ │ │ +0000a870: 2020 2020 2020 3c73 7061 6e20 636c 6173 // │ │ │ │ +0000a890: 5468 6973 2069 6d70 6c65 6d65 6e74 6174 This implementat │ │ │ │ +0000a8a0: 696f 6e20 6973 2063 6f6e 766f 6c75 7465 ion is convolute │ │ │ │ +0000a8b0: 6420 6279 2074 6865 2070 6f74 656e 7469 d by the potenti │ │ │ │ +0000a8c0: 616c 2073 7061 7273 6974 7920 6f66 2065 al sparsity of e │ │ │ │ +0000a8d0: 6163 6820 6d61 736b 2e20 2053 696e 6365 ach mask. Since │ │ │ │ +0000a8e0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +0000a900: 3c61 2069 643d 226c 3030 3235 3322 206e 253 // it is sp │ │ │ │ +0000a970: 6563 6966 6963 2074 6f20 6120 7665 7274 ecific to a vert │ │ │ │ +0000a980: 6578 2d76 6572 7465 7820 6d61 736b 2c20 ex-vertex mask, │ │ │ │ +0000a990: 7765 2061 7265 2067 7561 7261 6e74 6565 we are guarantee │ │ │ │ +0000a9a0: 6420 746f 2068 6176 6520 6578 6163 746c d to have exactl │ │ │ │ +0000a9b0: 7920 6f6e 653c 2f73 7061 6e3e 3c2f 6469 y one.
254 │ │ │ │ +0000aa10: 3c2f 7370 616e 3e20 2020 2020 2020 2020 │ │ │ │ +0000aa20: 2020 203c 7370 616e 2063 6c61 7373 3d22 // ver │ │ │ │ +0000aa40: 7465 782d 7765 6967 6874 2066 6f72 2062 tex-weight for b │ │ │ │ +0000aa50: 6f74 6820 6d61 736b 732c 2062 7574 2074 oth masks, but t │ │ │ │ +0000aa60: 6865 2065 6467 652d 2061 6e64 2066 6163 he edge- and fac │ │ │ │ +0000aa70: 652d 7765 6967 6874 7320 6172 6520 6f70 e-weights are op │ │ │ │ +0000aa80: 7469 6f6e 616c 2e20 2054 6865 3c2f 7370 tional. The
.
255 │ │ │ │ +0000aaf0: 2020 2020 2020 2020 2020 3c73 7061 6e20 │ │ │ │ +0000ab10: 2f2f 2020 6368 696c 6420 6d61 736b 2028 // child mask ( │ │ │ │ +0000ab20: 7468 6520 2671 756f 743b 736f 7572 6365 the "source │ │ │ │ +0000ab30: 2671 756f 743b 2920 7368 6f75 6c64 2068 ") should h │ │ │ │ +0000ab40: 6176 6520 6120 7375 7065 7273 6574 206f ave a superset o │ │ │ │ +0000ab50: 6620 7468 6520 7765 6967 6874 7320 6f66 f the weights of │ │ │ │ +0000ab60: 2074 6865 2070 6172 656e 743c 2f73 7061 the parent
.
256 │ │ │ │ +0000abd0: 2020 2020 2020 2020 203c 7370 616e 2063 / │ │ │ │ +0000abf0: 2f20 2028 7468 6520 2671 756f 743b 6465 / (the "de │ │ │ │ +0000ac00: 7374 696e 6174 696f 6e26 7175 6f74 3b29 stination") │ │ │ │ +0000ac10: 2067 6976 656e 2069 7473 2072 6564 7563 given its reduc │ │ │ │ +0000ac20: 6564 2073 6861 7270 6e65 7373 2c20 736f ed sharpness, so │ │ │ │ +0000ac30: 2077 6520 666f 7274 756e 6174 656c 7920 we fortunately │ │ │ │ +0000ac40: 646f 6e26 2333 393b 7420 6e65 6564 2074 don't need t │ │ │ │ +0000ac50: 6f3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c o
.< │ │ │ │ +0000ac60: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0000ac70: 3e3c 6120 6964 3d22 6c30 3032 3537 2220 > 257 < │ │ │ │ +0000acc0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +0000acd0: 656e 7422 3e2f 2f20 2074 6573 7420 616c ent">// test al │ │ │ │ +0000ace0: 6c20 7065 726d 7574 6174 696f 6e73 2e3c l permutations.< │ │ │ │ +0000acf0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ +0000ad10: 6120 6964 3d22 6c30 3032 3538 2220 6e61 a id="l00258" na │ │ │ │ +0000ad20: 6d65 3d22 6c30 3032 3538 223e 3c2f 613e me="l00258"> │ │ │ │ +0000ad30: 3c73 7061 6e20 636c 6173 733d 226c 696e 258 //.
259 │ │ │ │ +0000add0: 3c2f 7370 616e 3e20 2020 2020 2020 2020 │ │ │ │ +0000ade0: 2020 2064 7374 2e56 6572 7465 7857 6569 dst.VertexWei │ │ │ │ +0000adf0: 6768 7428 3029 203d 2064 7374 436f 6566 ght(0) = dstCoef │ │ │ │ +0000ae00: 6620 2a20 6473 742e 5665 7274 6578 5765 f * dst.VertexWe │ │ │ │ +0000ae10: 6967 6874 2830 2920 2b20 7468 6973 436f ight(0) + thisCo │ │ │ │ +0000ae20: 6566 6620 2a20 7468 6973 2d26 6774 3b3c eff * this->< │ │ │ │ +0000ae30: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +0000ae40: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ +0000ae50: 2261 3031 3334 352e 6874 6d6c 2361 6563 "a01345.html#aec │ │ │ │ +0000ae60: 3563 3261 6266 6466 6264 6534 6464 3933 5c2abfdfbde4dd93 │ │ │ │ +0000ae70: 3463 3036 3136 3235 3939 3437 3931 223e 4c061625994791"> │ │ │ │ +0000ae80: 5665 7274 6578 5765 6967 6874 3c2f 613e VertexWeight │ │ │ │ +0000ae90: 2830 293b 3c2f 6469 763e 0a3c 6469 7620 (0);
.
260 │ │ │ │ +0000aef0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0000af40: 2032 3631 3c2f 7370 616e 3e20 2020 2020 261 │ │ │ │ +0000af50: 2020 2020 2020 203c 7370 616e 2063 6c61 int edge │ │ │ │ +0000af80: 5765 6967 6874 436f 756e 7420 3d20 7468 WeightCount = th │ │ │ │ +0000af90: 6973 2d26 6774 3b3c 6120 636c 6173 733d is->GetNumEd │ │ │ │ +0000aff0: 6765 5765 6967 6874 733c 2f61 3e28 293b geWeights(); │ │ │ │ +0000b000: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0000b050: 2032 3632 3c2f 7370 616e 3e20 2020 2020 262 │ │ │ │ +0000b060: 2020 2020 2020 203c 7370 616e 2063 6c61 if (edge │ │ │ │ +0000b090: 5765 6967 6874 436f 756e 7429 207b 3c2f WeightCount) {.
2 │ │ │ │ +0000b0f0: 3633 3c2f 7370 616e 3e20 2020 2020 2020 63 │ │ │ │ +0000b100: 2020 2020 2020 2020 203c 7370 616e 2063 if (ds │ │ │ │ +0000b130: 742e 4765 744e 756d 4564 6765 5765 6967 t.GetNumEdgeWeig │ │ │ │ +0000b140: 6874 7328 2920 3d3d 2030 2920 7b3c 2f64 hts() == 0) {.
26 │ │ │ │ +0000b1a0: 343c 2f73 7061 6e3e 2020 2020 2020 2020 4 │ │ │ │ +0000b1b0: 2020 2020 2020 2020 2020 2020 6473 742e dst. │ │ │ │ +0000b1c0: 5365 744e 756d 4564 6765 5765 6967 6874 SetNumEdgeWeight │ │ │ │ +0000b1d0: 7328 6564 6765 5765 6967 6874 436f 756e s(edgeWeightCoun │ │ │ │ +0000b1e0: 7429 3b3c 2f64 6976 3e0a 3c64 6976 2063 t);
.
265 │ │ │ │ +0000b240: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000b250: 2020 3c73 7061 6e20 636c 6173 733d 226b for< │ │ │ │ +0000b270: 2f73 7061 6e3e 2028 3c73 7061 6e20 636c /span> (int i = │ │ │ │ +0000b2a0: 2030 3b20 6920 266c 743b 2065 6467 6557 0; i < edgeW │ │ │ │ +0000b2b0: 6569 6768 7443 6f75 6e74 3b20 2b2b 6929 eightCount; ++i) │ │ │ │ +0000b2c0: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
266 │ │ │ │ +0000b320: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000b330: 2020 2020 2064 7374 2e45 6467 6557 6569 dst.EdgeWei │ │ │ │ +0000b340: 6768 7428 6929 203d 2074 6869 7343 6f65 ght(i) = thisCoe │ │ │ │ +0000b350: 6666 202a 2074 6869 732d 2667 743b 3c61 ff * this->E │ │ │ │ +0000b3b0: 6467 6557 6569 6768 743c 2f61 3e28 6929 dgeWeight(i) │ │ │ │ +0000b3c0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +0000b410: 2020 3236 373c 2f73 7061 6e3e 2020 2020 267 │ │ │ │ +0000b420: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000b430: 7d3c 2f64 6976 3e0a 3c64 6976 2063 6c61 }
.
│ │ │ │ +0000b480: 2020 3236 383c 2f73 7061 6e3e 2020 2020 268 │ │ │ │ +0000b490: 2020 2020 2020 2020 2020 2020 7d20 3c73 } else {
.
< │ │ │ │ +0000b500: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0000b510: 6e6f 223e 2020 3236 393c 2f73 7061 6e3e no"> 269 │ │ │ │ +0000b520: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000b530: 2020 2020 3c73 7061 6e20 636c 6173 733d fo │ │ │ │ +0000b550: 723c 2f73 7061 6e3e 2028 3c73 7061 6e20 r (int i │ │ │ │ +0000b580: 203d 2030 3b20 6920 266c 743b 2065 6467 = 0; i < edg │ │ │ │ +0000b590: 6557 6569 6768 7443 6f75 6e74 3b20 2b2b eWeightCount; ++ │ │ │ │ +0000b5a0: 6929 207b 3c2f 6469 763e 0a3c 6469 7620 i) {
.
270 │ │ │ │ +0000b600: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000b610: 2020 2020 2020 2064 7374 2e45 6467 6557 dst.EdgeW │ │ │ │ +0000b620: 6569 6768 7428 6929 203d 2064 7374 436f eight(i) = dstCo │ │ │ │ +0000b630: 6566 6620 2a20 6473 742e 4564 6765 5765 eff * dst.EdgeWe │ │ │ │ +0000b640: 6967 6874 2869 2920 2b20 7468 6973 436f ight(i) + thisCo │ │ │ │ +0000b650: 6566 6620 2a20 7468 6973 2d26 6774 3b3c eff * this->< │ │ │ │ +0000b660: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +0000b670: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ +0000b680: 2261 3031 3334 352e 6874 6d6c 2361 3464 "a01345.html#a4d │ │ │ │ +0000b690: 6239 3332 6138 6133 3366 6430 3632 3263 b932a8a33fd0622c │ │ │ │ +0000b6a0: 3764 3031 3136 3765 6231 3462 3532 223e 7d01167eb14b52"> │ │ │ │ +0000b6b0: 4564 6765 5765 6967 6874 3c2f 613e 2869 EdgeWeight(i │ │ │ │ +0000b6c0: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
271 │ │ │ │ +0000b720: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000b730: 207d 3c2f 6469 763e 0a3c 6469 7620 636c }
.
272 │ │ │ │ +0000b790: 2020 2020 2020 2020 2020 2020 207d 3c2f }.
2 │ │ │ │ +0000b7f0: 3733 3c2f 7370 616e 3e20 2020 2020 2020 73 │ │ │ │ +0000b800: 2020 2020 207d 3c2f 6469 763e 0a3c 6469 }
.< │ │ │ │ +0000b820: 6120 6964 3d22 6c30 3032 3734 2220 6e61 a id="l00274" na │ │ │ │ +0000b830: 6d65 3d22 6c30 3032 3734 223e 3c2f 613e me="l00274"> │ │ │ │ +0000b840: 3c73 7061 6e20 636c 6173 733d 226c 696e 274
.
275 │ │ │ │ +0000b8c0: 2020 2020 2020 2020 203c 7370 616e 2063 int fa │ │ │ │ +0000b8f0: 6365 5765 6967 6874 436f 756e 7420 3d20 ceWeightCount = │ │ │ │ +0000b900: 7468 6973 2d26 6774 3b3c 6120 636c 6173 this->GetNum │ │ │ │ +0000b960: 4661 6365 5765 6967 6874 733c 2f61 3e28 FaceWeights( │ │ │ │ +0000b970: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
276 │ │ │ │ +0000b9d0: 2020 2020 2020 2020 203c 7370 616e 2063 if (fa │ │ │ │ +0000ba00: 6365 5765 6967 6874 436f 756e 7429 207b ceWeightCount) { │ │ │ │ +0000ba10: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0000ba60: 2032 3737 3c2f 7370 616e 3e20 2020 2020 277 │ │ │ │ +0000ba70: 2020 2020 2020 2020 2020 203c 7370 616e //
│ │ │ │ +0000baa0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +0000bad0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 278 │ │ │ │ +0000bb00: 2020 2020 203c 7370 616e 2063 6c61 7373 // I │ │ │ │ +0000bb20: 6620 636f 6d62 696e 696e 6720 6661 6365 f combining face │ │ │ │ +0000bb30: 2077 6569 6768 7473 2c20 6265 2073 7572 weights, be sur │ │ │ │ +0000bb40: 6520 7468 6569 7220 696e 7465 7270 7265 e their interpre │ │ │ │ +0000bb50: 7461 7469 6f6e 2028 692e 652e 2066 6163 tation (i.e. fac │ │ │ │ +0000bb60: 652d 6365 6e74 6572 733c 2f73 7061 6e3e e-centers │ │ │ │ +0000bb70: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0000bbc0: 2032 3739 3c2f 7370 616e 3e20 2020 2020 279 │ │ │ │ +0000bbd0: 2020 2020 2020 2020 2020 203c 7370 616e // or opposite │ │ │ │ +0000bc00: 2076 6572 7469 6365 7329 2069 7320 7072 vertices) is pr │ │ │ │ +0000bc10: 6f70 6572 6c79 2073 6574 2069 6e20 7468 operly set in th │ │ │ │ +0000bc20: 6520 6465 7374 696e 6174 696f 6e20 6d61 e destination ma │ │ │ │ +0000bc30: 736b 3a3c 2f73 7061 6e3e 3c2f 6469 763e sk:
│ │ │ │ +0000bc40: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +0000bc70: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 280 │ │ │ │ +0000bca0: 2020 2020 203c 7370 616e 2063 6c61 7373 //
.
281 │ │ │ │ +0000bd20: 2020 2020 2020 2020 2020 2020 2020 203c < │ │ │ │ +0000bd30: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +0000bd40: 6f72 6466 6c6f 7722 3e69 663c 2f73 7061 ordflow">if (dst.GetNumFa │ │ │ │ +0000bd60: 6365 5765 6967 6874 7328 2920 3d3d 2030 ceWeights() == 0 │ │ │ │ +0000bd70: 2920 7b3c 2f64 6976 3e0a 3c64 6976 2063 ) {
.
282 │ │ │ │ +0000bdd0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000bde0: 2020 6473 742e 5365 744e 756d 4661 6365 dst.SetNumFace │ │ │ │ +0000bdf0: 5765 6967 6874 7328 6661 6365 5765 6967 Weights(faceWeig │ │ │ │ +0000be00: 6874 436f 756e 7429 3b3c 2f64 6976 3e0a htCount);
. │ │ │ │ +0000be10: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
. │ │ │ │ +0000bf30: 3c61 2069 643d 226c 3030 3238 3422 206e 284
.
285 │ │ │ │ +0000bfd0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000bfe0: 2020 3c73 7061 6e20 636c 6173 733d 226b for< │ │ │ │ +0000c000: 2f73 7061 6e3e 2028 3c73 7061 6e20 636c /span> (int i = │ │ │ │ +0000c030: 2030 3b20 6920 266c 743b 2066 6163 6557 0; i < faceW │ │ │ │ +0000c040: 6569 6768 7443 6f75 6e74 3b20 2b2b 6929 eightCount; ++i) │ │ │ │ +0000c050: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
286 │ │ │ │ +0000c0b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000c0c0: 2020 2020 2064 7374 2e46 6163 6557 6569 dst.FaceWei │ │ │ │ +0000c0d0: 6768 7428 6929 203d 2074 6869 7343 6f65 ght(i) = thisCoe │ │ │ │ +0000c0e0: 6666 202a 2074 6869 732d 2667 743b 3c61 ff * this->F │ │ │ │ +0000c140: 6163 6557 6569 6768 743c 2f61 3e28 6929 aceWeight(i) │ │ │ │ +0000c150: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +0000c1a0: 2020 3238 373c 2f73 7061 6e3e 2020 2020 287 │ │ │ │ +0000c1b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000c1c0: 7d3c 2f64 6976 3e0a 3c64 6976 2063 6c61 }
.
│ │ │ │ +0000c210: 2020 3238 383c 2f73 7061 6e3e 2020 2020 288 │ │ │ │ +0000c220: 2020 2020 2020 2020 2020 2020 7d20 3c73 } else {
.
< │ │ │ │ +0000c290: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0000c2a0: 6e6f 223e 2020 3238 393c 2f73 7061 6e3e no"> 289 │ │ │ │ +0000c2b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0000c2c0: 2020 2020 6173 7365 7274 2874 6869 732d assert(this- │ │ │ │ +0000c2d0: 2667 743b 3c61 2063 6c61 7373 3d22 636f >AreFaceWeig │ │ │ │ +0000c330: 6874 7346 6f72 4661 6365 4365 6e74 6572 htsForFaceCenter │ │ │ │ +0000c340: 733c 2f61 3e28 2920 3d3d 2064 7374 2e41 s() == dst.A │ │ │ │ +0000c350: 7265 4661 6365 5765 6967 6874 7346 6f72 reFaceWeightsFor │ │ │ │ +0000c360: 4661 6365 4365 6e74 6572 7328 2929 3b3c FaceCenters());< │ │ │ │ +0000c370: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0000c3c0: 3239 303c 2f73 7061 6e3e 203c 2f64 6976 290
.
291< │ │ │ │ +0000c420: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ +0000c430: 2020 2020 2020 2020 2020 3c73 7061 6e20 for ( │ │ │ │ +0000c460: 3c73 7061 6e20 636c 6173 733d 226b 6579 int i = 0; i &l │ │ │ │ +0000c490: 743b 2066 6163 6557 6569 6768 7443 6f75 t; faceWeightCou │ │ │ │ +0000c4a0: 6e74 3b20 2b2b 6929 207b 3c2f 6469 763e nt; ++i) {
│ │ │ │ +0000c4b0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +0000c4e0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 292 │ │ │ │ +0000c510: 2020 2020 2020 2020 2020 2020 2064 7374 dst │ │ │ │ +0000c520: 2e46 6163 6557 6569 6768 7428 6929 203d .FaceWeight(i) = │ │ │ │ +0000c530: 2064 7374 436f 6566 6620 2a20 6473 742e dstCoeff * dst. │ │ │ │ +0000c540: 4661 6365 5765 6967 6874 2869 2920 2b20 FaceWeight(i) + │ │ │ │ +0000c550: 7468 6973 436f 6566 6620 2a20 7468 6973 thisCoeff * this │ │ │ │ +0000c560: 2d26 6774 3b3c 6120 636c 6173 733d 2263 ->FaceWeight │ │ │ │ +0000c5c0: 3c2f 613e 2869 293b 3c2f 6469 763e 0a3c (i);
.< │ │ │ │ +0000c5d0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0000c5e0: 3e3c 6120 6964 3d22 6c30 3032 3933 2220 > 293 │ │ │ │ +0000c630: 2020 2020 2020 207d 3c2f 6469 763e 0a3c }
.< │ │ │ │ 0000c640: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000c650: 3e3c 6120 6964 3d22 6c30 3033 3034 2220 > 304 double gamma = (0.62 │ │ │ │ -0000c6d0: 3566 202d 2028 6265 7461 202a 2062 6574 5f - (beta * bet │ │ │ │ -0000c6e0: 6129 2920 2a20 696e 7656 616c 656e 6365 a)) * invValence │ │ │ │ -0000c6f0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -0000c740: 2020 3330 353c 2f73 7061 6e3e 203c 2f64 305 .
30 │ │ │ │ -0000c7a0: 363c 2f73 7061 6e3e 2020 2020 2020 2020 6 │ │ │ │ -0000c7b0: 5765 6967 6874 2065 5765 6967 6874 203d Weight eWeight = │ │ │ │ -0000c7c0: 2028 5765 6967 6874 2920 2831 2e30 6620 (Weight) (1.0f │ │ │ │ -0000c7d0: 2f20 2864 5661 6c65 6e63 6520 2b20 332e / (dValence + 3. │ │ │ │ -0000c7e0: 3066 202f 2028 382e 3066 202a 2067 616d 0f / (8.0f * gam │ │ │ │ -0000c7f0: 6d61 2929 293b 3c2f 6469 763e 0a3c 6469 ma)));
.< │ │ │ │ -0000c810: 6120 6964 3d22 6c30 3033 3037 2220 6e61 a id="l00307" na │ │ │ │ -0000c820: 6d65 3d22 6c30 3033 3037 223e 3c2f 613e me="l00307"> │ │ │ │ -0000c830: 3c73 7061 6e20 636c 6173 733d 226c 696e 307 Weight │ │ │ │ -0000c860: 7657 6569 6768 7420 3d20 2857 6569 6768 vWeight = (Weigh │ │ │ │ -0000c870: 7429 2028 312e 3066 202d 2028 6557 6569 t) (1.0f - (eWei │ │ │ │ -0000c880: 6768 7420 2a20 6456 616c 656e 6365 2929 ght * dValence)) │ │ │ │ -0000c890: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -0000c8e0: 2020 3330 383c 2f73 7061 6e3e 203c 2f64 308 .
30 │ │ │ │ -0000c940: 393c 2f73 7061 6e3e 2020 2020 2020 2020 9 │ │ │ │ -0000c950: 706f 734d 6173 6b2e 5665 7274 6578 5765 posMask.VertexWe │ │ │ │ -0000c960: 6967 6874 2830 2920 3d20 7657 6569 6768 ight(0) = vWeigh │ │ │ │ -0000c970: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
310 │ │ │ │ -0000c9d0: 2020 2020 203c 7370 616e 2063 6c61 7373 f │ │ │ │ -0000c9f0: 6f72 3c2f 7370 616e 3e20 283c 7370 616e or (int │ │ │ │ -0000ca20: 6920 3d20 303b 2069 2026 6c74 3b20 7661 i = 0; i < va │ │ │ │ -0000ca30: 6c65 6e63 653b 202b 2b69 2920 7b3c 2f64 lence; ++i) {.
31 │ │ │ │ -0000ca90: 313c 2f73 7061 6e3e 2020 2020 2020 2020 1 │ │ │ │ -0000caa0: 2020 2020 706f 734d 6173 6b2e 4564 6765 posMask.Edge │ │ │ │ -0000cab0: 5765 6967 6874 2869 2920 3d20 6557 6569 Weight(i) = eWei │ │ │ │ -0000cac0: 6768 743b 3c2f 6469 763e 0a3c 6469 7620 ght;
.
312 │ │ │ │ -0000cb20: 2020 2020 2020 207d 3c2f 6469 763e 0a3c }
.< │ │ │ │ -0000cb30: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000cb40: 3e3c 6120 6964 3d22 6c30 3033 3133 2220 > 313 }
.< │ │ │ │ -0000cb90: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000cba0: 3e3c 6120 6964 3d22 6c30 3033 3134 2220 > 314}
.
.
315< │ │ │ │ -0000cc40: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ -0000cc60: 3c61 2069 643d 226c 3030 3331 3622 206e 316/*
.
│ │ │ │ -0000cd10: 2020 3331 373c 2f73 7061 6e3e 3c73 7061 317// Limit mask │ │ │ │ -0000cd40: 7320 666f 7220 7461 6e67 656e 7473 3a3c s for tangents:< │ │ │ │ -0000cd50: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -0000cd70: 6120 6964 3d22 6c30 3033 3138 2220 6e61 a id="l00318" na │ │ │ │ -0000cd80: 6d65 3d22 6c30 3033 3138 223e 3c2f 613e me="l00318"> │ │ │ │ -0000cd90: 3c73 7061 6e20 636c 6173 733d 226c 696e 318// │ │ │ │ -0000cdd0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000ce20: 2033 3139 3c2f 7370 616e 3e3c 7370 616e 319// A note on t │ │ │ │ -0000ce50: 616e 6765 6e74 206d 6167 6e69 7475 6465 angent magnitude │ │ │ │ -0000ce60: 733a 3c2f 7370 616e 3e3c 2f64 6976 3e0a s:
. │ │ │ │ -0000ce70: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
321// Several │ │ │ │ -0000cf60: 666f 726d 756c 6165 2065 7869 7374 2066 formulae exist f │ │ │ │ -0000cf70: 6f72 206c 696d 6974 2074 616e 6765 6e74 or limit tangent │ │ │ │ -0000cf80: 7320 6174 2061 2076 6572 7465 7820 746f s at a vertex to │ │ │ │ -0000cf90: 2061 6363 6f6d 6d6f 6461 7465 2074 6865 accommodate the │ │ │ │ -0000cfa0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000cfc0: 3c61 2069 643d 226c 3030 3332 3222 206e 322// diff │ │ │ │ -0000d020: 6572 656e 7420 746f 706f 6c6f 6769 6361 erent topologica │ │ │ │ -0000d030: 6c20 636f 6e66 6967 7572 6174 696f 6e73 l configurations │ │ │ │ -0000d040: 2061 726f 756e 6420 7468 6520 7665 7274 around the vert │ │ │ │ -0000d050: 6578 2e20 2057 6869 6c65 2074 6865 7365 ex. While these │ │ │ │ -0000d060: 2070 726f 6475 6365 3c2f 7370 616e 3e3c produce< │ │ │ │ -0000d070: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000d0c0: 3332 333c 2f73 7061 6e3e 3c73 7061 6e20 323 │ │ │ │ -0000d0e0: 2f2f 2020 7468 6520 6465 7369 7265 6420 // the desired │ │ │ │ -0000d0f0: 6469 7265 6374 696f 6e2c 2074 6865 7265 direction, there │ │ │ │ -0000d100: 2069 7320 696e 636f 6e73 6973 7465 6e63 is inconsistenc │ │ │ │ -0000d110: 7920 696e 2074 6865 2072 6573 756c 7469 y in the resulti │ │ │ │ -0000d120: 6e67 206d 6167 6e69 7475 6465 732e 3c2f ng magnitudes.
.
< │ │ │ │ -0000d170: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000d180: 6e6f 223e 2020 3332 343c 2f73 7061 6e3e no"> 324 │ │ │ │ -0000d190: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // Ideall │ │ │ │ -0000d1b0: 7920 6120 7265 6775 6c61 7220 6d65 7368 y a regular mesh │ │ │ │ -0000d1c0: 206f 6620 756e 6966 6f72 6d6c 7920 7368 of uniformly sh │ │ │ │ -0000d1d0: 6170 6564 2074 7269 616e 676c 6573 2077 aped triangles w │ │ │ │ -0000d1e0: 6974 6820 7369 6d69 6c61 7220 6564 6765 ith similar edge │ │ │ │ -0000d1f0: 206c 656e 6774 6873 3c2f 7370 616e 3e3c lengths< │ │ │ │ -0000d200: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000d250: 3332 353c 2f73 7061 6e3e 3c73 7061 6e20 325 │ │ │ │ -0000d270: 2f2f 2020 7368 6f75 6c64 2070 726f 6475 // should produ │ │ │ │ -0000d280: 6365 2074 616e 6765 6e74 7320 6f66 2073 ce tangents of s │ │ │ │ -0000d290: 696d 696c 6172 206d 6167 6e69 7475 6465 imilar magnitude │ │ │ │ -0000d2a0: 7320 7468 726f 7567 686f 7574 202d 2d20 s throughout -- │ │ │ │ -0000d2b0: 696e 636c 7564 696e 6720 636f 726e 6572 including corner │ │ │ │ -0000d2c0: 733c 2f73 7061 6e3e 3c2f 6469 763e 0a3c s
.< │ │ │ │ -0000d2d0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000d2e0: 3e3c 6120 6964 3d22 6c30 3033 3236 2220 > 326// and │ │ │ │ -0000d340: 2062 6f75 6e64 6172 6965 732e 2020 536f boundaries. So │ │ │ │ -0000d350: 2073 6f6d 6520 6f66 2074 6865 2063 6f6d some of the com │ │ │ │ -0000d360: 6d6f 6e20 666f 726d 756c 6165 2066 6f72 mon formulae for │ │ │ │ -0000d370: 2074 6865 7365 2061 7265 2061 646a 7573 these are adjus │ │ │ │ -0000d380: 7465 6420 7769 7468 3c2f 7370 616e 3e3c ted with< │ │ │ │ -0000d390: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000d3e0: 3332 373c 2f73 7061 6e3e 3c73 7061 6e20 327 │ │ │ │ -0000d400: 2f2f 2020 7363 616c 6520 6661 6374 6f72 // scale factor │ │ │ │ -0000d410: 732e 3c2f 7370 616e 3e3c 2f64 6976 3e0a s.
. │ │ │ │ -0000d420: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
329// For uses │ │ │ │ -0000d510: 2077 6865 7265 206d 6167 6e69 7475 6465 where magnitude │ │ │ │ -0000d520: 2064 6f65 7320 6e6f 7420 6d61 7474 6572 does not matter │ │ │ │ -0000d530: 2c20 7468 6973 2073 6361 6c69 6e67 2073 , this scaling s │ │ │ │ -0000d540: 686f 756c 6420 6265 2069 7272 656c 6576 hould be irrelev │ │ │ │ -0000d550: 616e 742e 3c2f 7370 616e 3e3c 2f64 6976 ant.
.
330< │ │ │ │ -0000d5b0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -0000d5d0: 4275 7420 6a75 7374 2061 7320 7769 7468 But just as with │ │ │ │ -0000d5e0: 2070 6174 6368 6573 2c20 7768 6572 6520 patches, where │ │ │ │ -0000d5f0: 7468 6520 6d61 676e 6974 7564 6573 206f the magnitudes o │ │ │ │ -0000d600: 6620 7061 7274 6961 6c20 6465 7269 7661 f partial deriva │ │ │ │ -0000d610: 7469 7665 7320 6172 653c 2f73 7061 6e3e tives are │ │ │ │ -0000d620: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000d670: 2033 3331 3c2f 7370 616e 3e3c 7370 616e 331// consistent │ │ │ │ -0000d6a0: 6265 7477 6565 6e20 7369 6d69 6c61 7220 between similar │ │ │ │ -0000d6b0: 7061 7463 6865 732c 2074 6865 206d 6167 patches, the mag │ │ │ │ -0000d6c0: 6e69 7475 6465 7320 6f66 206c 696d 6974 nitudes of limit │ │ │ │ -0000d6d0: 2074 616e 6765 6e74 7320 7368 6f75 6c64 tangents should │ │ │ │ -0000d6e0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000d700: 3c61 2069 643d 226c 3030 3333 3222 206e 332// also │ │ │ │ -0000d760: 2062 6520 7369 6d69 6c61 722e 3c2f 7370 be similar.
.
333//.
33 │ │ │ │ -0000d840: 343c 2f73 7061 6e3e 3c73 7061 6e20 636c 4// │ │ │ │ -0000d860: 2020 5468 6520 7265 6665 7265 6e63 6520 The reference │ │ │ │ -0000d870: 7461 6e67 656e 7473 2c20 696e 2074 6572 tangents, in ter │ │ │ │ -0000d880: 6d73 206f 6620 6d61 676e 6974 7564 6573 ms of magnitudes │ │ │ │ -0000d890: 2c20 6172 6520 7468 6f73 6520 7072 6f64 , are those prod │ │ │ │ -0000d8a0: 7563 6564 2062 7920 7468 653c 2f73 7061 uced by the
.
335// limit tan │ │ │ │ -0000d930: 6765 6e74 206d 6173 6b20 666f 7220 736d gent mask for sm │ │ │ │ -0000d940: 6f6f 7468 2069 6e74 6572 696f 7220 7665 ooth interior ve │ │ │ │ -0000d950: 7274 6963 6573 2c20 666f 7220 7768 6963 rtices, for whic │ │ │ │ -0000d960: 6820 7765 6c6c 2065 7374 6162 6c69 7368 h well establish │ │ │ │ -0000d970: 6564 3c2f 7370 616e 3e3c 2f64 6976 3e0a ed
. │ │ │ │ -0000d980: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -0000d9b0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 336// si │ │ │ │ -0000d9f0: 6e2f 636f 7320 666f 726d 756c 6165 2061 n/cos formulae a │ │ │ │ -0000da00: 7070 6c79 202d 2d20 7468 6573 6520 7265 pply -- these re │ │ │ │ -0000da10: 6d61 696e 2075 6e73 6361 6c65 642e 2020 main unscaled. │ │ │ │ -0000da20: 466f 726d 756c 6165 2066 6f72 2074 6865 Formulae for the │ │ │ │ -0000da30: 206f 7468 6572 3c2f 7370 616e 3e3c 2f64 other.
33 │ │ │ │ -0000da90: 373c 2f73 7061 6e3e 3c73 7061 6e20 636c 7// │ │ │ │ -0000dab0: 2020 6372 6561 7365 2f62 6f75 6e64 6172 crease/boundar │ │ │ │ -0000dac0: 792c 2063 6f72 6e65 7220 7461 6e67 656e y, corner tangen │ │ │ │ -0000dad0: 7473 2061 6e64 2069 7272 6567 756c 6172 ts and irregular │ │ │ │ -0000dae0: 2063 6173 6573 2061 7265 2073 6361 6c65 cases are scale │ │ │ │ -0000daf0: 6420 746f 2062 6520 6d6f 7265 3c2f 7370 d to be more
.
338// consiste │ │ │ │ -0000db80: 6e74 2077 6974 6820 7468 6573 652e 3c2f nt with these.
.
< │ │ │ │ -0000dbd0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000dbe0: 6e6f 223e 2020 3333 393c 2f73 7061 6e3e no"> 339 │ │ │ │ -0000dbf0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ -0000dc10: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000dc60: 3334 303c 2f73 7061 6e3e 3c73 7061 6e20 340 │ │ │ │ -0000dc80: 2f2f 2020 5468 6520 6372 6561 7365 2f62 // The crease/b │ │ │ │ -0000dc90: 6f75 6e64 6172 7920 7461 6e67 656e 7473 oundary tangents │ │ │ │ -0000dca0: 2066 6f72 2074 6865 2072 6567 756c 6172 for the regular │ │ │ │ -0000dcb0: 2063 6173 6520 6361 6e20 6265 2076 6965 case can be vie │ │ │ │ -0000dcc0: 7765 6420 6173 2064 6572 6976 6564 3c2f wed as derived
.
< │ │ │ │ -0000dd10: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000dd20: 6e6f 223e 2020 3334 313c 2f73 7061 6e3e no"> 341 │ │ │ │ -0000dd30: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // from t │ │ │ │ -0000dd50: 6865 2073 6d6f 6f74 6820 696e 7465 7269 he smooth interi │ │ │ │ -0000dd60: 6f72 206d 6173 6b73 2077 6974 6820 7477 or masks with tw │ │ │ │ -0000dd70: 6f20 2671 756f 743b 7068 616e 746f 6d26 o "phantom& │ │ │ │ -0000dd80: 7175 6f74 3b20 706f 696e 7473 2065 7874 quot; points ext │ │ │ │ -0000dd90: 7261 706f 6c61 7465 6420 6163 726f 7373 rapolated across │ │ │ │ -0000dda0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000ddc0: 3c61 2069 643d 226c 3030 3334 3222 206e 342// the │ │ │ │ -0000de20: 7265 6775 6c61 7220 626f 756e 6461 7279 regular boundary │ │ │ │ -0000de30: 3a3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c :
.< │ │ │ │ -0000de40: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000de50: 3e3c 6120 6964 3d22 6c30 3033 3433 2220 > 343//
.
344// │ │ │ │ -0000df30: 2076 3320 2020 2020 2020 2020 2020 7632 v3 v2 │ │ │ │ -0000df40: 2020 2020 2020 2020 2020 3c2f 7370 616e
.
│ │ │ │ -0000dfa0: 2020 3334 353c 2f73 7061 6e3e 3c73 7061 345// │ │ │ │ -0000dfd0: 2058 202d 202d 202d 202d 202d 2058 3c2f X - - - - - X
.
< │ │ │ │ -0000e020: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000e030: 6e6f 223e 2020 3334 363c 2f73 7061 6e3e no"> 346 │ │ │ │ -0000e040: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // │ │ │ │ -0000e060: 2020 202f 2020 205c 2020 2020 2020 202f / \ / │ │ │ │ -0000e070: 2020 205c 3c2f 7370 616e 3e3c 2f64 6976 \
.
347< │ │ │ │ -0000e0d0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -0000e0f0: 2020 2020 2020 202f 2020 2020 2020 205c / \ │ │ │ │ -0000e100: 2020 202f 2020 2020 2020 205c 3c2f 7370 / \
.
348// v4 X - │ │ │ │ -0000e190: 202d 202d 202d 202d 2058 202d 202d 202d - - - - X - - - │ │ │ │ -0000e1a0: 202d 202d 2058 2020 7631 3c2f 7370 616e - - X v1
.
│ │ │ │ -0000e200: 2020 3334 393c 2f73 7061 6e3e 3c73 7061 349// . │ │ │ │ -0000e230: 2020 2020 202e 2030 202e 2020 2020 2020 . 0 . │ │ │ │ -0000e240: 202e 3c2f 7370 616e 3e3c 2f64 6976 3e0a .
. │ │ │ │ -0000e250: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -0000e280: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 350// │ │ │ │ -0000e2c0: 2020 2020 2020 202e 2020 202e 2020 2020 . . │ │ │ │ -0000e2d0: 2020 202e 2020 202e 3c2f 7370 616e 3e3c . .< │ │ │ │ -0000e2e0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000e330: 3335 313c 2f73 7061 6e3e 3c73 7061 6e20 351 │ │ │ │ -0000e350: 2f2f 2020 2020 2020 2020 2020 2020 202e // . │ │ │ │ -0000e360: 2020 202e 2020 202e 2020 202e 3c2f 7370 . . .
.
352// │ │ │ │ -0000e3f0: 2028 7635 2920 2020 2020 2020 2020 2876 (v5) (v │ │ │ │ -0000e400: 3629 3c2f 7370 616e 3e3c 2f64 6976 3e0a 6)
. │ │ │ │ -0000e410: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
354// where v5 │ │ │ │ -0000e500: 203d 2076 3020 2b20 2876 3420 2d20 7633 = v0 + (v4 - v3 │ │ │ │ -0000e510: 2920 616e 6420 7636 203d 2076 3020 2b20 ) and v6 = v0 + │ │ │ │ -0000e520: 7631 202d 2076 322e 3c2f 7370 616e 3e3c v1 - v2.< │ │ │ │ -0000e530: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000e580: 3335 353c 2f73 7061 6e3e 3c73 7061 6e20 355 │ │ │ │ -0000e5a0: 2f2f 3c2f 7370 616e 3e3c 2f64 6976 3e0a //
. │ │ │ │ -0000e5b0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -0000e5e0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 356// Wh │ │ │ │ -0000e620: 656e 2074 6865 2073 7461 6e64 6172 6420 en the standard │ │ │ │ -0000e630: 6c69 6d69 7420 7461 6e67 656e 7420 6d61 limit tangent ma │ │ │ │ -0000e640: 736b 2069 7320 6170 706c 6965 642c 2074 sk is applied, t │ │ │ │ -0000e650: 6865 2063 6f73 696e 6573 206f 6620 696e he cosines of in │ │ │ │ -0000e660: 6372 656d 656e 7473 3c2f 7370 616e 3e3c crements< │ │ │ │ -0000e670: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000e6c0: 3335 373c 2f73 7061 6e3e 3c73 7061 6e20 357 │ │ │ │ -0000e6e0: 2f2f 2020 6f66 2070 692f 3320 6769 7665 // of pi/3 give │ │ │ │ -0000e6f0: 2075 7320 636f 6566 6669 6369 656e 7473 us coefficients │ │ │ │ -0000e700: 2074 6861 7420 6172 6520 6d75 6c74 6970 that are multip │ │ │ │ -0000e710: 6c65 7320 6f66 2031 2f32 2c20 6c65 6164 les of 1/2, lead │ │ │ │ -0000e720: 696e 6720 746f 2074 6865 2066 6972 7374 ing to the first │ │ │ │ -0000e730: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000e750: 3c61 2069 643d 226c 3030 3335 3822 206e 358// tang │ │ │ │ -0000e7b0: 656e 7420 5431 203d 2033 2f32 202a 2028 ent T1 = 3/2 * ( │ │ │ │ -0000e7c0: 7631 202d 2076 3429 2c20 7261 7468 6572 v1 - v4), rather │ │ │ │ -0000e7d0: 2074 6861 6e20 7468 6520 7769 6465 6c79 than the widely │ │ │ │ -0000e7e0: 2075 7365 6420 5431 203d 2076 3120 2d20 used T1 = v1 - │ │ │ │ -0000e7f0: 7634 2e20 2053 6f3c 2f73 7061 6e3e 3c2f v4. So.
3 │ │ │ │ -0000e850: 3539 3c2f 7370 616e 3e3c 7370 616e 2063 59/ │ │ │ │ -0000e870: 2f20 2074 6869 7320 7363 616c 6520 6661 / this scale fa │ │ │ │ -0000e880: 6374 6f72 206f 6620 332f 3220 6973 2061 ctor of 3/2 is a │ │ │ │ -0000e890: 7070 6c69 6564 2074 6f20 656e 7375 7265 pplied to ensure │ │ │ │ -0000e8a0: 2074 616e 6765 6e74 7320 616c 6f6e 6720 tangents along │ │ │ │ -0000e8b0: 7468 6520 626f 756e 6461 7269 6573 3c2f the boundaries
.
< │ │ │ │ -0000e900: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000e910: 6e6f 223e 2020 3336 303c 2f73 7061 6e3e no"> 360 │ │ │ │ -0000e920: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // are of │ │ │ │ -0000e940: 2073 696d 696c 6172 206d 6167 6e69 7475 similar magnitu │ │ │ │ -0000e950: 6465 2061 7320 7461 6e67 656e 7473 2069 de as tangents i │ │ │ │ -0000e960: 6e20 7468 6520 696d 6d65 6469 6174 6520 n the immediate │ │ │ │ -0000e970: 696e 7465 7269 6f72 2028 7768 6963 6820 interior (which │ │ │ │ -0000e980: 6d61 7920 6265 3c2f 7370 616e 3e3c 2f64 may be.
36 │ │ │ │ -0000e9e0: 313c 2f73 7061 6e3e 3c73 7061 6e20 636c 1// │ │ │ │ -0000ea00: 2020 7061 7261 6c6c 656c 292e 3c2f 7370 parallel).
.
362//.
36 │ │ │ │ -0000eae0: 333c 2f73 7061 6e3e 3c73 7061 6e20 636c 3// │ │ │ │ -0000eb00: 2020 5461 6e67 656e 7473 2061 7420 636f Tangents at co │ │ │ │ -0000eb10: 726e 6572 7320 6172 6520 6573 7365 6e74 rners are essent │ │ │ │ -0000eb20: 6961 6c6c 7920 6120 666f 726d 206f 6620 ially a form of │ │ │ │ -0000eb30: 626f 756e 6461 7279 2074 616e 6765 6e74 boundary tangent │ │ │ │ -0000eb40: 2c20 616e 6420 736f 2069 7473 3c2f 7370 , and so its
.
364// simple d │ │ │ │ -0000ebd0: 6966 6665 7265 6e63 6520 666f 726d 756c ifference formul │ │ │ │ -0000ebe0: 6120 6973 2073 6361 6c65 6420 746f 2062 a is scaled to b │ │ │ │ -0000ebf0: 6520 636f 6e73 6973 7465 6e74 2077 6974 e consistent wit │ │ │ │ -0000ec00: 6820 6164 6a6f 696e 696e 6720 626f 756e h adjoining boun │ │ │ │ -0000ec10: 6461 7279 3c2f 7370 616e 3e3c 2f64 6976 dary
.
365< │ │ │ │ -0000ec70: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -0000ec90: 7461 6e67 656e 7473 202d 2d20 6e6f 7420 tangents -- not │ │ │ │ -0000eca0: 6a75 7374 2077 6974 6820 7468 6520 332f just with the 3/ │ │ │ │ -0000ecb0: 3220 6661 6374 6f72 2066 726f 6d20 6162 2 factor from ab │ │ │ │ -0000ecc0: 6f76 652c 2062 7574 2077 6974 6820 616e ove, but with an │ │ │ │ -0000ecd0: 2061 6464 6974 696f 6e61 6c3c 2f73 7061 additional
.
366// 2.0 to co │ │ │ │ -0000ed60: 6d70 656e 7361 7465 2066 6f72 2074 6865 mpensate for the │ │ │ │ -0000ed70: 2066 6163 7420 7468 6174 2074 6865 2064 fact that the d │ │ │ │ -0000ed80: 6966 6665 7265 6e63 6520 6f66 206f 6e6c ifference of onl │ │ │ │ -0000ed90: 7920 7369 6465 206f 6620 7468 6520 7665 y side of the ve │ │ │ │ -0000eda0: 7274 6578 3c2f 7370 616e 3e3c 2f64 6976 rtex
.
367< │ │ │ │ -0000ee00: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -0000ee20: 6973 2063 6f6e 7369 6465 7265 6420 6865 is considered he │ │ │ │ -0000ee30: 7265 2e20 2054 6865 2072 6573 756c 7469 re. The resulti │ │ │ │ -0000ee40: 6e67 2073 6361 6c65 2066 6163 746f 7220 ng scale factor │ │ │ │ -0000ee50: 6f66 2033 2e30 2066 6f72 2074 6865 2072 of 3.0 for the r │ │ │ │ -0000ee60: 6567 756c 6172 2063 6f72 6e65 723c 2f73 egular corner
.
368< │ │ │ │ -0000eed0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -0000eee0: 656e 7422 3e2f 2f20 2069 7320 7768 6174 ent">// is what │ │ │ │ -0000eef0: 2073 696d 696c 6172 6c79 2061 7269 7365 similarly arise │ │ │ │ -0000ef00: 7320 6279 2065 7874 7261 706f 6c61 7469 s by extrapolati │ │ │ │ -0000ef10: 6e67 2061 6e20 696e 7465 7269 6f72 2072 ng an interior r │ │ │ │ -0000ef20: 6567 696f 6e20 6172 6f75 6e64 2074 6865 egion around the │ │ │ │ -0000ef30: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000ef50: 3c61 2069 643d 226c 3030 3336 3922 206e 369// vert │ │ │ │ -0000efb0: 6578 2061 6e64 2075 7369 6e67 2074 6865 ex and using the │ │ │ │ -0000efc0: 2069 6e74 6572 696f 7220 6d61 736b 2066 interior mask f │ │ │ │ -0000efd0: 6f72 2074 6865 2066 6972 7374 2074 616e or the first tan │ │ │ │ -0000efe0: 6765 6e74 2e3c 2f73 7061 6e3e 3c2f 6469 gent..
370 │ │ │ │ -0000f040: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 //< │ │ │ │ -0000f060: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -0000f080: 6120 6964 3d22 6c30 3033 3731 2220 6e61 a id="l00371" na │ │ │ │ -0000f090: 6d65 3d22 6c30 3033 3731 223e 3c2f 613e me="l00371"> │ │ │ │ -0000f0a0: 3c73 7061 6e20 636c 6173 733d 226c 696e 371// The c │ │ │ │ -0000f0e0: 726f 7373 2d74 616e 6765 6e74 2066 6f72 ross-tangent for │ │ │ │ -0000f0f0: 6d75 6c61 2066 6f72 2074 6865 2072 6567 mula for the reg │ │ │ │ -0000f100: 756c 6172 2063 7265 6173 652f 626f 756e ular crease/boun │ │ │ │ -0000f110: 6461 7279 2069 7320 7369 6d69 6c61 726c dary is similarl │ │ │ │ -0000f120: 7920 666f 756e 643c 2f73 7061 6e3e 3c2f y found.
3 │ │ │ │ -0000f180: 3732 3c2f 7370 616e 3e3c 7370 616e 2063 72/ │ │ │ │ -0000f1a0: 2f20 2066 726f 6d20 7468 6520 6162 6f76 / from the abov │ │ │ │ -0000f1b0: 6520 636f 6e73 7472 7563 7469 6f6e 206f e construction o │ │ │ │ -0000f1c0: 6620 7468 6520 626f 756e 6461 7279 2c20 f the boundary, │ │ │ │ -0000f1d0: 6275 7420 7468 6520 636f 6d6d 6f6e 6c79 but the commonly │ │ │ │ -0000f1e0: 2075 7365 6420 7765 6967 6874 7320 6f66 used weights of │ │ │ │ -0000f1f0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000f210: 3c61 2069 643d 226c 3030 3337 3322 206e 373// +/- │ │ │ │ -0000f270: 3120 616e 6420 3220 7265 7375 6c74 2066 1 and 2 result f │ │ │ │ -0000f280: 726f 6d20 6f6d 6974 7469 6e67 2074 6865 rom omitting the │ │ │ │ -0000f290: 2063 6f6d 6d6f 6e20 6661 6374 6f72 206f common factor o │ │ │ │ -0000f2a0: 6620 7371 7274 2833 292f 3220 2861 7269 f sqrt(3)/2 (ari │ │ │ │ -0000f2b0: 7369 6e67 2066 726f 6d3c 2f73 7061 6e3e sing from │ │ │ │ -0000f2c0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000f310: 2033 3734 3c2f 7370 616e 3e3c 7370 616e 374// the sines o │ │ │ │ -0000f340: 6620 696e 6372 656d 656e 7473 206f 6620 f increments of │ │ │ │ -0000f350: 7069 2f33 292e 2020 5769 7468 2074 6861 pi/3). With tha │ │ │ │ -0000f360: 7420 7363 616c 6520 6661 6374 6f72 2063 t scale factor c │ │ │ │ -0000f370: 6c6f 7365 2074 6f20 6f6e 652c 2069 7420 lose to one, it │ │ │ │ -0000f380: 6861 733c 2f73 7061 6e3e 3c2f 6469 763e has
│ │ │ │ -0000f390: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -0000f3c0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 375// l │ │ │ │ -0000f400: 6573 7320 696d 7061 6374 2074 6861 6e20 ess impact than │ │ │ │ -0000f410: 7468 6520 6972 7265 6775 6c61 7220 6361 the irregular ca │ │ │ │ -0000f420: 7365 732c 2077 6869 6368 2061 7265 2061 ses, which are a │ │ │ │ -0000f430: 6e61 6c6f 676f 7573 2074 6f20 636f 726e nalogous to corn │ │ │ │ -0000f440: 6572 2074 616e 6765 6e74 733c 2f73 7061 er tangents
.
376// in that d │ │ │ │ -0000f4d0: 6966 6665 7265 6e63 6573 206f 6e20 6f6e ifferences on on │ │ │ │ -0000f4e0: 6c79 206f 6e65 2073 6964 6520 6f66 2074 ly one side of t │ │ │ │ -0000f4f0: 6865 2076 6572 7465 7820 6172 6520 636f he vertex are co │ │ │ │ -0000f500: 6e73 6964 6572 6564 2e20 2057 6869 6c65 nsidered. While │ │ │ │ -0000f510: 2061 3c2f 7370 616e 3e3c 2f64 6976 3e0a a
. │ │ │ │ -0000f520: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
378< │ │ │ │ -0000f640: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -0000f650: 656e 7422 3e2f 2f20 206c 6573 7320 6f62 ent">// less ob │ │ │ │ -0000f660: 7669 6f75 7320 696e 2074 6865 2069 7272 vious in the irr │ │ │ │ -0000f670: 6567 756c 6172 2066 6f72 6d75 6c61 2066 egular formula f │ │ │ │ -0000f680: 6f72 2076 616c 656e 6365 2026 6774 3b20 or valence > │ │ │ │ -0000f690: 342c 2062 7574 2073 696d 696c 6172 6c79 4, but similarly │ │ │ │ -0000f6a0: 2065 6666 6563 7469 7665 2e3c 2f73 7061 effective.
.
379//.
380 │ │ │ │ -0000f780: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ -0000f7a0: 2054 6865 2065 6e64 2072 6573 756c 7420 The end result │ │ │ │ -0000f7b0: 6f66 2074 6865 7365 2061 646a 7573 746d of these adjustm │ │ │ │ -0000f7c0: 656e 7473 2073 686f 756c 6420 6265 2061 ents should be a │ │ │ │ -0000f7d0: 2073 6574 206f 6620 6c69 6d69 7420 7461 set of limit ta │ │ │ │ -0000f7e0: 6e67 656e 7473 2074 6861 7420 6172 653c ngents that are< │ │ │ │ -0000f7f0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -0000f810: 6120 6964 3d22 6c30 3033 3831 2220 6e61 a id="l00381" na │ │ │ │ -0000f820: 6d65 3d22 6c30 3033 3831 223e 3c2f 613e me="l00381"> │ │ │ │ -0000f830: 3c73 7061 6e20 636c 6173 733d 226c 696e 381// of si │ │ │ │ -0000f870: 6d69 6c61 7220 6d61 676e 6974 7564 6520 milar magnitude │ │ │ │ -0000f880: 6f76 6572 2061 2072 6567 756c 6172 206d over a regular m │ │ │ │ -0000f890: 6573 6820 696e 636c 7564 696e 6720 626f esh including bo │ │ │ │ -0000f8a0: 756e 6461 7269 6573 2061 6e64 2063 6f72 undaries and cor │ │ │ │ -0000f8b0: 6e65 7273 2e3c 2f73 7061 6e3e 3c2f 6469 ners..
382 │ │ │ │ -0000f910: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 */< │ │ │ │ -0000f930: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -0000f950: 6120 6964 3d22 6c30 3033 3833 2220 6e61 a id="l00383" na │ │ │ │ -0000f960: 6d65 3d22 6c30 3033 3833 223e 3c2f 613e me="l00383"> │ │ │ │ -0000f970: 3c73 7061 6e20 636c 6173 733d 226c 696e 383template< │ │ │ │ -0000f9b0: 2f73 7061 6e3e 2026 6c74 3b26 6774 3b3c /span> <>< │ │ │ │ -0000f9c0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000fa10: 3338 343c 2f73 7061 6e3e 3c73 7061 6e20 384 │ │ │ │ -0000fa30: 7465 6d70 6c61 7465 3c2f 7370 616e 3e20 template │ │ │ │ -0000fa40: 266c 743b 3c73 7061 6e20 636c 6173 733d <typena │ │ │ │ -0000fa60: 6d65 3c2f 7370 616e 3e20 5645 5254 4558 me VERTEX │ │ │ │ -0000fa70: 2c20 3c73 7061 6e20 636c 6173 733d 226b , typename │ │ │ │ -0000fa90: 3c2f 7370 616e 3e20 4d41 534b 2667 743b MASK> │ │ │ │ -0000faa0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000faf0: 2033 3835 3c2f 7370 616e 3e3c 7370 616e 385inline < │ │ │ │ -0000fb20: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -0000fb30: 6f72 6474 7970 6522 3e76 6f69 643c 2f73 ordtype">void
.
│ │ │ │ -0000fb90: 0a3c 6469 7620 636c 6173 733d 226c 696e ..
387 │ │ │ │ -0000fd50: 2020 2020 204d 4153 4b26 616d 703b 2074 MASK& t │ │ │ │ -0000fd60: 616e 314d 6173 6b2c 204d 4153 4b26 616d an1Mask, MASK&am │ │ │ │ -0000fd70: 703b 2074 616e 324d 6173 6b29 3c73 7061 p; tan2Mask) const │ │ │ │ -0000fda0: 7b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 {
.
│ │ │ │ -0000fdf0: 2020 3338 383c 2f73 7061 6e3e 203c 2f64 388 .
38 │ │ │ │ -0000fe50: 393c 2f73 7061 6e3e 2020 2020 3c73 7061 9 int │ │ │ │ -0000fe80: 2076 616c 656e 6365 203d 2076 6572 7465 valence = verte │ │ │ │ -0000fe90: 782e 4765 744e 756d 4564 6765 7328 293b x.GetNumEdges(); │ │ │ │ -0000fea0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000fef0: 2033 3930 3c2f 7370 616e 3e20 3c2f 6469 390 .
391 │ │ │ │ -0000ff50: 3c2f 7370 616e 3e20 2020 2074 616e 314d tan1M │ │ │ │ -0000ff60: 6173 6b2e 5365 744e 756d 5665 7274 6578 ask.SetNumVertex │ │ │ │ -0000ff70: 5765 6967 6874 7328 3129 3b3c 2f64 6976 Weights(1);
.
392< │ │ │ │ -0000ffd0: 2f73 7061 6e3e 2020 2020 7461 6e31 4d61 /span> tan1Ma │ │ │ │ -0000ffe0: 736b 2e53 6574 4e75 6d45 6467 6557 6569 sk.SetNumEdgeWei │ │ │ │ -0000fff0: 6768 7473 2876 616c 656e 6365 293b 3c2f ghts(valence);.
3 │ │ │ │ -00010050: 3933 3c2f 7370 616e 3e20 2020 2074 616e 93 tan │ │ │ │ -00010060: 314d 6173 6b2e 5365 744e 756d 4661 6365 1Mask.SetNumFace │ │ │ │ -00010070: 5765 6967 6874 7328 3029 3b3c 2f64 6976 Weights(0);
.
394< │ │ │ │ -000100d0: 2f73 7061 6e3e 2020 2020 7461 6e31 4d61 /span> tan1Ma │ │ │ │ -000100e0: 736b 2e53 6574 4661 6365 5765 6967 6874 sk.SetFaceWeight │ │ │ │ -000100f0: 7346 6f72 4661 6365 4365 6e74 6572 7328 sForFaceCenters( │ │ │ │ -00010100: 3c73 7061 6e20 636c 6173 733d 226b 6579 false);
.
395 │ │ │ │ -00010180: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000101d0: 2033 3936 3c2f 7370 616e 3e20 2020 2074 396 t │ │ │ │ -000101e0: 616e 324d 6173 6b2e 5365 744e 756d 5665 an2Mask.SetNumVe │ │ │ │ -000101f0: 7274 6578 5765 6967 6874 7328 3129 3b3c rtexWeights(1);< │ │ │ │ -00010200: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00010250: 3339 373c 2f73 7061 6e3e 2020 2020 7461 397 ta │ │ │ │ -00010260: 6e32 4d61 736b 2e53 6574 4e75 6d45 6467 n2Mask.SetNumEdg │ │ │ │ -00010270: 6557 6569 6768 7473 2876 616c 656e 6365 eWeights(valence │ │ │ │ -00010280: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
398 │ │ │ │ -000102e0: 2074 616e 324d 6173 6b2e 5365 744e 756d tan2Mask.SetNum │ │ │ │ -000102f0: 4661 6365 5765 6967 6874 7328 3029 3b3c FaceWeights(0);< │ │ │ │ -00010300: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00010350: 3339 393c 2f73 7061 6e3e 2020 2020 7461 399 ta │ │ │ │ -00010360: 6e32 4d61 736b 2e53 6574 4661 6365 5765 n2Mask.SetFaceWe │ │ │ │ -00010370: 6967 6874 7346 6f72 4661 6365 4365 6e74 ightsForFaceCent │ │ │ │ -00010380: 6572 7328 3c73 7061 6e20 636c 6173 733d ers(false< │ │ │ │ -000103a0: 2f73 7061 6e3e 293b 3c2f 6469 763e 0a3c /span>);
.< │ │ │ │ -000103b0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -000103c0: 3e3c 6120 6964 3d22 6c30 3034 3030 2220 > 400
.
401 │ │ │ │ -00010460: 2020 203c 7370 616e 2063 6c61 7373 3d22 // See │ │ │ │ -00010480: 206e 6f74 6520 6162 6f76 6520 7265 6761 note above rega │ │ │ │ -00010490: 7264 696e 6720 7363 616c 6520 6661 6374 rding scale fact │ │ │ │ -000104a0: 6f72 206f 6620 332e 303a 3c2f 7370 616e or of 3.0:
.
│ │ │ │ -00010500: 2020 3430 323c 2f73 7061 6e3e 2020 2020 402 │ │ │ │ -00010510: 7461 6e31 4d61 736b 2e56 6572 7465 7857 tan1Mask.VertexW │ │ │ │ -00010520: 6569 6768 7428 3029 203d 202d 332e 3066 eight(0) = -3.0f │ │ │ │ -00010530: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00010580: 2020 3430 333c 2f73 7061 6e3e 2020 2020 403 │ │ │ │ -00010590: 7461 6e31 4d61 736b 2e45 6467 6557 6569 tan1Mask.EdgeWei │ │ │ │ -000105a0: 6768 7428 3029 2020 203d 2020 332e 3066 ght(0) = 3.0f │ │ │ │ -000105b0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00010600: 2020 3430 343c 2f73 7061 6e3e 2020 2020 404 │ │ │ │ -00010610: 7461 6e31 4d61 736b 2e45 6467 6557 6569 tan1Mask.EdgeWei │ │ │ │ -00010620: 6768 7428 3129 2020 203d 2020 302e 3066 ght(1) = 0.0f │ │ │ │ -00010630: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00010680: 2020 3430 353c 2f73 7061 6e3e 203c 2f64 405 .
40 │ │ │ │ -000106e0: 363c 2f73 7061 6e3e 2020 2020 7461 6e32 6 tan2 │ │ │ │ -000106f0: 4d61 736b 2e56 6572 7465 7857 6569 6768 Mask.VertexWeigh │ │ │ │ -00010700: 7428 3029 203d 202d 332e 3066 3b3c 2f64 t(0) = -3.0f;.
40 │ │ │ │ -00010760: 373c 2f73 7061 6e3e 2020 2020 7461 6e32 7 tan2 │ │ │ │ -00010770: 4d61 736b 2e45 6467 6557 6569 6768 7428 Mask.EdgeWeight( │ │ │ │ -00010780: 3029 2020 203d 2020 302e 3066 3b3c 2f64 0) = 0.0f;.
40 │ │ │ │ -000107e0: 383c 2f73 7061 6e3e 2020 2020 7461 6e32 8 tan2 │ │ │ │ -000107f0: 4d61 736b 2e45 6467 6557 6569 6768 7428 Mask.EdgeWeight( │ │ │ │ -00010800: 3129 2020 203d 2020 332e 3066 3b3c 2f64 1) = 3.0f;.
40 │ │ │ │ -00010860: 393c 2f73 7061 6e3e 203c 2f64 6976 3e0a 9
. │ │ │ │ -00010870: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -000108a0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 410 // │ │ │ │ -000108e0: 2020 5368 6f75 6c64 2062 6520 6174 206c Should be at l │ │ │ │ -000108f0: 6561 7374 2032 2065 6467 6573 202d 2d20 east 2 edges -- │ │ │ │ -00010900: 6265 2073 7572 6520 746f 2063 6c65 6172 be sure to clear │ │ │ │ -00010910: 2077 6569 6768 7473 2066 6f72 2061 6e79 weights for any │ │ │ │ -00010920: 206d 6f72 653a 3c2f 7370 616e 3e3c 2f64 more:.
41 │ │ │ │ -00010980: 313c 2f73 7061 6e3e 2020 2020 3c73 7061 1 for │ │ │ │ -000109b0: 2028 3c73 7061 6e20 636c 6173 733d 226b (int< │ │ │ │ -000109d0: 2f73 7061 6e3e 2069 203d 2032 3b20 6920 /span> i = 2; i │ │ │ │ -000109e0: 266c 743b 2076 616c 656e 6365 3b20 2b2b < valence; ++ │ │ │ │ -000109f0: 6929 207b 3c2f 6469 763e 0a3c 6469 7620 i) {
.
412 │ │ │ │ -00010a50: 2020 2020 2020 2074 616e 314d 6173 6b2e tan1Mask. │ │ │ │ -00010a60: 4564 6765 5765 6967 6874 2869 2920 3d20 EdgeWeight(i) = │ │ │ │ -00010a70: 302e 3066 3b3c 2f64 6976 3e0a 3c64 6976 0.0f;
.
< │ │ │ │ -00010ab0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00010ac0: 6e6f 223e 2020 3431 333c 2f73 7061 6e3e no"> 413 │ │ │ │ -00010ad0: 2020 2020 2020 2020 7461 6e32 4d61 736b tan2Mask │ │ │ │ -00010ae0: 2e45 6467 6557 6569 6768 7428 6929 203d .EdgeWeight(i) = │ │ │ │ -00010af0: 2030 2e30 663b 3c2f 6469 763e 0a3c 6469 0.0f;
.< │ │ │ │ -00010b10: 6120 6964 3d22 6c30 3034 3134 2220 6e61 a id="l00414" na │ │ │ │ -00010b20: 6d65 3d22 6c30 3034 3134 223e 3c2f 613e me="l00414"> │ │ │ │ -00010b30: 3c73 7061 6e20 636c 6173 733d 226c 696e 414 }
.< │ │ │ │ -00010b70: 6120 6964 3d22 6c30 3034 3135 2220 6e61 a id="l00415" na │ │ │ │ -00010b80: 6d65 3d22 6c30 3034 3135 223e 3c2f 613e me="l00415"> │ │ │ │ -00010b90: 3c73 7061 6e20 636c 6173 733d 226c 696e 415}
.
. │ │ │ │ -00010bc0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
< │ │ │ │ -00010c50: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00010c60: 6e6f 223e 2020 3431 373c 2f73 7061 6e3e no"> 417 │ │ │ │ -00010c70: 3c73 7061 6e20 636c 6173 733d 226b 6579 template <>.
4 │ │ │ │ -00010cf0: 3138 3c2f 7370 616e 3e3c 7370 616e 2063 18t │ │ │ │ -00010d10: 656d 706c 6174 653c 2f73 7061 6e3e 2026 emplate & │ │ │ │ -00010d20: 6c74 3b3c 7370 616e 2063 6c61 7373 3d22 lt;typenam │ │ │ │ -00010d40: 653c 2f73 7061 6e3e 2056 4552 5445 582c e VERTEX, │ │ │ │ -00010d50: 203c 7370 616e 2063 6c61 7373 3d22 6b65 typename< │ │ │ │ -00010d70: 2f73 7061 6e3e 204d 4153 4b26 6774 3b3c /span> MASK>< │ │ │ │ -00010d80: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00010dd0: 3431 393c 2f73 7061 6e3e 3c73 7061 6e20 419 │ │ │ │ -00010df0: 696e 6c69 6e65 3c2f 7370 616e 3e20 3c73 inline void
.
. │ │ │ │ -00010e70: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
│ │ │ │ -00011020: 2020 3432 313c 2f73 7061 6e3e 2020 2020 421 │ │ │ │ -00011030: 2020 2020 4d41 534b 2661 6d70 3b20 7461 MASK& ta │ │ │ │ -00011040: 6e31 4d61 736b 2c20 4d41 534b 2661 6d70 n1Mask, MASK& │ │ │ │ -00011050: 3b20 7461 6e32 4d61 736b 2c20 3c73 7061 ; tan2Mask, int │ │ │ │ -00011080: 203c 7370 616e 2063 6c61 7373 3d22 6b65 const creaseEnds[2 │ │ │ │ -000110b0: 5d29 3c73 7061 6e20 636c 6173 733d 226b ]) const < │ │ │ │ -000110d0: 2f73 7061 6e3e 7b3c 2f64 6976 3e0a 3c64 /span>{
. 294 │ │ │ │ +0000c6a0: 2020 207d 3c2f 6469 763e 0a3c 6469 7620 }
.
295 │ │ │ │ +0000c700: 2020 2020 2020 2020 2020 207d 3c2f 6469 }.
296 │ │ │ │ +0000c760: 3c2f 7370 616e 3e20 2020 2020 2020 207d } │ │ │ │ +0000c770: 3c2f 6469 763e 0a3c 2f64 6976 3e0a 3c64
.
. │ │ │ │ +0000c790: 3c61 2069 643d 226c 3030 3239 3722 206e 297
.
298 │ │ │ │ +0000c830: 2020 3c73 7061 6e20 636c 6173 733d 226b private< │ │ │ │ +0000c850: 2f73 7061 6e3e 3a3c 2f64 6976 3e0a 3c64 /span>:
. │ │ │ │ +0000c870: 3c61 2069 643d 226c 3030 3239 3922 206e 299 Weight │ │ │ │ +0000c910: 3c2f 613e 2a20 5f76 5765 6967 6874 733b * _vWeights; │ │ │ │ +0000c920: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0000c970: 2033 3030 3c2f 7370 616e 3e20 2020 2020 300 │ │ │ │ +0000c980: 2020 203c 6120 636c 6173 733d 2263 6f64 Weight* _ │ │ │ │ +0000c9e0: 6557 6569 6768 7473 3b3c 2f64 6976 3e0a eWeights;
. │ │ │ │ +0000c9f0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
302 │ │ │ │ +0000cb10: 2020 2020 203c 7370 616e 2063 6c61 7373 i │ │ │ │ +0000cb30: 6e74 3c2f 7370 616e 3e20 5f76 436f 756e nt _vCoun │ │ │ │ +0000cb40: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
303 │ │ │ │ +0000cba0: 2020 2020 203c 7370 616e 2063 6c61 7373 i │ │ │ │ +0000cbc0: 6e74 3c2f 7370 616e 3e20 5f65 436f 756e nt _eCoun │ │ │ │ +0000cbd0: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
304 │ │ │ │ +0000cc30: 2020 2020 203c 7370 616e 2063 6c61 7373 i │ │ │ │ +0000cc50: 6e74 3c2f 7370 616e 3e20 5f66 436f 756e nt _fCoun │ │ │ │ +0000cc60: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
305 │ │ │ │ +0000ccc0: 2020 2020 203c 7370 616e 2063 6c61 7373 b │ │ │ │ +0000cce0: 6f6f 6c3c 2f73 7061 6e3e 205f 6657 6569 ool _fWei │ │ │ │ +0000ccf0: 6768 7473 466f 7243 656e 7465 7273 3b3c ghtsForCenters;< │ │ │ │ +0000cd00: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0000cd50: 3330 363c 2f73 7061 6e3e 2020 2020 7d3b 306 }; │ │ │ │ +0000cd60: 3c2f 6469 763e 0a3c 2f64 6976 3e0a 3c64
.
. │ │ │ │ +0000cd80: 3c61 2069 643d 226c 3030 3330 3722 206e 307};
.
.
308< │ │ │ │ +0000ce20: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ +0000ce40: 3c61 2069 643d 226c 3030 3330 3922 206e 309
.
310//.
31 │ │ │ │ +0000cf50: 313c 2f73 7061 6e3e 3c73 7061 6e20 636c 1// │ │ │ │ +0000cf70: 2020 4372 6561 7365 2061 6e64 2063 6f72 Crease and cor │ │ │ │ +0000cf80: 6e65 7220 6d61 736b 7320 6172 6520 636f ner masks are co │ │ │ │ +0000cf90: 6d6d 6f6e 2074 6f20 6d6f 7374 2073 6368 mmon to most sch │ │ │ │ +0000cfa0: 656d 6573 202d 2d20 7468 6520 7265 7374 emes -- the rest │ │ │ │ +0000cfb0: 206e 6565 6420 746f 2062 6520 7072 6f76 need to be prov │ │ │ │ +0000cfc0: 6964 6564 3c2f 7370 616e 3e3c 2f64 6976 ided
.
312< │ │ │ │ +0000d020: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ +0000d040: 666f 7220 6561 6368 2053 6368 656d 6520 for each Scheme │ │ │ │ +0000d050: 7370 6563 6961 6c69 7a61 7469 6f6e 2e3c specialization.< │ │ │ │ +0000d060: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ +0000d080: 6120 6964 3d22 6c30 3033 3133 2220 6e61 a id="l00313" na │ │ │ │ +0000d090: 6d65 3d22 6c30 3033 3133 223e 3c2f 613e me="l00313"> │ │ │ │ +0000d0a0: 3c73 7061 6e20 636c 6173 733d 226c 696e 313// │ │ │ │ +0000d0e0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0000d130: 2033 3134 3c2f 7370 616e 3e3c 7370 616e 314template │ │ │ │ +0000d160: 2026 6c74 3b53 6368 656d 6554 7970 6520 <SchemeType │ │ │ │ +0000d170: 5343 4845 4d45 2667 743b 3c2f 6469 763e SCHEME>
│ │ │ │ +0000d180: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +0000d1b0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 315templ │ │ │ │ +0000d1f0: 6174 653c 2f73 7061 6e3e 2026 6c74 3b3c ate << │ │ │ │ +0000d200: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +0000d210: 6f72 6422 3e74 7970 656e 616d 653c 2f73 ord">typename EDGE, typename │ │ │ │ +0000d250: 204d 4153 4b26 6774 3b3c 2f64 6976 3e0a MASK>
. │ │ │ │ +0000d260: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +0000d290: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 316inline │ │ │ │ +0000d2d0: 3c2f 7370 616e 3e20 3c73 7061 6e20 636c void.
.
317 │ │ │ │ +0000d3e0: 3c2f 7370 616e 3e3c 6120 636c 6173 733d Scheme&l │ │ │ │ +0000d440: 743b 5343 4845 4d45 2667 743b 3a3a 6173 t;SCHEME>::as │ │ │ │ +0000d450: 7369 676e 4372 6561 7365 4d61 736b 466f signCreaseMaskFo │ │ │ │ +0000d460: 7245 6467 653c 2f61 3e28 4544 4745 203c rEdge(EDGE < │ │ │ │ +0000d470: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +0000d480: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const&, MASK& │ │ │ │ +0000d4a0: 3b20 6d61 736b 293c 7370 616e 2063 6c61 ; mask) co │ │ │ │ +0000d4c0: 6e73 7420 3c2f 7370 616e 3e7b 3c2f 6469 nst {.
318 │ │ │ │ +0000d520: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ +0000d530: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0000d540: 3e3c 6120 6964 3d22 6c30 3033 3139 2220 > 319
mask.SetN │ │ │ │ +0000d590: 756d 5665 7274 6578 5765 6967 6874 7328 umVertexWeights( │ │ │ │ +0000d5a0: 3229 3b3c 2f64 6976 3e0a 3c64 6976 2063 2);
.
320 │ │ │ │ +0000d600: 2020 6d61 736b 2e53 6574 4e75 6d45 6467 mask.SetNumEdg │ │ │ │ +0000d610: 6557 6569 6768 7473 2830 293b 3c2f 6469 eWeights(0);.
321 │ │ │ │ +0000d670: 3c2f 7370 616e 3e20 2020 206d 6173 6b2e mask. │ │ │ │ +0000d680: 5365 744e 756d 4661 6365 5765 6967 6874 SetNumFaceWeight │ │ │ │ +0000d690: 7328 3029 3b3c 2f64 6976 3e0a 3c64 6976 s(0);
.
< │ │ │ │ +0000d6d0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0000d6e0: 6e6f 223e 2020 3332 323c 2f73 7061 6e3e no"> 322 │ │ │ │ +0000d6f0: 2020 2020 6d61 736b 2e53 6574 4661 6365 mask.SetFace │ │ │ │ +0000d700: 5765 6967 6874 7346 6f72 4661 6365 4365 WeightsForFaceCe │ │ │ │ +0000d710: 6e74 6572 7328 3c73 7061 6e20 636c 6173 nters(fals │ │ │ │ +0000d730: 653c 2f73 7061 6e3e 293b 3c2f 6469 763e e);
│ │ │ │ +0000d740: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ +0000d7b0: 6120 6964 3d22 6c30 3033 3234 2220 6e61 a id="l00324" na │ │ │ │ +0000d7c0: 6d65 3d22 6c30 3033 3234 223e 3c2f 613e me="l00324"> │ │ │ │ +0000d7d0: 3c73 7061 6e20 636c 6173 733d 226c 696e 324 mask.Vertex │ │ │ │ +0000d800: 5765 6967 6874 2830 2920 3d20 302e 3566 Weight(0) = 0.5f │ │ │ │ +0000d810: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +0000d860: 2020 3332 353c 2f73 7061 6e3e 2020 2020 325 │ │ │ │ +0000d870: 6d61 736b 2e56 6572 7465 7857 6569 6768 mask.VertexWeigh │ │ │ │ +0000d880: 7428 3129 203d 2030 2e35 663b 3c2f 6469 t(1) = 0.5f;.
326 │ │ │ │ +0000d8e0: 3c2f 7370 616e 3e7d 3c2f 6469 763e 0a3c }
.< │ │ │ │ +0000d8f0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0000d940: 3332 373c 2f73 7061 6e3e 203c 2f64 6976 327
.
328< │ │ │ │ +0000d9a0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>temp │ │ │ │ +0000d9c0: 6c61 7465 3c2f 7370 616e 3e20 266c 743b late < │ │ │ │ +0000d9d0: 5363 6865 6d65 5479 7065 2053 4348 454d SchemeType SCHEM │ │ │ │ +0000d9e0: 4526 6774 3b3c 2f64 6976 3e0a 3c64 6976 E>
.
< │ │ │ │ +0000da20: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0000da30: 6e6f 223e 2020 3332 393c 2f73 7061 6e3e no"> 329 │ │ │ │ +0000da40: 3c73 7061 6e20 636c 6173 733d 226b 6579 template < │ │ │ │ +0000da80: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ +0000da90: 5645 5254 4558 2c20 3c73 7061 6e20 636c VERTEX, ty │ │ │ │ +0000dab0: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ +0000dac0: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ +0000dae0: 6120 6964 3d22 6c30 3033 3330 2220 6e61 a id="l00330" na │ │ │ │ +0000daf0: 6d65 3d22 6c30 3033 3330 223e 3c2f 613e me="l00330"> │ │ │ │ +0000db00: 3c73 7061 6e20 636c 6173 733d 226c 696e 330inline v │ │ │ │ +0000db60: 6f69 643c 2f73 7061 6e3e 3c2f 6469 763e oid
│ │ │ │ +0000db70: 0a3c 6469 7620 636c 6173 733d 2266 6f6c .
.
< │ │ │ │ +0000dc00: 6120 636c 6173 733d 226c 696e 6522 2068 a class="line" h │ │ │ │ +0000dc10: 7265 663d 2261 3031 3334 312e 6874 6d6c ref="a01341.html │ │ │ │ +0000dc20: 2361 3737 3634 3466 3639 6564 6530 3366 #a77644f69ede03f │ │ │ │ +0000dc30: 6136 3232 3232 6436 3061 3939 3937 3032 a62222d60a999702 │ │ │ │ +0000dc40: 3338 223e 2020 3333 313c 2f61 3e3c 2f73 38"> 331Scheme<S │ │ │ │ +0000dcb0: 4348 454d 4526 6774 3b3a 3a61 7373 6967 CHEME>::assig │ │ │ │ +0000dcc0: 6e43 6f72 6e65 724d 6173 6b46 6f72 5665 nCornerMaskForVe │ │ │ │ +0000dcd0: 7274 6578 3c2f 613e 2856 4552 5445 5820 rtex(VERTEX │ │ │ │ +0000dce0: 3c73 7061 6e20 636c 6173 733d 226b 6579 const&, MASK&am │ │ │ │ +0000dd10: 703b 206d 6173 6b29 3c73 7061 6e20 636c p; mask) c │ │ │ │ +0000dd30: 6f6e 7374 203c 2f73 7061 6e3e 7b3c 2f64 onst {.
33 │ │ │ │ +0000dd90: 323c 2f73 7061 6e3e 203c 2f64 6976 3e0a 2
. │ │ │ │ +0000dda0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
334 │ │ │ │ +0000de70: 2020 206d 6173 6b2e 5365 744e 756d 4564 mask.SetNumEd │ │ │ │ +0000de80: 6765 5765 6967 6874 7328 3029 3b3c 2f64 geWeights(0);.
33 │ │ │ │ +0000dee0: 353c 2f73 7061 6e3e 2020 2020 6d61 736b 5 mask │ │ │ │ +0000def0: 2e53 6574 4e75 6d46 6163 6557 6569 6768 .SetNumFaceWeigh │ │ │ │ +0000df00: 7473 2830 293b 3c2f 6469 763e 0a3c 6469 ts(0);
.< │ │ │ │ +0000df20: 6120 6964 3d22 6c30 3033 3336 2220 6e61 a id="l00336" na │ │ │ │ +0000df30: 6d65 3d22 6c30 3033 3336 223e 3c2f 613e me="l00336"> │ │ │ │ +0000df40: 3c73 7061 6e20 636c 6173 733d 226c 696e 336 mask.SetFac │ │ │ │ +0000df70: 6557 6569 6768 7473 466f 7246 6163 6543 eWeightsForFaceC │ │ │ │ +0000df80: 656e 7465 7273 283c 7370 616e 2063 6c61 enters(fal │ │ │ │ +0000dfa0: 7365 3c2f 7370 616e 3e29 3b3c 2f64 6976 se);
.
337< │ │ │ │ +0000e000: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ +0000e020: 3c61 2069 643d 226c 3030 3333 3822 206e 338 mask.Verte │ │ │ │ +0000e070: 7857 6569 6768 7428 3029 203d 2031 2e30 xWeight(0) = 1.0 │ │ │ │ +0000e080: 663b 3c2f 6469 763e 0a3c 6469 7620 636c f;
.
339}.
.
< │ │ │ │ +0000e120: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0000e130: 6e6f 223e 2020 3334 303c 2f73 7061 6e3e no"> 340 │ │ │ │ +0000e140: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ +0000e190: 2020 3334 313c 2f73 7061 6e3e 203c 2f64 341 .
34 │ │ │ │ +0000e1f0: 323c 2f73 7061 6e3e 3c73 7061 6e20 636c 2// │ │ │ │ +0000e210: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +0000e230: 3c61 2069 643d 226c 3030 3334 3322 206e 343// The │ │ │ │ +0000e290: 636f 6d70 7574 6174 696f 6e20 6f66 2061 computation of a │ │ │ │ +0000e2a0: 2066 6163 652d 7665 7274 6578 206d 6173 face-vertex mas │ │ │ │ +0000e2b0: 6b20 6973 2074 7269 7669 616c 2061 6e64 k is trivial and │ │ │ │ +0000e2c0: 2063 6f6e 7369 7374 656e 7420 666f 7220 consistent for │ │ │ │ +0000e2d0: 616c 6c20 7363 6865 6d65 733a 3c2f 7370 all schemes:
.
344//.
34 │ │ │ │ +0000e3b0: 353c 2f73 7061 6e3e 3c73 7061 6e20 636c 5te │ │ │ │ +0000e3d0: 6d70 6c61 7465 3c2f 7370 616e 3e20 266c mplate &l │ │ │ │ +0000e3e0: 743b 5363 6865 6d65 5479 7065 2053 4348 t;SchemeType SCH │ │ │ │ +0000e3f0: 454d 4526 6774 3b3c 2f64 6976 3e0a 3c64 EME>
. │ │ │ │ +0000e410: 3c61 2069 643d 226c 3030 3334 3622 206e 346template │ │ │ │ +0000e470: 3c2f 7370 616e 3e20 266c 743b 3c73 7061 <typename FACE, ty │ │ │ │ +0000e4c0: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ +0000e4d0: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ +0000e4f0: 6120 6964 3d22 6c30 3033 3437 2220 6e61 a id="l00347" na │ │ │ │ +0000e500: 6d65 3d22 6c30 3033 3437 223e 3c2f 613e me="l00347"> │ │ │ │ +0000e510: 3c73 7061 6e20 636c 6173 733d 226c 696e 347void< │ │ │ │ +0000e550: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
..
│ │ │ │ +0000e630: 2020 3334 383c 2f61 3e3c 2f73 7061 6e3e 348 │ │ │ │ +0000e640: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Scheme<SCHEM │ │ │ │ +0000e6a0: 4526 6774 3b3a 3a43 6f6d 7075 7465 4661 E>::ComputeFa │ │ │ │ +0000e6b0: 6365 5665 7274 6578 4d61 736b 3c2f 613e ceVertexMask │ │ │ │ +0000e6c0: 2846 4143 4520 3c73 7061 6e20 636c 6173 (FACE cons │ │ │ │ +0000e6e0: 743c 2f73 7061 6e3e 2661 6d70 3b20 6661 t& fa │ │ │ │ +0000e6f0: 6365 2c20 4d41 534b 2661 6d70 3b20 6d61 ce, MASK& ma │ │ │ │ +0000e700: 736b 293c 7370 616e 2063 6c61 7373 3d22 sk) const │ │ │ │ +0000e720: 3c2f 7370 616e 3e7b 3c2f 6469 763e 0a3c {
.< │ │ │ │ +0000e730: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0000e740: 3e3c 6120 6964 3d22 6c30 3033 3439 2220 > 349
.
350 │ │ │ │ +0000e7e0: 2020 203c 7370 616e 2063 6c61 7373 3d22 int │ │ │ │ +0000e800: 3c2f 7370 616e 3e20 7665 7274 436f 756e vertCoun │ │ │ │ +0000e810: 7420 3d20 6661 6365 2e47 6574 4e75 6d56 t = face.GetNumV │ │ │ │ +0000e820: 6572 7469 6365 7328 293b 3c2f 6469 763e ertices();
│ │ │ │ +0000e830: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ +0000e8a0: 6120 6964 3d22 6c30 3033 3532 2220 6e61 a id="l00352" na │ │ │ │ +0000e8b0: 6d65 3d22 6c30 3033 3532 223e 3c2f 613e me="l00352"> │ │ │ │ +0000e8c0: 3c73 7061 6e20 636c 6173 733d 226c 696e 352 mask.SetNum │ │ │ │ +0000e8f0: 5665 7274 6578 5765 6967 6874 7328 7665 VertexWeights(ve │ │ │ │ +0000e900: 7274 436f 756e 7429 3b3c 2f64 6976 3e0a rtCount);
. │ │ │ │ +0000e910: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
354 │ │ │ │ +0000e9e0: 206d 6173 6b2e 5365 744e 756d 4661 6365 mask.SetNumFace │ │ │ │ +0000e9f0: 5765 6967 6874 7328 3029 3b3c 2f64 6976 Weights(0);
.
355< │ │ │ │ +0000ea50: 2f73 7061 6e3e 2020 2020 6d61 736b 2e53 /span> mask.S │ │ │ │ +0000ea60: 6574 4661 6365 5765 6967 6874 7346 6f72 etFaceWeightsFor │ │ │ │ +0000ea70: 4661 6365 4365 6e74 6572 7328 3c73 7061 FaceCenters(false); │ │ │ │ +0000eaa0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0000eaf0: 2033 3536 3c2f 7370 616e 3e20 3c2f 6469 356 .
357 │ │ │ │ +0000eb50: 3c2f 7370 616e 3e20 2020 203c 7370 616e typename │ │ │ │ +0000eb80: 204d 4153 4b3a 3a57 6569 6768 7420 7657 MASK::Weight vW │ │ │ │ +0000eb90: 6569 6768 7420 3d20 312e 3066 202f 2028 eight = 1.0f / ( │ │ │ │ +0000eba0: 3c73 7061 6e20 636c 6173 733d 226b 6579 typename MASK::Weig │ │ │ │ +0000ebd0: 6874 2920 7665 7274 436f 756e 743b 3c2f ht) vertCount;.
3 │ │ │ │ +0000ec30: 3538 3c2f 7370 616e 3e20 2020 203c 7370 58 for (int │ │ │ │ +0000ec80: 3c2f 7370 616e 3e20 6920 3d20 303b 2069 i = 0; i │ │ │ │ +0000ec90: 2026 6c74 3b20 7665 7274 436f 756e 743b < vertCount; │ │ │ │ +0000eca0: 202b 2b69 2920 7b3c 2f64 6976 3e0a 3c64 ++i) {
. │ │ │ │ +0000ecc0: 3c61 2069 643d 226c 3030 3335 3922 206e 359 mask.V │ │ │ │ +0000ed10: 6572 7465 7857 6569 6768 7428 6929 203d ertexWeight(i) = │ │ │ │ +0000ed20: 2076 5765 6967 6874 3b3c 2f64 6976 3e0a vWeight;
. │ │ │ │ +0000ed30: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
. │ │ │ │ +0000ed90: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
..
362 │ │ │ │ +0000ee40: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ +0000ee50: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0000ee60: 3e3c 6120 6964 3d22 6c30 3033 3633 2220 > 363
.
364< │ │ │ │ +0000ef00: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +0000ef10: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
3 │ │ │ │ +0000ef70: 3635 3c2f 7370 616e 3e3c 7370 616e 2063 65/ │ │ │ │ +0000ef90: 2f20 2054 6865 2063 6f6d 7075 7461 7469 / The computati │ │ │ │ +0000efa0: 6f6e 206f 6620 616e 2065 6467 652d 7665 on of an edge-ve │ │ │ │ +0000efb0: 7274 6578 206d 6173 6b20 7265 7175 6972 rtex mask requir │ │ │ │ +0000efc0: 6573 2069 6e73 7065 6374 696f 6e20 6f66 es inspection of │ │ │ │ +0000efd0: 2073 6861 7270 6e65 7373 2076 616c 7565 sharpness value │ │ │ │ +0000efe0: 7320 746f 3c2f 7370 616e 3e3c 2f64 6976 s to
.
366< │ │ │ │ +0000f040: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ +0000f060: 6465 7465 726d 696e 6520 6966 2073 6d6f determine if smo │ │ │ │ +0000f070: 6f74 6820 6f72 2061 2063 7265 6173 652c oth or a crease, │ │ │ │ +0000f080: 2061 6e64 2061 6c73 6f20 746f 2064 6574 and also to det │ │ │ │ +0000f090: 6563 7420 616e 6420 6170 706c 7920 6120 ect and apply a │ │ │ │ +0000f0a0: 7472 616e 7369 7469 6f6e 2066 726f 6d20 transition from │ │ │ │ +0000f0b0: 613c 2f73 7061 6e3e 3c2f 6469 763e 0a3c a
.< │ │ │ │ +0000f0c0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0000f0d0: 3e3c 6120 6964 3d22 6c30 3033 3637 2220 > 367// cre │ │ │ │ +0000f130: 6173 6520 746f 2073 6d6f 6f74 682e 2020 ase to smooth. │ │ │ │ +0000f140: 5573 696e 6720 7468 6520 7072 6f74 6563 Using the protec │ │ │ │ +0000f150: 7465 6420 6d65 7468 6f64 7320 746f 2061 ted methods to a │ │ │ │ +0000f160: 7373 6967 6e20 7468 6520 7370 6563 6966 ssign the specif │ │ │ │ +0000f170: 6963 206d 6173 6b73 2028 6f6e 6c79 3c2f ic masks (only
.
< │ │ │ │ +0000f1c0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0000f1d0: 6e6f 223e 2020 3336 383c 2f73 7061 6e3e no"> 368 │ │ │ │ +0000f1e0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // two -- │ │ │ │ +0000f200: 2073 6d6f 6f74 6820 6f72 2063 7265 6173 smooth or creas │ │ │ │ +0000f210: 6529 2074 6869 7320 696d 706c 656d 656e e) this implemen │ │ │ │ +0000f220: 7461 7469 6f6e 2073 686f 756c 6420 7365 tation should se │ │ │ │ +0000f230: 7276 6520 616c 6c20 6e6f 6e2d 6c69 6e65 rve all non-line │ │ │ │ +0000f240: 6172 2073 6368 656d 6573 3c2f 7370 616e ar schemes
.
│ │ │ │ +0000f2a0: 2020 3336 393c 2f73 7061 6e3e 3c73 7061 369// (currently │ │ │ │ +0000f2d0: 2043 6174 6d61 726b 2061 6e64 204c 6f6f Catmark and Loo │ │ │ │ +0000f2e0: 7029 2061 6e64 206f 6e6c 7920 6e65 6564 p) and only need │ │ │ │ +0000f2f0: 7320 746f 2062 6520 7370 6563 6961 6c69 s to be speciali │ │ │ │ +0000f300: 7a65 6420 666f 7220 4269 6c69 6e65 6172 zed for Bilinear │ │ │ │ +0000f310: 2074 6f3c 2f73 7061 6e3e 3c2f 6469 763e to
│ │ │ │ +0000f320: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +0000f350: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 370// t │ │ │ │ +0000f390: 7269 7669 616c 697a 6520 6974 2074 6f20 rivialize it to │ │ │ │ +0000f3a0: 7468 6520 6372 6561 7365 2063 6173 652e the crease case. │ │ │ │ +0000f3b0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +0000f3d0: 3c61 2069 643d 226c 3030 3337 3122 206e 371//
.
│ │ │ │ +0000f480: 2020 3337 323c 2f73 7061 6e3e 3c73 7061 372// The implem │ │ │ │ +0000f4b0: 656e 7461 7469 6f6e 2068 6572 6520 6973 entation here is │ │ │ │ +0000f4c0: 2073 6c69 6768 746c 7920 636f 6d70 6c69 slightly compli │ │ │ │ +0000f4d0: 6361 7465 6420 6279 2063 6f6d 6269 6e69 cated by combini │ │ │ │ +0000f4e0: 6e67 2074 776f 2073 6365 6e61 7269 6f73 ng two scenarios │ │ │ │ +0000f4f0: 2069 6e74 6f20 613c 2f73 7061 6e3e 3c2f into a.
3 │ │ │ │ +0000f550: 3733 3c2f 7370 616e 3e3c 7370 616e 2063 73/ │ │ │ │ +0000f570: 2f20 2073 696e 676c 6520 696d 706c 656d / single implem │ │ │ │ +0000f580: 656e 7461 7469 6f6e 202d 2d20 6569 7468 entation -- eith │ │ │ │ +0000f590: 6572 2074 6865 2063 616c 6c65 7220 6b6e er the caller kn │ │ │ │ +0000f5a0: 6f77 7320 7468 6520 7061 7265 6e74 2061 ows the parent a │ │ │ │ +0000f5b0: 6e64 2063 6869 6c64 2072 756c 6573 2061 nd child rules a │ │ │ │ +0000f5c0: 6e64 3c2f 7370 616e 3e3c 2f64 6976 3e0a nd
. │ │ │ │ +0000f5d0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.< │ │ │ │ +0000f6a0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0000f6b0: 3e3c 6120 6964 3d22 6c30 3033 3735 2220 > 375// val │ │ │ │ +0000f710: 7565 732e 2020 426f 7468 2063 6173 6573 ues. Both cases │ │ │ │ +0000f720: 2069 6e63 6c75 6465 2071 7569 636b 2072 include quick r │ │ │ │ +0000f730: 6574 7572 6e20 6f6e 6365 2074 6865 2070 eturn once the p │ │ │ │ +0000f740: 6172 656e 7420 6973 2064 6574 6572 6d69 arent is determi │ │ │ │ +0000f750: 6e65 6420 746f 2062 653c 2f73 7061 6e3e ned to be │ │ │ │ +0000f760: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0000f7b0: 2033 3736 3c2f 7370 616e 3e3c 7370 616e 376// smooth or t │ │ │ │ +0000f7e0: 6865 2063 6869 6c64 2061 2063 7265 6173 he child a creas │ │ │ │ +0000f7f0: 652c 206c 6561 7669 6e67 2074 6865 2074 e, leaving the t │ │ │ │ +0000f800: 7261 6e73 6974 696f 6e61 6c20 6361 7365 ransitional case │ │ │ │ +0000f810: 2072 656d 6169 6e69 6e67 2e3c 2f73 7061 remaining.
.
377//.
378 │ │ │ │ +0000f8f0: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ +0000f910: 2054 6865 206f 7665 7261 6c6c 2070 726f The overall pro │ │ │ │ +0000f920: 6365 7373 2069 7320 6173 2066 6f6c 6c6f cess is as follo │ │ │ │ +0000f930: 7773 3a3c 2f73 7061 6e3e 3c2f 6469 763e ws:
│ │ │ │ +0000f940: 0a3c 6469 7620 636c 6173 733d 226c 696e .
.
380< │ │ │ │ +0000fa10: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +0000fa20: 656e 7422 3e2f 2f20 2020 2020 202d 2071 ent">// - q │ │ │ │ +0000fa30: 7569 636b 6c79 2064 6574 6563 7420 7468 uickly detect th │ │ │ │ +0000fa40: 6520 6d6f 7374 2063 6f6d 6d6f 6e20 7370 e most common sp │ │ │ │ +0000fa50: 6563 6966 6965 6420 6f72 2064 6574 6563 ecified or detec │ │ │ │ +0000fa60: 7465 6420 536d 6f6f 7468 2063 6173 6520 ted Smooth case │ │ │ │ +0000fa70: 616e 6420 7265 7475 726e 3c2f 7370 616e and return
.
│ │ │ │ +0000fad0: 2020 3338 313c 2f73 7061 6e3e 3c73 7061 381// - quic │ │ │ │ +0000fb00: 6b6c 7920 6465 7465 6374 2061 2066 756c kly detect a ful │ │ │ │ +0000fb10: 6c20 4372 6561 7365 2062 7920 6368 696c l Crease by chil │ │ │ │ +0000fb20: 6420 5275 6c65 2061 7373 6967 6e6d 656e d Rule assignmen │ │ │ │ +0000fb30: 7420 616e 6420 7265 7475 726e 3c2f 7370 t and return
.
382// - de │ │ │ │ +0000fbc0: 7465 726d 696e 6520 6672 6f6d 2073 6861 termine from sha │ │ │ │ +0000fbd0: 7270 6e65 7373 2069 6620 756e 7370 6563 rpness if unspec │ │ │ │ +0000fbe0: 6966 6965 6420 6368 696c 6420 6973 2061 ified child is a │ │ │ │ +0000fbf0: 2063 7265 6173 6520 2d2d 2072 6574 7572 crease -- retur │ │ │ │ +0000fc00: 6e20 6966 2073 6f3c 2f73 7061 6e3e 3c2f n if so.
3 │ │ │ │ +0000fc60: 3833 3c2f 7370 616e 3e3c 7370 616e 2063 83/ │ │ │ │ +0000fc80: 2f20 2020 2020 202d 2063 6f6d 7075 7465 / - compute │ │ │ │ +0000fc90: 2073 6d6f 6f74 6820 6d61 736b 2066 6f72 smooth mask for │ │ │ │ +0000fca0: 2063 6869 6c64 2061 6e64 2063 6f6d 6269 child and combi │ │ │ │ +0000fcb0: 6e65 2077 6974 6820 6372 6561 7365 2066 ne with crease f │ │ │ │ +0000fcc0: 726f 6d20 7061 7265 6e74 3c2f 7370 616e rom parent
.
│ │ │ │ +0000fd20: 2020 3338 343c 2f73 7061 6e3e 3c73 7061 384//
.
385< │ │ │ │ +0000fda0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ +0000fdc0: 5573 6167 6520 6f66 2074 6865 2070 6172 Usage of the par │ │ │ │ +0000fdd0: 656e 7420 5275 6c65 2068 6572 6520 616c ent Rule here al │ │ │ │ +0000fde0: 6c6f 7773 2073 6f6d 6520 6d69 7375 7365 lows some misuse │ │ │ │ +0000fdf0: 2069 6e20 7468 6174 206f 6e6c 7920 7468 in that only th │ │ │ │ +0000fe00: 7265 6520 6f66 2066 6976 6520 706f 7373 ree of five poss │ │ │ │ +0000fe10: 6962 6c65 3c2f 7370 616e 3e3c 2f64 6976 ible
.
386< │ │ │ │ +0000fe70: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ +0000fe90: 6173 7369 676e 6d65 6e74 7320 6172 6520 assignments are │ │ │ │ +0000fea0: 6c65 6769 7469 6d61 7465 2066 6f72 2074 legitimate for t │ │ │ │ +0000feb0: 6865 2070 6172 656e 7420 616e 6420 666f he parent and fo │ │ │ │ +0000fec0: 7572 2066 6f72 2074 6865 2063 6869 6c64 ur for the child │ │ │ │ +0000fed0: 2028 4461 7274 2062 6569 6e67 206f 6e6c (Dart being onl │ │ │ │ +0000fee0: 793c 2f73 7061 6e3e 3c2f 6469 763e 0a3c y
.< │ │ │ │ +0000fef0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0000ff00: 3e3c 6120 6964 3d22 6c30 3033 3837 2220 > 387
// val │ │ │ │ +0000ff60: 6964 2066 6f72 2074 6865 2063 6869 6c64 id for the child │ │ │ │ +0000ff70: 2061 6e64 2043 6f72 6e65 7220 666f 7220 and Corner for │ │ │ │ +0000ff80: 6e65 6974 6865 7229 2e20 2052 6573 756c neither). Resul │ │ │ │ +0000ff90: 7473 2061 7265 2075 6e64 6566 696e 6564 ts are undefined │ │ │ │ +0000ffa0: 2069 6e20 7468 6573 6520 6361 7365 732e in these cases. │ │ │ │ +0000ffb0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +0000ffd0: 3c61 2069 643d 226c 3030 3338 3822 206e 388//
.
│ │ │ │ +00010080: 2020 3338 393c 2f73 7061 6e3e 3c73 7061 389template <SchemeType │ │ │ │ +000100c0: 2053 4348 454d 4526 6774 3b3c 2f64 6976 SCHEME>
.
390< │ │ │ │ +00010120: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>temp │ │ │ │ +00010140: 6c61 7465 3c2f 7370 616e 3e20 266c 743b late < │ │ │ │ +00010150: 3c73 7061 6e20 636c 6173 733d 226b 6579 typename EDGE, typename MASK>
│ │ │ │ +000101b0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +000101e0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 391v │ │ │ │ +00010220: 6f69 643c 2f73 7061 6e3e 3c2f 6469 763e oid
│ │ │ │ +00010230: 0a3c 6469 7620 636c 6173 733d 2266 6f6c .
.
< │ │ │ │ +000102c0: 6120 636c 6173 733d 226c 696e 6522 2068 a class="line" h │ │ │ │ +000102d0: 7265 663d 2261 3031 3334 312e 6874 6d6c ref="a01341.html │ │ │ │ +000102e0: 2361 3562 3561 3533 3737 6130 3165 6234 #a5b5a5377a01eb4 │ │ │ │ +000102f0: 6261 3434 3665 3137 3465 6666 3965 3435 ba446e174eff9e45 │ │ │ │ +00010300: 6163 223e 2020 3339 323c 2f61 3e3c 2f73 ac"> 392Scheme<S │ │ │ │ +00010370: 4348 454d 4526 6774 3b3a 3a43 6f6d 7075 CHEME>::Compu │ │ │ │ +00010380: 7465 4564 6765 5665 7274 6578 4d61 736b teEdgeVertexMask │ │ │ │ +00010390: 3c2f 613e 2845 4447 4520 3c73 7061 6e20 (EDGE │ │ │ │ +000103b0: 636f 6e73 743c 2f73 7061 6e3e 2661 6d70 const& │ │ │ │ +000103c0: 3b20 2020 2020 6564 6765 2c3c 2f64 6976 ; edge,
.
393< │ │ │ │ +00010420: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ +00010430: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00010440: 2020 2020 2020 2020 2020 2020 2020 204d M │ │ │ │ +00010450: 4153 4b26 616d 703b 2020 2020 2020 2020 ASK& │ │ │ │ +00010460: 2020 206d 6173 6b2c 3c2f 6469 763e 0a3c mask,
.< │ │ │ │ +00010470: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00010480: 3e3c 6120 6964 3d22 6c30 3033 3934 2220 > 394 │ │ │ │ +000104d0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +000104e0: 2020 2020 2020 2020 2020 2020 3c61 2063 │ │ │ │ +00010540: 4372 6561 7365 3a3a 5275 6c65 3c2f 613e Crease::Rule │ │ │ │ +00010550: 2070 6172 656e 7452 756c 652c 3c2f 6469 parentRule,.
395 │ │ │ │ +000105b0: 3c2f 7370 616e 3e20 2020 2020 2020 2020 │ │ │ │ +000105c0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +000105d0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +000105e0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Crease::Rule │ │ │ │ +00010640: 3c2f 613e 2063 6869 6c64 5275 6c65 293c childRule)< │ │ │ │ +00010650: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00010660: 6f72 6422 3e20 636f 6e73 7420 3c2f 7370 ord"> const {
.
396 │ │ │ │ +000106d0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00010720: 2033 3937 3c2f 7370 616e 3e20 2020 203c 397 < │ │ │ │ +00010730: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00010740: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
3 │ │ │ │ +000107a0: 3938 3c2f 7370 616e 3e20 2020 203c 7370 98 // If the pa │ │ │ │ +000107d0: 7265 6e74 2077 6173 2073 7065 6369 6669 rent was specifi │ │ │ │ +000107e0: 6564 206f 7220 6465 7465 726d 696e 6564 ed or determined │ │ │ │ +000107f0: 2074 6f20 6265 2053 6d6f 6f74 682c 2077 to be Smooth, w │ │ │ │ +00010800: 6520 6361 6e20 7175 6963 6b6c 7920 7265 e can quickly re │ │ │ │ +00010810: 7475 726e 3c2f 7370 616e 3e3c 2f64 6976 turn
.
399< │ │ │ │ +00010870: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ +00010890: 2f2f 2020 7769 7468 2061 2053 6d6f 6f74 // with a Smoot │ │ │ │ +000108a0: 6820 6d61 736b 2e20 204f 7468 6572 7769 h mask. Otherwi │ │ │ │ +000108b0: 7365 2074 6865 2070 6172 656e 7420 6973 se the parent is │ │ │ │ +000108c0: 2061 2063 7265 6173 6520 2d2d 2069 6620 a crease -- if │ │ │ │ +000108d0: 7468 6520 6368 696c 6420 7761 733c 2f73 the child was
.
400 │ │ │ │ +00010940: 2020 203c 7370 616e 2063 6c61 7373 3d22 // als │ │ │ │ +00010960: 6f20 7370 6563 6966 6965 6420 746f 2062 o specified to b │ │ │ │ +00010970: 6520 6120 6372 6561 7365 2c20 7765 2063 e a crease, we c │ │ │ │ +00010980: 616e 2071 7569 636b 6c79 2072 6574 7572 an quickly retur │ │ │ │ +00010990: 6e20 7769 7468 2061 2043 7265 6173 6520 n with a Crease │ │ │ │ +000109a0: 6d61 736b 2e3c 2f73 7061 6e3e 3c2f 6469 mask..
401 │ │ │ │ +00010a00: 3c2f 7370 616e 3e20 2020 203c 7370 616e //
│ │ │ │ +00010a30: 0a3c 6469 7620 636c 6173 733d 226c 696e ..
403< │ │ │ │ +00010ba0: 2f73 7061 6e3e 2020 2020 2020 2028 2870 /span> ((p │ │ │ │ +00010bb0: 6172 656e 7452 756c 6520 3d3d 203c 6120 arentRule == │ │ │ │ +00010c30: 4372 6561 7365 3a3a 5255 4c45 5f55 4e4b Crease::RULE_UNK │ │ │ │ +00010c40: 4e4f 574e 3c2f 613e 2920 2661 6d70 3b26 NOWN) && │ │ │ │ +00010c50: 616d 703b 2028 6564 6765 2e47 6574 5368 amp; (edge.GetSh │ │ │ │ +00010c60: 6172 706e 6573 7328 2920 266c 743b 3d20 arpness() <= │ │ │ │ +00010c70: 302e 3066 2929 2920 7b3c 2f64 6976 3e0a 0.0f))) {
. │ │ │ │ +00010c80: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
│ │ │ │ +00010d50: 2034 3035 3c2f 7370 616e 3e20 2020 2020 405 │ │ │ │ +00010d60: 2020 203c 7370 616e 2063 6c61 7373 3d22 ret │ │ │ │ +00010d80: 7572 6e3c 2f73 7061 6e3e 3b3c 2f64 6976 urn;
.
406< │ │ │ │ +00010de0: 2f73 7061 6e3e 2020 2020 7d3c 2f64 6976 /span> }
.
407< │ │ │ │ +00010e40: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> if (c │ │ │ │ +00010e70: 6869 6c64 5275 6c65 203d 3d20 3c61 2063 hildRule == C │ │ │ │ +00010ef0: 7265 6173 653a 3a52 554c 455f 4352 4541 rease::RULE_CREA │ │ │ │ +00010f00: 5345 3c2f 613e 2920 7b3c 2f64 6976 3e0a SE) {
. │ │ │ │ +00010f10: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
│ │ │ │ +00010fe0: 2034 3039 3c2f 7370 616e 3e20 2020 2020 409 │ │ │ │ +00010ff0: 2020 203c 7370 616e 2063 6c61 7373 3d22 ret │ │ │ │ +00011010: 7572 6e3c 2f73 7061 6e3e 3b3c 2f64 6976 urn;
.
410< │ │ │ │ +00011070: 2f73 7061 6e3e 2020 2020 7d3c 2f64 6976 /span> }
.
411< │ │ │ │ +000110d0: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ -000110f0: 3c61 2069 643d 226c 3030 3432 3222 206e 422
.
423 │ │ │ │ -00011190: 2020 3c73 7061 6e20 636c 6173 733d 226b typedef< │ │ │ │ -000111b0: 2f73 7061 6e3e 203c 7370 616e 2063 6c61 /span> typ │ │ │ │ -000111d0: 656e 616d 653c 2f73 7061 6e3e 204d 4153 ename MAS │ │ │ │ -000111e0: 4b3a 3a57 6569 6768 7420 5765 6967 6874 K::Weight Weight │ │ │ │ -000111f0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00011240: 2020 3432 343c 2f73 7061 6e3e 203c 2f64 424 .
42 │ │ │ │ -000112a0: 353c 2f73 7061 6e3e 2020 2020 3c73 7061 5 //
.
426< │ │ │ │ -00011320: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -00011340: 2f2f 2020 4669 7273 742c 2074 6865 2074 // First, the t │ │ │ │ -00011350: 616e 6765 6e74 2061 6c6f 6e67 2074 6865 angent along the │ │ │ │ -00011360: 2063 7265 6173 653a 3c2f 7370 616e 3e3c crease:< │ │ │ │ -00011370: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -000113c0: 3432 373c 2f73 7061 6e3e 2020 2020 3c73 427 // The │ │ │ │ -000113f0: 6669 7273 7420 6372 6561 7365 2065 6467 first crease edg │ │ │ │ -00011400: 6520 6973 2063 6f6e 7369 6465 7265 6420 e is considered │ │ │ │ -00011410: 7468 6520 2671 756f 743b 6c65 6164 696e the "leadin │ │ │ │ -00011420: 6726 7175 6f74 3b20 6564 6765 206f 6620 g" edge of │ │ │ │ -00011430: 7468 6520 7370 616e 3c2f 7370 616e 3e3c the span< │ │ │ │ -00011440: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00011490: 3432 383c 2f73 7061 6e3e 2020 2020 3c73 428 // of surfa │ │ │ │ -000114c0: 6365 2066 6f72 2077 6869 6368 2077 6520 ce for which we │ │ │ │ -000114d0: 6172 6520 6576 616c 7561 7469 6e67 2074 are evaluating t │ │ │ │ -000114e0: 616e 6765 6e74 7320 616e 6420 7468 6520 angents and the │ │ │ │ -000114f0: 7365 636f 6e64 2065 6467 6520 7468 653c second edge the< │ │ │ │ -00011500: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -00011520: 6120 6964 3d22 6c30 3034 3239 2220 6e61 a id="l00429" na │ │ │ │ -00011530: 6d65 3d22 6c30 3034 3239 223e 3c2f 613e me="l00429"> │ │ │ │ -00011540: 3c73 7061 6e20 636c 6173 733d 226c 696e 429 // & │ │ │ │ -00011580: 7175 6f74 3b74 7261 696c 696e 6720 6564 quot;trailing ed │ │ │ │ -00011590: 6765 2671 756f 743b 2e20 2042 7920 636f ge". By co │ │ │ │ -000115a0: 6e76 656e 7469 6f6e 2c20 7468 6520 7461 nvention, the ta │ │ │ │ -000115b0: 6e67 656e 7420 616c 6f6e 6720 7468 6520 ngent along the │ │ │ │ -000115c0: 6372 6561 7365 2069 7320 6f72 6965 6e74 crease is orient │ │ │ │ -000115d0: 6564 3c2f 7370 616e 3e3c 2f64 6976 3e0a ed
. │ │ │ │ -000115e0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -00011610: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 430 // │ │ │ │ -00011650: 2020 696e 2074 6865 2064 6972 6563 7469 in the directi │ │ │ │ -00011660: 6f6e 206f 6620 7468 6520 6c65 6164 696e on of the leadin │ │ │ │ -00011670: 6720 6564 6765 2e3c 2f73 7061 6e3e 3c2f g edge..
4 │ │ │ │ -000116d0: 3331 3c2f 7370 616e 3e20 2020 203c 7370 31 //.
432 │ │ │ │ -00011750: 3c2f 7370 616e 3e20 2020 203c 7370 616e int │ │ │ │ -00011780: 7661 6c65 6e63 6520 3d20 7665 7274 6578 valence = vertex │ │ │ │ -00011790: 2e47 6574 4e75 6d45 6467 6573 2829 3b3c .GetNumEdges();< │ │ │ │ -000117a0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -000117f0: 3433 333c 2f73 7061 6e3e 203c 2f64 6976 433
.
434< │ │ │ │ -00011850: 2f73 7061 6e3e 2020 2020 7461 6e31 4d61 /span> tan1Ma │ │ │ │ -00011860: 736b 2e53 6574 4e75 6d56 6572 7465 7857 sk.SetNumVertexW │ │ │ │ -00011870: 6569 6768 7473 2831 293b 3c2f 6469 763e eights(1);
│ │ │ │ -00011880: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -000118b0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 435 tan1Mas │ │ │ │ -000118e0: 6b2e 5365 744e 756d 4564 6765 5765 6967 k.SetNumEdgeWeig │ │ │ │ -000118f0: 6874 7328 7661 6c65 6e63 6529 3b3c 2f64 hts(valence);.
43 │ │ │ │ -00011950: 363c 2f73 7061 6e3e 2020 2020 7461 6e31 6 tan1 │ │ │ │ -00011960: 4d61 736b 2e53 6574 4e75 6d46 6163 6557 Mask.SetNumFaceW │ │ │ │ -00011970: 6569 6768 7473 2830 293b 3c2f 6469 763e eights(0);
│ │ │ │ -00011980: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -000119b0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 437 tan1Mas │ │ │ │ -000119e0: 6b2e 5365 7446 6163 6557 6569 6768 7473 k.SetFaceWeights │ │ │ │ -000119f0: 466f 7246 6163 6543 656e 7465 7273 283c ForFaceCenters(< │ │ │ │ -00011a00: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00011a10: 6f72 6422 3e66 616c 7365 3c2f 7370 616e ord">false);
.
438 < │ │ │ │ -00011a80: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00011ad0: 3433 393c 2f73 7061 6e3e 2020 2020 7461 439 ta │ │ │ │ -00011ae0: 6e31 4d61 736b 2e56 6572 7465 7857 6569 n1Mask.VertexWei │ │ │ │ -00011af0: 6768 7428 3029 203d 2030 2e30 663b 3c2f ght(0) = 0.0f;.
4 │ │ │ │ -00011b50: 3430 3c2f 7370 616e 3e20 2020 203c 7370 40 for (int │ │ │ │ -00011ba0: 3c2f 7370 616e 3e20 6920 3d20 303b 2069 i = 0; i │ │ │ │ -00011bb0: 2026 6c74 3b20 7661 6c65 6e63 653b 202b < valence; + │ │ │ │ -00011bc0: 2b69 2920 7b3c 2f64 6976 3e0a 3c64 6976 +i) {
.
< │ │ │ │ -00011c00: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00011c10: 6e6f 223e 2020 3434 313c 2f73 7061 6e3e no"> 441 │ │ │ │ -00011c20: 2020 2020 2020 2020 7461 6e31 4d61 736b tan1Mask │ │ │ │ -00011c30: 2e45 6467 6557 6569 6768 7428 6929 203d .EdgeWeight(i) = │ │ │ │ -00011c40: 2030 2e30 663b 3c2f 6469 763e 0a3c 6469 0.0f;
.< │ │ │ │ -00011c60: 6120 6964 3d22 6c30 3034 3432 2220 6e61 a id="l00442" na │ │ │ │ -00011c70: 6d65 3d22 6c30 3034 3432 223e 3c2f 613e me="l00442"> │ │ │ │ -00011c80: 3c73 7061 6e20 636c 6173 733d 226c 696e 442 }
.< │ │ │ │ -00011cc0: 6120 6964 3d22 6c30 3034 3433 2220 6e61 a id="l00443" na │ │ │ │ -00011cd0: 6d65 3d22 6c30 3034 3433 223e 3c2f 613e me="l00443"> │ │ │ │ -00011ce0: 3c73 7061 6e20 636c 6173 733d 226c 696e 443
.
444 │ │ │ │ -00011d60: 203c 7370 616e 2063 6c61 7373 3d22 636f // See t │ │ │ │ -00011d80: 6865 206e 6f74 6520 6162 6f76 6520 7265 he note above re │ │ │ │ -00011d90: 6761 7264 696e 6720 7363 616c 6520 6661 garding scale fa │ │ │ │ -00011da0: 6374 6f72 206f 6620 312e 353a 3c2f 7370 ctor of 1.5:
.
445 │ │ │ │ -00011e10: 2020 7461 6e31 4d61 736b 2e45 6467 6557 tan1Mask.EdgeW │ │ │ │ -00011e20: 6569 6768 7428 6372 6561 7365 456e 6473 eight(creaseEnds │ │ │ │ -00011e30: 5b30 5d29 203d 2020 312e 3566 3b3c 2f64 [0]) = 1.5f;.
44 │ │ │ │ -00011e90: 363c 2f73 7061 6e3e 2020 2020 7461 6e31 6 tan1 │ │ │ │ -00011ea0: 4d61 736b 2e45 6467 6557 6569 6768 7428 Mask.EdgeWeight( │ │ │ │ -00011eb0: 6372 6561 7365 456e 6473 5b31 5d29 203d creaseEnds[1]) = │ │ │ │ -00011ec0: 202d 312e 3566 3b3c 2f64 6976 3e0a 3c64 -1.5f;
. │ │ │ │ -00011ee0: 3c61 2069 643d 226c 3030 3434 3722 206e 447
.
448 │ │ │ │ -00011f80: 2020 3c73 7061 6e20 636c 6173 733d 2263 //
.
│ │ │ │ -00011ff0: 2020 3434 393c 2f73 7061 6e3e 2020 2020 449 │ │ │ │ -00012000: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // Second │ │ │ │ -00012020: 2c20 7468 6520 7461 6e67 656e 7420 6163 , the tangent ac │ │ │ │ -00012030: 726f 7373 2074 6865 2069 6e74 6572 696f ross the interio │ │ │ │ -00012040: 7220 6661 6365 733a 3c2f 7370 616e 3e3c r faces:< │ │ │ │ -00012050: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -000120a0: 3435 303c 2f73 7061 6e3e 2020 2020 3c73 450 // Note │ │ │ │ -000120d0: 2074 6869 7320 6973 2061 6d62 6967 756f this is ambiguo │ │ │ │ -000120e0: 7573 2066 6f72 2061 6e20 696e 7465 7269 us for an interi │ │ │ │ -000120f0: 6f72 2076 6572 7465 782e 2020 5765 2063 or vertex. We c │ │ │ │ -00012100: 7572 7265 6e74 6c79 2072 6574 7572 6e3c urrently return< │ │ │ │ -00012110: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -00012130: 6120 6964 3d22 6c30 3034 3531 2220 6e61 a id="l00451" na │ │ │ │ -00012140: 6d65 3d22 6c30 3034 3531 223e 3c2f 613e me="l00451"> │ │ │ │ -00012150: 3c73 7061 6e20 636c 6173 733d 226c 696e 451 // t │ │ │ │ -00012190: 6865 2074 616e 6765 6e74 2066 6f72 2074 he tangent for t │ │ │ │ -000121a0: 6865 2073 7572 6661 6365 2069 6e20 7468 he surface in th │ │ │ │ -000121b0: 6520 636f 756e 7465 722d 636c 6f63 6b77 e counter-clockw │ │ │ │ -000121c0: 6973 6520 7370 616e 2062 6574 7765 656e ise span between │ │ │ │ -000121d0: 2074 6865 3c2f 7370 616e 3e3c 2f64 6976 the
.
452< │ │ │ │ -00012230: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -00012250: 2f2f 2020 6c65 6164 696e 6720 616e 6420 // leading and │ │ │ │ -00012260: 7472 6169 6c69 6e67 2065 6467 6573 2074 trailing edges t │ │ │ │ -00012270: 6861 7420 666f 726d 2074 6865 2063 7265 hat form the cre │ │ │ │ -00012280: 6173 652e 2020 4769 7665 6e20 7468 6520 ase. Given the │ │ │ │ -00012290: 6578 7065 6374 6564 3c2f 7370 616e 3e3c expected< │ │ │ │ -000122a0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -000122f0: 3435 333c 2f73 7061 6e3e 2020 2020 3c73 453 // computat │ │ │ │ -00012320: 696f 6e20 6f66 2061 2073 7572 6661 6365 ion of a surface │ │ │ │ -00012330: 206e 6f72 6d61 6c20 6173 2054 616e 3120 normal as Tan1 │ │ │ │ -00012340: 5820 5461 6e32 2c20 7468 6973 2074 616e X Tan2, this tan │ │ │ │ -00012350: 6765 6e74 2073 686f 756c 6420 6265 3c2f gent should be
.
< │ │ │ │ -000123a0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -000123b0: 6e6f 223e 2020 3435 343c 2f73 7061 6e3e no"> 454 │ │ │ │ -000123c0: 2020 2020 3c73 7061 6e20 636c 6173 733d // or │ │ │ │ -000123e0: 6965 6e74 6564 2026 7175 6f74 3b69 6e77 iented "inw │ │ │ │ -000123f0: 6172 6426 7175 6f74 3b20 6672 6f6d 2074 ard" from t │ │ │ │ -00012400: 6865 2063 7265 6173 652f 626f 756e 6461 he crease/bounda │ │ │ │ -00012410: 7279 202d 2d20 6163 726f 7373 2074 6865 ry -- across the │ │ │ │ -00012420: 2073 7572 6661 6365 2072 6174 6865 723c surface rather< │ │ │ │ -00012430: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -00012450: 6120 6964 3d22 6c30 3034 3535 2220 6e61 a id="l00455" na │ │ │ │ -00012460: 6d65 3d22 6c30 3034 3535 223e 3c2f 613e me="l00455"> │ │ │ │ -00012470: 3c73 7061 6e20 636c 6173 733d 226c 696e 455 // t │ │ │ │ -000124b0: 6861 6e20 6f75 7477 6172 6420 616e 6420 han outward and │ │ │ │ -000124c0: 6177 6179 2066 726f 6d20 6974 2e3c 2f73 away from it.
.
456 │ │ │ │ -00012530: 2020 203c 7370 616e 2063 6c61 7373 3d22 //
.
457 │ │ │ │ -000125b0: 203c 7370 616e 2063 6c61 7373 3d22 636f // There │ │ │ │ -000125d0: 2069 7320 696e 636f 6e73 6973 7465 6e63 is inconsistenc │ │ │ │ -000125e0: 7920 696e 2074 6865 206f 7269 656e 7461 y in the orienta │ │ │ │ -000125f0: 7469 6f6e 206f 6620 7468 6973 2074 616e tion of this tan │ │ │ │ -00012600: 6765 6e74 2069 6e20 636f 6d6d 6f6e 6c79 gent in commonly │ │ │ │ -00012610: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00012630: 3c61 2069 643d 226c 3030 3435 3822 206e 458 // │ │ │ │ -00012690: 7075 626c 6973 6865 6420 7265 7375 6c74 published result │ │ │ │ -000126a0: 733a 2020 7468 6520 6765 6e65 7261 6c20 s: the general │ │ │ │ -000126b0: 666f 726d 756c 6120 7072 6f76 6964 6564 formula provided │ │ │ │ -000126c0: 2066 6f72 2061 7262 6974 7261 7279 2076 for arbitrary v │ │ │ │ -000126d0: 616c 656e 6365 3c2f 7370 616e 3e3c 2f64 alence.
45 │ │ │ │ -00012730: 393c 2f73 7061 6e3e 2020 2020 3c73 7061 9 // has the ta │ │ │ │ -00012760: 6e67 656e 7420 706f 696e 7469 6e67 2061 ngent pointing a │ │ │ │ -00012770: 6372 6f73 7320 7468 6520 6372 6561 7365 cross the crease │ │ │ │ -00012780: 2061 6e64 2026 7175 6f74 3b6f 7574 7761 and "outwa │ │ │ │ -00012790: 7264 2671 756f 743b 2066 726f 6d20 7468 rd" from th │ │ │ │ -000127a0: 6520 7375 7266 6163 652c 3c2f 7370 616e e surface,
.
│ │ │ │ -00012800: 2020 3436 303c 2f73 7061 6e3e 2020 2020 460 │ │ │ │ -00012810: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // while │ │ │ │ -00012830: 7468 6520 7370 6563 6961 6c20 6361 7365 the special case │ │ │ │ -00012840: 7320 666f 7220 7265 6775 6c61 7220 7661 s for regular va │ │ │ │ -00012850: 6c65 6e63 6520 616e 6420 6c6f 7765 7220 lence and lower │ │ │ │ -00012860: 6861 7665 2074 6865 2074 616e 6765 6e74 have the tangent │ │ │ │ -00012870: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00012890: 3c61 2069 643d 226c 3030 3436 3122 206e 461 // │ │ │ │ -000128f0: 706f 696e 7469 6e67 2061 6372 6f73 7320 pointing across │ │ │ │ -00012900: 7468 6520 7375 7266 6163 6520 616e 6420 the surface and │ │ │ │ -00012910: 2671 756f 743b 696e 7761 7264 2671 756f "inward&quo │ │ │ │ -00012920: 743b 2066 726f 6d20 7468 6520 6372 6561 t; from the crea │ │ │ │ -00012930: 7365 2e20 2053 6f20 6966 2077 6520 6172 se. So if we ar │ │ │ │ -00012940: 653c 2f73 7061 6e3e 3c2f 6469 763e 0a3c e
.< │ │ │ │ -00012950: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00012960: 3e3c 6120 6964 3d22 6c30 3034 3632 2220 > 462 // │ │ │ │ -000129c0: 2074 6f20 636f 6e73 6973 7465 6e74 6c79 to consistently │ │ │ │ -000129d0: 206f 7269 656e 7420 7468 6520 6669 7273 orient the firs │ │ │ │ -000129e0: 7420 7461 6e67 656e 7420 616c 6f6e 6720 t tangent along │ │ │ │ -000129f0: 7468 6520 6372 6561 7365 2c20 7265 6761 the crease, rega │ │ │ │ -00012a00: 7264 6c65 7373 206f 663c 2f73 7061 6e3e rdless of │ │ │ │ -00012a10: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00012a60: 2034 3633 3c2f 7370 616e 3e20 2020 203c 463 < │ │ │ │ -00012a70: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00012a80: 656e 7422 3e2f 2f20 2074 6865 2069 6e74 ent">// the int │ │ │ │ -00012a90: 6572 696f 7220 746f 706f 6c6f 6779 2c20 erior topology, │ │ │ │ -00012aa0: 7765 2068 6176 6520 746f 2063 6f72 7265 we have to corre │ │ │ │ -00012ab0: 6374 2074 6869 732e 2020 5769 7468 2074 ct this. With t │ │ │ │ -00012ac0: 6865 2066 6972 7374 2074 616e 6765 6e74 he first tangent │ │ │ │ -00012ad0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00012af0: 3c61 2069 643d 226c 3030 3436 3422 206e 464 // │ │ │ │ -00012b50: 666f 6c6c 6f77 696e 6720 7468 6520 6469 following the di │ │ │ │ -00012b60: 7265 6374 696f 6e20 6f66 2074 6865 206c rection of the l │ │ │ │ -00012b70: 6561 6469 6e67 2063 7265 6173 6520 6564 eading crease ed │ │ │ │ -00012b80: 6765 2c20 7765 2077 616e 7420 7468 6520 ge, we want the │ │ │ │ -00012b90: 7365 636f 6e64 3c2f 7370 616e 3e3c 2f64 second.
46 │ │ │ │ -00012bf0: 353c 2f73 7061 6e3e 2020 2020 3c73 7061 5 // tangent po │ │ │ │ -00012c20: 696e 7469 6e67 2069 6e77 6172 642f 6163 inting inward/ac │ │ │ │ -00012c30: 726f 7373 2074 6865 2073 7572 6661 6365 ross the surface │ │ │ │ -00012c40: 202d 2d20 736f 2077 6520 666c 6970 2074 -- so we flip t │ │ │ │ -00012c50: 6865 2072 6573 756c 7420 6f66 3c2f 7370 he result of
.
466 │ │ │ │ -00012cc0: 2020 3c73 7061 6e20 636c 6173 733d 2263 // the │ │ │ │ -00012ce0: 6765 6e65 7261 6c20 666f 726d 756c 612e general formula. │ │ │ │ -00012cf0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00012d10: 3c61 2069 643d 226c 3030 3436 3722 206e 467 //
.
< │ │ │ │ -00012db0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00012dc0: 6e6f 223e 2020 3436 383c 2f73 7061 6e3e no"> 468 │ │ │ │ -00012dd0: 2020 2020 7461 6e32 4d61 736b 2e53 6574 tan2Mask.Set │ │ │ │ -00012de0: 4e75 6d56 6572 7465 7857 6569 6768 7473 NumVertexWeights │ │ │ │ -00012df0: 2831 293b 3c2f 6469 763e 0a3c 6469 7620 (1);
.
469 │ │ │ │ -00012e50: 2020 2074 616e 324d 6173 6b2e 5365 744e tan2Mask.SetN │ │ │ │ -00012e60: 756d 4564 6765 5765 6967 6874 7328 7661 umEdgeWeights(va │ │ │ │ -00012e70: 6c65 6e63 6529 3b3c 2f64 6976 3e0a 3c64 lence);
. │ │ │ │ -00012e90: 3c61 2069 643d 226c 3030 3437 3022 206e 470 tan2Mask.S │ │ │ │ -00012ee0: 6574 4e75 6d46 6163 6557 6569 6768 7473 etNumFaceWeights │ │ │ │ -00012ef0: 2830 293b 3c2f 6469 763e 0a3c 6469 7620 (0);
.
471 │ │ │ │ -00012f50: 2020 2074 616e 324d 6173 6b2e 5365 7446 tan2Mask.SetF │ │ │ │ -00012f60: 6163 6557 6569 6768 7473 466f 7246 6163 aceWeightsForFac │ │ │ │ -00012f70: 6543 656e 7465 7273 283c 7370 616e 2063 eCenters(f │ │ │ │ -00012f90: 616c 7365 3c2f 7370 616e 3e29 3b3c 2f64 alse);.
47 │ │ │ │ -00012ff0: 323c 2f73 7061 6e3e 203c 2f64 6976 3e0a 2
. │ │ │ │ -00013000: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.< │ │ │ │ -000130e0: 6120 6964 3d22 6c30 3034 3734 2220 6e61 a id="l00474" na │ │ │ │ -000130f0: 6d65 3d22 6c30 3034 3734 223e 3c2f 613e me="l00474"> │ │ │ │ -00013100: 3c73 7061 6e20 636c 6173 733d 226c 696e 474 tan2Mas │ │ │ │ -00013130: 6b2e 4564 6765 5765 6967 6874 2869 2920 k.EdgeWeight(i) │ │ │ │ -00013140: 3d20 302e 3066 3b3c 2f64 6976 3e0a 3c64 = 0.0f;
. │ │ │ │ -00013160: 3c61 2069 643d 226c 3030 3437 3522 206e 475 }
. │ │ │ │ -000131c0: 3c61 2069 643d 226c 3030 3437 3622 206e 476 │ │ │ │ -00013220: 696e 743c 2f73 7061 6e3e 2069 6e74 6572 int inter │ │ │ │ -00013230: 696f 7245 6467 6543 6f75 6e74 203d 2063 iorEdgeCount = c │ │ │ │ -00013240: 7265 6173 6545 6e64 735b 315d 202d 2063 reaseEnds[1] - c │ │ │ │ -00013250: 7265 6173 6545 6e64 735b 305d 202d 2031 reaseEnds[0] - 1 │ │ │ │ -00013260: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -000132b0: 2020 3437 373c 2f73 7061 6e3e 2020 2020 477 │ │ │ │ -000132c0: 3c73 7061 6e20 636c 6173 733d 226b 6579 if (interiorEdg │ │ │ │ -000132f0: 6543 6f75 6e74 203d 3d20 3229 207b 3c2f eCount == 2) {.
4 │ │ │ │ -00013350: 3738 3c2f 7370 616e 3e20 2020 2020 2020 78 │ │ │ │ -00013360: 203c 7370 616e 2063 6c61 7373 3d22 636f // See n │ │ │ │ -00013380: 6f74 6520 6162 6f76 6520 7265 6761 7264 ote above regard │ │ │ │ -00013390: 696e 6720 7363 616c 6520 6661 6374 6f72 ing scale factor │ │ │ │ -000133a0: 206f 6620 2873 696e 2836 3020 6465 6773 of (sin(60 degs │ │ │ │ -000133b0: 2920 3d3d 2073 7172 7428 3329 2f32 3a3c ) == sqrt(3)/2:< │ │ │ │ -000133c0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -000133e0: 6120 6964 3d22 6c30 3034 3739 2220 6e61 a id="l00479" na │ │ │ │ -000133f0: 6d65 3d22 6c30 3034 3739 223e 3c2f 613e me="l00479"> │ │ │ │ -00013400: 3c73 7061 6e20 636c 6173 733d 226c 696e 479
.
480 │ │ │ │ -00013480: 2020 2020 203c 7370 616e 2063 6c61 7373 stati │ │ │ │ -000134a0: 633c 2f73 7061 6e3e 2057 6569 6768 7420 c Weight │ │ │ │ -000134b0: 3c73 7061 6e20 636c 6173 733d 226b 6579 const Root3 = (W │ │ │ │ -000134e0: 6569 6768 7429 2031 2e37 3332 3035 3038 eight) 1.7320508 │ │ │ │ -000134f0: 3037 3536 3838 3737 3239 3335 323b 3c2f 0756887729352;.
4 │ │ │ │ -00013550: 3831 3c2f 7370 616e 3e20 2020 2020 2020 81 │ │ │ │ -00013560: 203c 7370 616e 2063 6c61 7373 3d22 6b65 static Weight const R │ │ │ │ -000135b0: 6f6f 7433 6279 3220 3d20 2857 6569 6768 oot3by2 = (Weigh │ │ │ │ -000135c0: 7429 2028 526f 6f74 3320 2a20 302e 3529 t) (Root3 * 0.5) │ │ │ │ -000135d0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00013620: 2020 3438 323c 2f73 7061 6e3e 203c 2f64 482 .
48 │ │ │ │ -00013680: 333c 2f73 7061 6e3e 2020 2020 2020 2020 3 │ │ │ │ -00013690: 7461 6e32 4d61 736b 2e56 6572 7465 7857 tan2Mask.VertexW │ │ │ │ -000136a0: 6569 6768 7428 3029 203d 202d 526f 6f74 eight(0) = -Root │ │ │ │ -000136b0: 333b 3c2f 6469 763e 0a3c 6469 7620 636c 3;
.
484 .
4 │ │ │ │ -00013760: 3835 3c2f 7370 616e 3e20 2020 2020 2020 85 │ │ │ │ -00013770: 2074 616e 324d 6173 6b2e 4564 6765 5765 tan2Mask.EdgeWe │ │ │ │ -00013780: 6967 6874 2863 7265 6173 6545 6e64 735b ight(creaseEnds[ │ │ │ │ -00013790: 305d 2920 3d20 2d52 6f6f 7433 6279 323b 0]) = -Root3by2; │ │ │ │ -000137a0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000137f0: 2034 3836 3c2f 7370 616e 3e20 2020 2020 486 │ │ │ │ -00013800: 2020 2074 616e 324d 6173 6b2e 4564 6765 tan2Mask.Edge │ │ │ │ -00013810: 5765 6967 6874 2863 7265 6173 6545 6e64 Weight(creaseEnd │ │ │ │ -00013820: 735b 315d 2920 3d20 2d52 6f6f 7433 6279 s[1]) = -Root3by │ │ │ │ -00013830: 323b 3c2f 6469 763e 0a3c 6469 7620 636c 2;
.
487 .
4 │ │ │ │ -000138e0: 3838 3c2f 7370 616e 3e20 2020 2020 2020 88 │ │ │ │ -000138f0: 2074 616e 324d 6173 6b2e 4564 6765 5765 tan2Mask.EdgeWe │ │ │ │ -00013900: 6967 6874 2863 7265 6173 6545 6e64 735b ight(creaseEnds[ │ │ │ │ -00013910: 305d 202b 2031 2920 3d20 526f 6f74 333b 0] + 1) = Root3; │ │ │ │ -00013920: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00013970: 2034 3839 3c2f 7370 616e 3e20 2020 2020 489 │ │ │ │ -00013980: 2020 2074 616e 324d 6173 6b2e 4564 6765 tan2Mask.Edge │ │ │ │ -00013990: 5765 6967 6874 2863 7265 6173 6545 6e64 Weight(creaseEnd │ │ │ │ -000139a0: 735b 305d 202b 2032 2920 3d20 526f 6f74 s[0] + 2) = Root │ │ │ │ -000139b0: 333b 3c2f 6469 763e 0a3c 6469 7620 636c 3;
.
490 │ │ │ │ -00013a10: 207d 203c 7370 616e 2063 6c61 7373 3d22 } els │ │ │ │ -00013a30: 653c 2f73 7061 6e3e 203c 7370 616e 2063 e if (in │ │ │ │ -00013a60: 7465 7269 6f72 4564 6765 436f 756e 7420 teriorEdgeCount │ │ │ │ -00013a70: 2667 743b 2032 2920 7b3c 2f64 6976 3e0a > 2) {
. │ │ │ │ -00013a80: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
│ │ │ │ -00013b90: 2034 3932 3c2f 7370 616e 3e20 2020 2020 492 │ │ │ │ -00013ba0: 2020 203c 7370 616e 2063 6c61 7373 3d22 // 2.0 │ │ │ │ -00013bc0: 2066 6f72 2063 6f6e 7369 6465 7269 6e67 for considering │ │ │ │ -00013bd0: 2074 6865 2072 6567 696f 6e20 6173 2061 the region as a │ │ │ │ -00013be0: 2068 616c 662d 6469 736b 2c20 616e 6420 half-disk, and │ │ │ │ -00013bf0: 312e 3520 696e 206b 6565 7069 6e67 3c2f 1.5 in keeping
.
< │ │ │ │ -00013c40: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00013c50: 6e6f 223e 2020 3439 333c 2f73 7061 6e3e no"> 493 │ │ │ │ -00013c60: 2020 2020 2020 2020 3c73 7061 6e20 636c // │ │ │ │ -00013c80: 2020 7769 7468 2074 6865 2063 7265 6173 with the creas │ │ │ │ -00013c90: 6520 7461 6e67 656e 7429 3a3c 2f73 7061 e tangent):
.
494 .
4 │ │ │ │ -00013d50: 3935 3c2f 7370 616e 3e20 2020 2020 2020 95 │ │ │ │ -00013d60: 203c 7370 616e 2063 6c61 7373 3d22 6b65 doubl │ │ │ │ -00013d80: 653c 2f73 7061 6e3e 2074 6865 7461 203d e theta = │ │ │ │ -00013d90: 204d 5f50 4920 2f20 2869 6e74 6572 696f M_PI / (interio │ │ │ │ -00013da0: 7245 6467 6543 6f75 6e74 202b 2031 293b rEdgeCount + 1); │ │ │ │ -00013db0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00013e00: 2034 3936 3c2f 7370 616e 3e20 3c2f 6469 496 .
497 │ │ │ │ -00013e60: 3c2f 7370 616e 3e20 2020 2020 2020 2074 t │ │ │ │ -00013e70: 616e 324d 6173 6b2e 5665 7274 6578 5765 an2Mask.VertexWe │ │ │ │ -00013e80: 6967 6874 2830 2920 3d20 302e 3066 3b3c ight(0) = 0.0f;< │ │ │ │ -00013e90: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00013ee0: 3439 383c 2f73 7061 6e3e 203c 2f64 6976 498
.
499< │ │ │ │ -00013f40: 2f73 7061 6e3e 2020 2020 2020 2020 5765 /span> We │ │ │ │ -00013f50: 6967 6874 2063 5765 6967 6874 203d 2028 ight cWeight = ( │ │ │ │ -00013f60: 5765 6967 6874 2920 282d 332e 3066 202a Weight) (-3.0f * │ │ │ │ -00013f70: 2073 7464 3a3a 7369 6e28 7468 6574 6129 std::sin(theta) │ │ │ │ -00013f80: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
500 │ │ │ │ -00013fe0: 2020 2020 2074 616e 324d 6173 6b2e 4564 tan2Mask.Ed │ │ │ │ -00013ff0: 6765 5765 6967 6874 2863 7265 6173 6545 geWeight(creaseE │ │ │ │ -00014000: 6e64 735b 305d 2920 3d20 6357 6569 6768 nds[0]) = cWeigh │ │ │ │ -00014010: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
501 │ │ │ │ -00014070: 2020 2020 2074 616e 324d 6173 6b2e 4564 tan2Mask.Ed │ │ │ │ -00014080: 6765 5765 6967 6874 2863 7265 6173 6545 geWeight(creaseE │ │ │ │ -00014090: 6e64 735b 315d 2920 3d20 6357 6569 6768 nds[1]) = cWeigh │ │ │ │ -000140a0: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
502 .
5 │ │ │ │ -00014150: 3033 3c2f 7370 616e 3e20 2020 2020 2020 03 │ │ │ │ -00014160: 203c 7370 616e 2063 6c61 7373 3d22 6b65 doubl │ │ │ │ -00014180: 653c 2f73 7061 6e3e 2065 436f 6566 6620 e eCoeff │ │ │ │ -00014190: 203d 202d 332e 3066 202a 2032 2e30 6620 = -3.0f * 2.0f │ │ │ │ -000141a0: 2a20 2873 7464 3a3a 636f 7328 7468 6574 * (std::cos(thet │ │ │ │ -000141b0: 6129 202d 2031 2e30 6629 3b3c 2f64 6976 a) - 1.0f);
.
504< │ │ │ │ -00014210: 2f73 7061 6e3e 2020 2020 2020 2020 3c73 /span> for (in │ │ │ │ -00014260: 743c 2f73 7061 6e3e 2069 203d 2031 3b20 t i = 1; │ │ │ │ -00014270: 6920 266c 743b 3d20 696e 7465 7269 6f72 i <= interior │ │ │ │ -00014280: 4564 6765 436f 756e 743b 202b 2b69 2920 EdgeCount; ++i) │ │ │ │ -00014290: 7b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 {
.
│ │ │ │ -000142e0: 2020 3530 353c 2f73 7061 6e3e 2020 2020 505 │ │ │ │ -000142f0: 2020 2020 2020 2020 7461 6e32 4d61 736b tan2Mask │ │ │ │ -00014300: 2e45 6467 6557 6569 6768 7428 6372 6561 .EdgeWeight(crea │ │ │ │ -00014310: 7365 456e 6473 5b30 5d20 2b20 6929 203d seEnds[0] + i) = │ │ │ │ -00014320: 2028 5765 6967 6874 2920 2865 436f 6566 (Weight) (eCoef │ │ │ │ -00014330: 6620 2a20 7374 643a 3a73 696e 2869 202a f * std::sin(i * │ │ │ │ -00014340: 2074 6865 7461 2929 3b3c 2f64 6976 3e0a theta));
. │ │ │ │ -00014350: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -00014380: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 506 }.
50 │ │ │ │ -00014400: 373c 2f73 7061 6e3e 2020 2020 7d20 3c73 7 } else if │ │ │ │ -00014450: 3c2f 7370 616e 3e20 2869 6e74 6572 696f (interio │ │ │ │ -00014460: 7245 6467 6543 6f75 6e74 203d 3d20 3129 rEdgeCount == 1) │ │ │ │ -00014470: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
508 │ │ │ │ -000144d0: 2020 2020 203c 7370 616e 2063 6c61 7373 // S │ │ │ │ -000144f0: 6565 206e 6f74 6573 2061 626f 7665 2072 ee notes above r │ │ │ │ -00014500: 6567 6172 6469 6e67 2073 6361 6c65 2066 egarding scale f │ │ │ │ -00014510: 6163 746f 7220 6f66 2033 2e30 3a3c 2f73 actor of 3.0:
.
509 │ │ │ │ -00014580: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000145d0: 2035 3130 3c2f 7370 616e 3e20 2020 2020 510 │ │ │ │ -000145e0: 2020 2074 616e 324d 6173 6b2e 5665 7274 tan2Mask.Vert │ │ │ │ -000145f0: 6578 5765 6967 6874 2830 2920 3d20 2d33 exWeight(0) = -3 │ │ │ │ -00014600: 2e30 663b 3c2f 6469 763e 0a3c 6469 7620 .0f;
.
511 │ │ │ │ -00014660: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000146b0: 2035 3132 3c2f 7370 616e 3e20 2020 2020 512 │ │ │ │ -000146c0: 2020 2074 616e 324d 6173 6b2e 4564 6765 tan2Mask.Edge │ │ │ │ -000146d0: 5765 6967 6874 2863 7265 6173 6545 6e64 Weight(creaseEnd │ │ │ │ -000146e0: 735b 305d 2920 3d20 302e 3066 3b3c 2f64 s[0]) = 0.0f;.
51 │ │ │ │ -00014740: 333c 2f73 7061 6e3e 2020 2020 2020 2020 3 │ │ │ │ -00014750: 7461 6e32 4d61 736b 2e45 6467 6557 6569 tan2Mask.EdgeWei │ │ │ │ -00014760: 6768 7428 6372 6561 7365 456e 6473 5b31 ght(creaseEnds[1 │ │ │ │ -00014770: 5d29 203d 2030 2e30 663b 3c2f 6469 763e ]) = 0.0f;
│ │ │ │ -00014780: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -000147f0: 6120 6964 3d22 6c30 3035 3135 2220 6e61 a id="l00515" na │ │ │ │ -00014800: 6d65 3d22 6c30 3035 3135 223e 3c2f 613e me="l00515"> │ │ │ │ -00014810: 3c73 7061 6e20 636c 6173 733d 226c 696e 515 tan2Mas │ │ │ │ -00014840: 6b2e 4564 6765 5765 6967 6874 2863 7265 k.EdgeWeight(cre │ │ │ │ -00014850: 6173 6545 6e64 735b 305d 202b 2031 2920 aseEnds[0] + 1) │ │ │ │ -00014860: 3d20 332e 3066 3b3c 2f64 6976 3e0a 3c64 = 3.0f;
. │ │ │ │ -00014880: 3c61 2069 643d 226c 3030 3531 3622 206e 516 } else {< │ │ │ │ -000148f0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00014940: 3531 373c 2f73 7061 6e3e 2020 2020 2020 517 │ │ │ │ -00014950: 2020 3c73 7061 6e20 636c 6173 733d 2263 // See │ │ │ │ -00014970: 6e6f 7465 7320 6162 6f76 6520 7265 6761 notes above rega │ │ │ │ -00014980: 7264 696e 6720 7363 616c 6520 6661 6374 rding scale fact │ │ │ │ -00014990: 6f72 206f 6620 332e 303a 3c2f 7370 616e or of 3.0:
.
│ │ │ │ -000149f0: 2020 3531 383c 2f73 7061 6e3e 203c 2f64 518 .
51 │ │ │ │ -00014a50: 393c 2f73 7061 6e3e 2020 2020 2020 2020 9 │ │ │ │ -00014a60: 7461 6e32 4d61 736b 2e56 6572 7465 7857 tan2Mask.VertexW │ │ │ │ -00014a70: 6569 6768 7428 3029 203d 202d 362e 3066 eight(0) = -6.0f │ │ │ │ -00014a80: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00014ad0: 2020 3532 303c 2f73 7061 6e3e 203c 2f64 520 .
52 │ │ │ │ -00014b30: 313c 2f73 7061 6e3e 2020 2020 2020 2020 1 │ │ │ │ -00014b40: 7461 6e32 4d61 736b 2e45 6467 6557 6569 tan2Mask.EdgeWei │ │ │ │ -00014b50: 6768 7428 6372 6561 7365 456e 6473 5b30 ght(creaseEnds[0 │ │ │ │ -00014b60: 5d29 203d 2033 2e30 663b 3c2f 6469 763e ]) = 3.0f;
│ │ │ │ -00014b70: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00014ba0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 522 tan │ │ │ │ -00014bd0: 324d 6173 6b2e 4564 6765 5765 6967 6874 2Mask.EdgeWeight │ │ │ │ -00014be0: 2863 7265 6173 6545 6e64 735b 315d 2920 (creaseEnds[1]) │ │ │ │ -00014bf0: 3d20 332e 3066 3b3c 2f64 6976 3e0a 3c64 = 3.0f;
. │ │ │ │ -00014c10: 3c61 2069 643d 226c 3030 3532 3322 206e 523 }
. │ │ │ │ -00014c70: 3c61 2069 643d 226c 3030 3532 3422 206e 524 │ │ │ │ -00014cd0: 666f 723c 2f73 7061 6e3e 2028 3c73 7061 for (int │ │ │ │ -00014d00: 2069 203d 2063 7265 6173 6545 6e64 735b i = creaseEnds[ │ │ │ │ -00014d10: 315d 202b 2031 3b20 6920 266c 743b 2076 1] + 1; i < v │ │ │ │ -00014d20: 616c 656e 6365 3b20 2b2b 6929 207b 3c2f alence; ++i) {.
5 │ │ │ │ -00014d80: 3235 3c2f 7370 616e 3e20 2020 2020 2020 25 │ │ │ │ -00014d90: 2074 616e 324d 6173 6b2e 4564 6765 5765 tan2Mask.EdgeWe │ │ │ │ -00014da0: 6967 6874 2869 2920 3d20 302e 3066 3b3c ight(i) = 0.0f;< │ │ │ │ -00014db0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00014e00: 3532 363c 2f73 7061 6e3e 2020 2020 7d3c 526 }< │ │ │ │ -00014e10: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00014e60: 3532 373c 2f73 7061 6e3e 7d3c 2f64 6976 527}
.
.
528 .
5 │ │ │ │ -00014f20: 3239 3c2f 7370 616e 3e3c 7370 616e 2063 29t │ │ │ │ -00014f40: 656d 706c 6174 653c 2f73 7061 6e3e 2026 emplate & │ │ │ │ -00014f50: 6c74 3b26 6774 3b3c 2f64 6976 3e0a 3c64 lt;>
. │ │ │ │ -00014f70: 3c61 2069 643d 226c 3030 3533 3022 206e 530
template │ │ │ │ -00014fd0: 3c2f 7370 616e 3e20 266c 743b 3c73 7061 <typename VERTEX, │ │ │ │ -00015020: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ -00015030: 4d41 534b 2667 743b 3c2f 6469 763e 0a3c MASK>
.< │ │ │ │ -00015040: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00015050: 3e3c 6120 6964 3d22 6c30 3035 3331 2220 > 531inline< │ │ │ │ -000150b0: 2f73 7061 6e3e 203c 7370 616e 2063 6c61 /span> void.
. │ │ │ │ -00015290: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -000152c0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 533 MAS │ │ │ │ -000152f0: 4b26 616d 703b 2074 616e 314d 6173 6b2c K& tan1Mask, │ │ │ │ -00015300: 204d 4153 4b26 616d 703b 2074 616e 324d MASK& tan2M │ │ │ │ -00015310: 6173 6b29 3c73 7061 6e20 636c 6173 733d ask) const │ │ │ │ -00015330: 203c 2f73 7061 6e3e 7b3c 2f64 6976 3e0a {
. │ │ │ │ -00015340: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ -000153d0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -000153e0: 6e6f 223e 2020 3533 353c 2f73 7061 6e3e no"> 535 │ │ │ │ -000153f0: 2020 2020 3c73 7061 6e20 636c 6173 733d typede │ │ │ │ -00015410: 663c 2f73 7061 6e3e 203c 7370 616e 2063 f t │ │ │ │ -00015430: 7970 656e 616d 653c 2f73 7061 6e3e 204d ypename M │ │ │ │ -00015440: 4153 4b3a 3a57 6569 6768 7420 5765 6967 ASK::Weight Weig │ │ │ │ -00015450: 6874 3b3c 2f64 6976 3e0a 3c64 6976 2063 ht;
.
536 < │ │ │ │ -000154b0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00015500: 3533 373c 2f73 7061 6e3e 2020 2020 3c73 537 int valence = ver │ │ │ │ -00015540: 7465 782e 4765 744e 756d 4661 6365 7328 tex.GetNumFaces( │ │ │ │ -00015550: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
538 .
5 │ │ │ │ -00015600: 3339 3c2f 7370 616e 3e20 2020 2074 616e 39 tan │ │ │ │ -00015610: 314d 6173 6b2e 5365 744e 756d 5665 7274 1Mask.SetNumVert │ │ │ │ -00015620: 6578 5765 6967 6874 7328 3129 3b3c 2f64 exWeights(1);.
54 │ │ │ │ -00015680: 303c 2f73 7061 6e3e 2020 2020 7461 6e31 0 tan1 │ │ │ │ -00015690: 4d61 736b 2e53 6574 4e75 6d45 6467 6557 Mask.SetNumEdgeW │ │ │ │ -000156a0: 6569 6768 7473 2876 616c 656e 6365 293b eights(valence); │ │ │ │ -000156b0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00015700: 2035 3431 3c2f 7370 616e 3e20 2020 2074 541 t │ │ │ │ -00015710: 616e 314d 6173 6b2e 5365 744e 756d 4661 an1Mask.SetNumFa │ │ │ │ -00015720: 6365 5765 6967 6874 7328 3029 3b3c 2f64 ceWeights(0);.
54 │ │ │ │ -00015780: 323c 2f73 7061 6e3e 2020 2020 7461 6e31 2 tan1 │ │ │ │ -00015790: 4d61 736b 2e53 6574 4661 6365 5765 6967 Mask.SetFaceWeig │ │ │ │ -000157a0: 6874 7346 6f72 4661 6365 4365 6e74 6572 htsForFaceCenter │ │ │ │ -000157b0: 7328 3c73 7061 6e20 636c 6173 733d 226b s(false);
.< │ │ │ │ -000157f0: 6120 6964 3d22 6c30 3035 3433 2220 6e61 a id="l00543" na │ │ │ │ -00015800: 6d65 3d22 6c30 3035 3433 223e 3c2f 613e me="l00543"> │ │ │ │ -00015810: 3c73 7061 6e20 636c 6173 733d 226c 696e 543
.
544 │ │ │ │ -00015890: 2074 616e 324d 6173 6b2e 5365 744e 756d tan2Mask.SetNum │ │ │ │ -000158a0: 5665 7274 6578 5765 6967 6874 7328 3129 VertexWeights(1) │ │ │ │ -000158b0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00015900: 2020 3534 353c 2f73 7061 6e3e 2020 2020 545 │ │ │ │ -00015910: 7461 6e32 4d61 736b 2e53 6574 4e75 6d45 tan2Mask.SetNumE │ │ │ │ -00015920: 6467 6557 6569 6768 7473 2876 616c 656e dgeWeights(valen │ │ │ │ -00015930: 6365 293b 3c2f 6469 763e 0a3c 6469 7620 ce);
.
546 │ │ │ │ -00015990: 2020 2074 616e 324d 6173 6b2e 5365 744e tan2Mask.SetN │ │ │ │ -000159a0: 756d 4661 6365 5765 6967 6874 7328 3029 umFaceWeights(0) │ │ │ │ -000159b0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00015a00: 2020 3534 373c 2f73 7061 6e3e 2020 2020 547 │ │ │ │ -00015a10: 7461 6e32 4d61 736b 2e53 6574 4661 6365 tan2Mask.SetFace │ │ │ │ -00015a20: 5765 6967 6874 7346 6f72 4661 6365 4365 WeightsForFaceCe │ │ │ │ -00015a30: 6e74 6572 7328 3c73 7061 6e20 636c 6173 nters(fals │ │ │ │ -00015a50: 653c 2f73 7061 6e3e 293b 3c2f 6469 763e e);
│ │ │ │ -00015a60: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -00015ad0: 6120 6964 3d22 6c30 3035 3439 2220 6e61 a id="l00549" na │ │ │ │ -00015ae0: 6d65 3d22 6c30 3035 3439 223e 3c2f 613e me="l00549"> │ │ │ │ -00015af0: 3c73 7061 6e20 636c 6173 733d 226c 696e 549 tan1Mask.Ve │ │ │ │ -00015b20: 7274 6578 5765 6967 6874 2830 2920 3d20 rtexWeight(0) = │ │ │ │ -00015b30: 302e 3066 3b3c 2f64 6976 3e0a 3c64 6976 0.0f;
.
< │ │ │ │ -00015b70: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00015b80: 6e6f 223e 2020 3535 303c 2f73 7061 6e3e no"> 550 │ │ │ │ -00015b90: 2020 2020 7461 6e32 4d61 736b 2e56 6572 tan2Mask.Ver │ │ │ │ -00015ba0: 7465 7857 6569 6768 7428 3029 203d 2030 texWeight(0) = 0 │ │ │ │ -00015bb0: 2e30 663b 3c2f 6469 763e 0a3c 6469 7620 .0f;
.
551 │ │ │ │ -00015c10: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00015c60: 2035 3532 3c2f 7370 616e 3e20 2020 203c 552 < │ │ │ │ -00015c70: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00015c80: 6f72 6466 6c6f 7722 3e69 663c 2f73 7061 ordflow">if (valence == 6 │ │ │ │ -00015ca0: 2920 7b3c 2f64 6976 3e0a 3c64 6976 2063 ) {
.
553 │ │ │ │ -00015d00: 2020 2020 2020 3c73 7061 6e20 636c 6173 stat │ │ │ │ -00015d20: 6963 3c2f 7370 616e 3e20 5765 6967 6874 ic Weight │ │ │ │ -00015d30: 203c 7370 616e 2063 6c61 7373 3d22 6b65 const Root3by2 = ( │ │ │ │ -00015d60: 5765 6967 6874 2928 302e 3520 2a20 312e Weight)(0.5 * 1. │ │ │ │ -00015d70: 3733 3230 3530 3830 3735 3638 3837 3732 7320508075688772 │ │ │ │ -00015d80: 3933 3532 293b 3c2f 6469 763e 0a3c 6469 9352);
.< │ │ │ │ -00015da0: 6120 6964 3d22 6c30 3035 3534 2220 6e61 a id="l00554" na │ │ │ │ -00015db0: 6d65 3d22 6c30 3035 3534 223e 3c2f 613e me="l00554"> │ │ │ │ -00015dc0: 3c73 7061 6e20 636c 6173 733d 226c 696e 554
.
555 │ │ │ │ -00015e40: 2020 2020 2074 616e 314d 6173 6b2e 4564 tan1Mask.Ed │ │ │ │ -00015e50: 6765 5765 6967 6874 2830 2920 3d20 2031 geWeight(0) = 1 │ │ │ │ -00015e60: 2e30 663b 3c2f 6469 763e 0a3c 6469 7620 .0f;
.
556 │ │ │ │ -00015ec0: 2020 2020 2020 2074 616e 314d 6173 6b2e tan1Mask. │ │ │ │ -00015ed0: 4564 6765 5765 6967 6874 2831 2920 3d20 EdgeWeight(1) = │ │ │ │ -00015ee0: 2030 2e35 663b 3c2f 6469 763e 0a3c 6469 0.5f;
.< │ │ │ │ -00015f00: 6120 6964 3d22 6c30 3035 3537 2220 6e61 a id="l00557" na │ │ │ │ -00015f10: 6d65 3d22 6c30 3035 3537 223e 3c2f 613e me="l00557"> │ │ │ │ -00015f20: 3c73 7061 6e20 636c 6173 733d 226c 696e 557 tan1Mas │ │ │ │ -00015f50: 6b2e 4564 6765 5765 6967 6874 2832 2920 k.EdgeWeight(2) │ │ │ │ -00015f60: 3d20 2d30 2e35 663b 3c2f 6469 763e 0a3c = -0.5f;
.< │ │ │ │ -00015f70: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00015f80: 3e3c 6120 6964 3d22 6c30 3035 3538 2220 > 558 tan1M │ │ │ │ -00015fd0: 6173 6b2e 4564 6765 5765 6967 6874 2833 ask.EdgeWeight(3 │ │ │ │ -00015fe0: 2920 3d20 2d31 2e30 663b 3c2f 6469 763e ) = -1.0f;
│ │ │ │ -00015ff0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00016020: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 559 tan │ │ │ │ -00016050: 314d 6173 6b2e 4564 6765 5765 6967 6874 1Mask.EdgeWeight │ │ │ │ -00016060: 2834 2920 3d20 2d30 2e35 663b 3c2f 6469 (4) = -0.5f;.
560 │ │ │ │ -000160c0: 3c2f 7370 616e 3e20 2020 2020 2020 2074 t │ │ │ │ -000160d0: 616e 314d 6173 6b2e 4564 6765 5765 6967 an1Mask.EdgeWeig │ │ │ │ -000160e0: 6874 2835 2920 3d20 2030 2e35 663b 3c2f ht(5) = 0.5f;.
5 │ │ │ │ -00016140: 3631 3c2f 7370 616e 3e20 3c2f 6469 763e 61
│ │ │ │ -00016150: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00016180: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 562 tan │ │ │ │ -000161b0: 324d 6173 6b2e 4564 6765 5765 6967 6874 2Mask.EdgeWeight │ │ │ │ -000161c0: 2830 2920 3d20 2030 2e30 663b 3c2f 6469 (0) = 0.0f;.
563 │ │ │ │ -00016220: 3c2f 7370 616e 3e20 2020 2020 2020 2074 t │ │ │ │ -00016230: 616e 324d 6173 6b2e 4564 6765 5765 6967 an2Mask.EdgeWeig │ │ │ │ -00016240: 6874 2831 2920 3d20 2052 6f6f 7433 6279 ht(1) = Root3by │ │ │ │ -00016250: 323b 3c2f 6469 763e 0a3c 6469 7620 636c 2;
.
564 │ │ │ │ -000162b0: 2020 2020 2074 616e 324d 6173 6b2e 4564 tan2Mask.Ed │ │ │ │ -000162c0: 6765 5765 6967 6874 2832 2920 3d20 2052 geWeight(2) = R │ │ │ │ -000162d0: 6f6f 7433 6279 323b 3c2f 6469 763e 0a3c oot3by2;
.< │ │ │ │ -000162e0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -000162f0: 3e3c 6120 6964 3d22 6c30 3035 3635 2220 > 565 tan2M │ │ │ │ -00016340: 6173 6b2e 4564 6765 5765 6967 6874 2833 ask.EdgeWeight(3 │ │ │ │ -00016350: 2920 3d20 2030 2e30 663b 3c2f 6469 763e ) = 0.0f;
│ │ │ │ -00016360: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00016390: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 566 tan │ │ │ │ -000163c0: 324d 6173 6b2e 4564 6765 5765 6967 6874 2Mask.EdgeWeight │ │ │ │ -000163d0: 2834 2920 3d20 2d52 6f6f 7433 6279 323b (4) = -Root3by2; │ │ │ │ -000163e0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00016430: 2035 3637 3c2f 7370 616e 3e20 2020 2020 567 │ │ │ │ -00016440: 2020 2074 616e 324d 6173 6b2e 4564 6765 tan2Mask.Edge │ │ │ │ -00016450: 5765 6967 6874 2835 2920 3d20 2d52 6f6f Weight(5) = -Roo │ │ │ │ -00016460: 7433 6279 323b 3c2f 6469 763e 0a3c 6469 t3by2;
.< │ │ │ │ -00016480: 6120 6964 3d22 6c30 3035 3638 2220 6e61 a id="l00568" na │ │ │ │ -00016490: 6d65 3d22 6c30 3035 3638 223e 3c2f 613e me="l00568"> │ │ │ │ -000164a0: 3c73 7061 6e20 636c 6173 733d 226c 696e 568 } else {.
5 │ │ │ │ -00016540: 3639 3c2f 7370 616e 3e20 2020 2020 2020 69 │ │ │ │ -00016550: 203c 7370 616e 2063 6c61 7373 3d22 6b65 doubl │ │ │ │ -00016570: 653c 2f73 7061 6e3e 2061 6c70 6861 203d e alpha = │ │ │ │ -00016580: 2032 2e30 6620 2a20 4d5f 5049 202f 2076 2.0f * M_PI / v │ │ │ │ -00016590: 616c 656e 6365 3b3c 2f64 6976 3e0a 3c64 alence;
. │ │ │ │ -000165b0: 3c61 2069 643d 226c 3030 3537 3022 206e 570 for ( │ │ │ │ -00016620: 3c73 7061 6e20 636c 6173 733d 226b 6579 int
i = 0; i &l │ │ │ │ -00016650: 743b 2076 616c 656e 6365 3b20 2b2b 6929 t; valence; ++i) │ │ │ │ -00016660: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
571 │ │ │ │ -000166c0: 2020 2020 2020 2020 203c 7370 616e 2063 double │ │ │ │ -000166f0: 2061 6c70 6861 4920 3d20 616c 7068 6120 alphaI = alpha │ │ │ │ -00016700: 2a20 693b 3c2f 6469 763e 0a3c 6469 7620 * i;
.
572 │ │ │ │ -00016760: 2020 2020 2020 2020 2020 2074 616e 314d tan1M │ │ │ │ -00016770: 6173 6b2e 4564 6765 5765 6967 6874 2869 ask.EdgeWeight(i │ │ │ │ -00016780: 2920 3d20 2857 6569 6768 7429 2073 7464 ) = (Weight) std │ │ │ │ -00016790: 3a3a 636f 7328 616c 7068 6149 293b 3c2f ::cos(alphaI);.
5 │ │ │ │ -000167f0: 3733 3c2f 7370 616e 3e20 2020 2020 2020 73 │ │ │ │ -00016800: 2020 2020 2074 616e 324d 6173 6b2e 4564 tan2Mask.Ed │ │ │ │ -00016810: 6765 5765 6967 6874 2869 2920 3d20 2857 geWeight(i) = (W │ │ │ │ -00016820: 6569 6768 7429 2073 7464 3a3a 7369 6e28 eight) std::sin( │ │ │ │ -00016830: 616c 7068 6149 293b 3c2f 6469 763e 0a3c alphaI);
.< │ │ │ │ -00016840: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00016850: 3e3c 6120 6964 3d22 6c30 3035 3734 2220 > 574 }.
575 │ │ │ │ -000168f0: 3c2f 7370 616e 3e20 2020 207d 3c2f 6469 }.
576 │ │ │ │ -00016950: 3c2f 7370 616e 3e7d 3c2f 6469 763e 0a3c }
.< │ │ │ │ -00016960: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -000169b0: 3537 373c 2f73 7061 6e3e 203c 2f64 6976 577
.
578< │ │ │ │ -00016a10: 2f73 7061 6e3e 7d20 3c73 7061 6e20 636c /span>} // │ │ │ │ -00016a30: 2065 6e64 206e 616d 6573 7061 6365 2053 end namespace S │ │ │ │ -00016a40: 6463 3c2f 7370 616e 3e3c 2f64 6976 3e0a dc
. │ │ │ │ -00016a50: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.< │ │ │ │ -00016b00: 6120 6964 3d22 6c30 3035 3830 2220 6e61 a id="l00580" na │ │ │ │ -00016b10: 6d65 3d22 6c30 3035 3830 223e 3c2f 613e me="l00580"> │ │ │ │ -00016b20: 3c73 7061 6e20 636c 6173 733d 226c 696e 580using nam │ │ │ │ -00016b60: 6573 7061 6365 203c 2f73 7061 6e3e 4f50 espace OP │ │ │ │ -00016b70: 454e 5355 4244 4956 5f56 4552 5349 4f4e ENSUBDIV_VERSION │ │ │ │ -00016b80: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00016bd0: 2020 3538 313c 2f73 7061 6e3e 7d20 3c73 581} // end names │ │ │ │ -00016c00: 7061 6365 204f 7065 6e53 7562 6469 763c pace OpenSubdiv< │ │ │ │ -00016c10: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -00016c30: 6120 6964 3d22 6c30 3035 3832 2220 6e61 a id="l00582" na │ │ │ │ -00016c40: 6d65 3d22 6c30 3035 3832 223e 3c2f 613e me="l00582"> │ │ │ │ -00016c50: 3c73 7061 6e20 636c 6173 733d 226c 696e 582
.
583#endif < │ │ │ │ -00016cf0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>/* O │ │ │ │ -00016d10: 5045 4e53 5542 4449 5633 5f53 4443 5f4c PENSUBDIV3_SDC_L │ │ │ │ -00016d20: 4f4f 505f 5343 4845 4d45 5f48 202a 2f3c OOP_SCHEME_H */< │ │ │ │ -00016d30: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>
.< │ │ │ │ -00016d60: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ -00016d70: 6964 3d22 6161 3030 3930 355f 6874 6d6c id="aa00905_html │ │ │ │ -00016d80: 223e 3c64 6976 2063 6c61 7373 3d22 7474 "> │ │ │ │ -00016dc0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ -00016de0: 3c2f 623e 203c 6120 6872 6566 3d22 6130 limits. │ │ │ │ -00016e10: 683a 3332 3c2f 613e 3c2f 6469 763e 3c2f h:32
.
Sp │ │ │ │ -00016f00: 6c69 743c 2f64 6976 3e3c 6469 7620 636c lit
Enum │ │ │ │ -00016f20: 6572 6174 6564 2074 7970 6520 666f 7220 erated type for │ │ │ │ -00016f30: 616c 6c20 6661 6365 2073 706c 6974 7469 all face splitti │ │ │ │ -00016f40: 6e67 2073 6368 656d 6573 2e3c 2f64 6976 ng schemes.
Definitio │ │ │ │ -00016f70: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n types. │ │ │ │ -00016fa0: 683a 3437 3c2f 613e 3c2f 6469 763e 3c2f h:47
.
< │ │ │ │ -00017030: 6120 6872 6566 3d22 6130 3039 3133 2e68 a href="a00913.h │ │ │ │ -00017040: 746d 6c23 6136 3165 6632 6638 6637 3635 tml#a61ef2f8f765 │ │ │ │ -00017050: 6261 3137 6638 3033 3662 6363 3066 3066 ba17f8036bcc0f0f │ │ │ │ -00017060: 6138 3837 6261 3331 3935 3962 3336 6336 a887ba31959b36c6 │ │ │ │ -00017070: 3738 6663 6235 3630 6634 3738 6563 6237 78fcb560f478ecb7 │ │ │ │ -00017080: 6330 3531 6635 223e 4f70 656e 5375 6264 c051f5">OpenSubd │ │ │ │ -00017090: 6976 3a3a 4f50 454e 5355 4244 4956 5f56 iv::OPENSUBDIV_V │ │ │ │ -000170a0: 4552 5349 4f4e 3a3a 5364 633a 3a53 504c ERSION::Sdc::SPL │ │ │ │ -000170b0: 4954 5f54 4f5f 5452 4953 3c2f 613e 3c2f IT_TO_TRIS
@ SPLIT_ │ │ │ │ -000170e0: 544f 5f54 5249 533c 2f64 6976 3e3c 6469 TO_TRIS
│ │ │ │ -00017100: 5573 6564 2062 7920 4c6f 6f70 2e3c 2f64 Used by Loop.
Definit │ │ │ │ -00017130: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion type │ │ │ │ -00017160: 732e 683a 3439 3c2f 613e 3c2f 6469 763e s.h:49
│ │ │ │ -00017170: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
void a │ │ │ │ -00017270: 7373 6967 6e53 6d6f 6f74 684d 6173 6b46 ssignSmoothMaskF │ │ │ │ -00017280: 6f72 4564 6765 2845 4447 4520 636f 6e73 orEdge(EDGE cons │ │ │ │ -00017290: 7420 2661 6d70 3b65 6467 652c 204d 4153 t &edge, MAS │ │ │ │ -000172a0: 4b20 2661 6d70 3b6d 6173 6b29 2063 6f6e K &mask) con │ │ │ │ -000172b0: 7374 3c2f 6469 763e 3c2f 6469 763e 0a3c st
.< │ │ │ │ -000172c0: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ -000172d0: 6964 3d22 6161 3031 3334 315f 6874 6d6c id="aa01341_html │ │ │ │ -000172e0: 5f61 3134 6239 3764 6464 6535 6662 6133 _a14b97ddde5fba3 │ │ │ │ -000172f0: 3163 6137 6639 3333 3530 3865 6536 3439 1ca7f933508ee649 │ │ │ │ -00017300: 6461 223e 3c64 6976 2063 6c61 7373 3d22 da">static Split G │ │ │ │ -000173c0: 6574 546f 706f 6c6f 6769 6361 6c53 706c etTopologicalSpl │ │ │ │ -000173d0: 6974 5479 7065 2829 3c2f 6469 763e 3c2f itType()
.
void a │ │ │ │ -000174e0: 7373 6967 6e43 7265 6173 654d 6173 6b46 ssignCreaseMaskF │ │ │ │ -000174f0: 6f72 5665 7274 6578 2856 4552 5445 5820 orVertex(VERTEX │ │ │ │ -00017500: 636f 6e73 7420 2661 6d70 3b65 6467 652c const &edge, │ │ │ │ -00017510: 204d 4153 4b20 2661 6d70 3b6d 6173 6b2c MASK &mask, │ │ │ │ -00017520: 2069 6e74 2063 6f6e 7374 2063 7265 6173 int const creas │ │ │ │ -00017530: 6545 6e64 735b 325d 2920 636f 6e73 743c eEnds[2]) const< │ │ │ │ -00017540: 2f64 6976 3e3c 2f64 6976 3e0a 3c64 6976 /div>
.
void assign │ │ │ │ -00017650: 4372 6561 7365 4c69 6d69 7454 616e 6765 CreaseLimitTange │ │ │ │ -00017660: 6e74 4d61 736b 7328 5645 5254 4558 2063 ntMasks(VERTEX c │ │ │ │ -00017670: 6f6e 7374 2026 616d 703b 7665 7274 6578 onst &vertex │ │ │ │ -00017680: 2c20 4d41 534b 2026 616d 703b 7461 6e31 , MASK &tan1 │ │ │ │ -00017690: 2c20 4d41 534b 2026 616d 703b 7461 6e32 , MASK &tan2 │ │ │ │ -000176a0: 2c20 696e 7420 636f 6e73 7420 6372 6561 , int const crea │ │ │ │ -000176b0: 7365 456e 6473 5b32 5d29 2063 6f6e 7374 seEnds[2]) const │ │ │ │ -000176c0: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.
stati │ │ │ │ -000177c0: 6320 696e 7420 4765 7452 6567 756c 6172 c int GetRegular │ │ │ │ -000177d0: 4661 6365 5369 7a65 2829 3c2f 6469 763e FaceSize()
│ │ │ │ -000177e0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
void a │ │ │ │ -000178e0: 7373 6967 6e43 7265 6173 654d 6173 6b46 ssignCreaseMaskF │ │ │ │ -000178f0: 6f72 4564 6765 2845 4447 4520 636f 6e73 orEdge(EDGE cons │ │ │ │ -00017900: 7420 2661 6d70 3b65 6467 652c 204d 4153 t &edge, MAS │ │ │ │ -00017910: 4b20 2661 6d70 3b6d 6173 6b29 2063 6f6e K &mask) con │ │ │ │ -00017920: 7374 3c2f 6469 763e 3c64 6976 2063 6c61 st
De │ │ │ │ -00017940: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:317
.
v │ │ │ │ -00017a80: 6f69 6420 6173 7369 676e 536d 6f6f 7468 oid assignSmooth │ │ │ │ -00017a90: 4c69 6d69 744d 6173 6b28 5645 5254 4558 LimitMask(VERTEX │ │ │ │ -00017aa0: 2063 6f6e 7374 2026 616d 703b 7665 7274 const &vert │ │ │ │ -00017ab0: 6578 2c20 4d41 534b 2026 616d 703b 706f ex, MASK &po │ │ │ │ -00017ac0: 7329 2063 6f6e 7374 3c2f 6469 763e 3c2f s) const
.
OpenSubdiv │ │ │ │ -00017b70: 3a3a 4f50 454e 5355 4244 4956 5f56 4552 ::OPENSUBDIV_VER │ │ │ │ -00017b80: 5349 4f4e 3a3a 5364 633a 3a53 6368 656d SION::Sdc::Schem │ │ │ │ -00017b90: 653a 3a47 6574 4c6f 6361 6c4e 6569 6768 e::GetLocalNeigh │ │ │ │ -00017ba0: 626f 7268 6f6f 6453 697a 653c 2f61 3e3c borhoodSize< │ │ │ │ -00017bb0: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
static │ │ │ │ -00017bd0: 696e 7420 4765 744c 6f63 616c 4e65 6967 int GetLocalNeig │ │ │ │ -00017be0: 6862 6f72 686f 6f64 5369 7a65 2829 3c2f hborhoodSize()
.
│ │ │ │ -00017c40: 3c64 6976 2063 6c61 7373 3d22 7474 6e61
│ │ │ │ -00017cf0: 766f 6964 2061 7373 6967 6e43 6f72 6e65 void assignCorne │ │ │ │ -00017d00: 724d 6173 6b46 6f72 5665 7274 6578 2856 rMaskForVertex(V │ │ │ │ -00017d10: 4552 5445 5820 636f 6e73 7420 2661 6d70 ERTEX const & │ │ │ │ -00017d20: 3b65 6467 652c 204d 4153 4b20 2661 6d70 ;edge, MASK & │ │ │ │ -00017d30: 3b6d 6173 6b29 2063 6f6e 7374 3c2f 6469 ;mask) const
Definiti │ │ │ │ -00017d60: 6f6e 3c2f 623e 203c 6120 6872 6566 3d22 on schem │ │ │ │ -00017d90: 652e 683a 3333 313c 2f61 3e3c 2f64 6976 e.h:331
.
OpenSub │ │ │ │ -00017e40: 6469 763a 3a4f 5045 4e53 5542 4449 565f div::OPENSUBDIV_ │ │ │ │ -00017e50: 5645 5253 494f 4e3a 3a53 6463 3a3a 5363 VERSION::Sdc::Sc │ │ │ │ -00017e60: 6865 6d65 3a3a 6173 7369 676e 4372 6561 heme::assignCrea │ │ │ │ -00017e70: 7365 4c69 6d69 744d 6173 6b3c 2f61 3e3c seLimitMask< │ │ │ │ -00017e80: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
void as │ │ │ │ -00017ea0: 7369 676e 4372 6561 7365 4c69 6d69 744d signCreaseLimitM │ │ │ │ -00017eb0: 6173 6b28 5645 5254 4558 2063 6f6e 7374 ask(VERTEX const │ │ │ │ -00017ec0: 2026 616d 703b 7665 7274 6578 2c20 4d41 &vertex, MA │ │ │ │ -00017ed0: 534b 2026 616d 703b 706f 732c 2069 6e74 SK &pos, int │ │ │ │ -00017ee0: 2063 6f6e 7374 2063 7265 6173 6545 6e64 const creaseEnd │ │ │ │ -00017ef0: 735b 325d 2920 636f 6e73 743c 2f64 6976 s[2]) const
.< │ │ │ │ -00018050: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
< │ │ │ │ -000180b0: 6120 6872 6566 3d22 6130 3133 3431 2e68 a href="a01341.h │ │ │ │ -000180c0: 746d 6c23 6138 6637 6539 3833 6232 3139 tml#a8f7e983b219 │ │ │ │ -000180d0: 3561 6336 6233 3838 6337 6136 6462 3137 5ac6b388c7a6db17 │ │ │ │ -000180e0: 6638 6362 3022 3e4f 7065 6e53 7562 6469 f8cb0">OpenSubdi │ │ │ │ -000180f0: 763a 3a4f 5045 4e53 5542 4449 565f 5645 v::OPENSUBDIV_VE │ │ │ │ -00018100: 5253 494f 4e3a 3a53 6463 3a3a 5363 6865 RSION::Sdc::Sche │ │ │ │ -00018110: 6d65 3a3a 4765 7452 6567 756c 6172 5665 me::GetRegularVe │ │ │ │ -00018120: 7274 6578 5661 6c65 6e63 653c 2f61 3e3c rtexValence< │ │ │ │ -00018130: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
static │ │ │ │ -00018150: 696e 7420 4765 7452 6567 756c 6172 5665 int GetRegularVe │ │ │ │ -00018160: 7274 6578 5661 6c65 6e63 6528 293c 2f64 rtexValence()
.< │ │ │ │ -00018260: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ -00018270: 6922 3e76 6f69 6420 6173 7369 676e 536d i">void assignSm │ │ │ │ -00018280: 6f6f 7468 4c69 6d69 7454 616e 6765 6e74 oothLimitTangent │ │ │ │ -00018290: 4d61 736b 7328 5645 5254 4558 2063 6f6e Masks(VERTEX con │ │ │ │ -000182a0: 7374 2026 616d 703b 7665 7274 6578 2c20 st &vertex, │ │ │ │ -000182b0: 4d41 534b 2026 616d 703b 7461 6e31 2c20 MASK &tan1, │ │ │ │ -000182c0: 4d41 534b 2026 616d 703b 7461 6e32 2920 MASK &tan2) │ │ │ │ -000182d0: 636f 6e73 743c 2f64 6976 3e3c 2f64 6976 const
.
< │ │ │ │ -000183c0: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ -000183d0: 6922 3e76 6f69 6420 6173 7369 676e 436f i">void assignCo │ │ │ │ -000183e0: 726e 6572 4c69 6d69 744d 6173 6b28 5645 rnerLimitMask(VE │ │ │ │ -000183f0: 5254 4558 2063 6f6e 7374 2026 616d 703b RTEX const & │ │ │ │ -00018400: 7665 7274 6578 2c20 4d41 534b 2026 616d vertex, MASK &am │ │ │ │ -00018410: 703b 706f 7329 2063 6f6e 7374 3c2f 6469 p;pos) const
.void assignCor │ │ │ │ -00018530: 6e65 724c 696d 6974 5461 6e67 656e 744d nerLimitTangentM │ │ │ │ -00018540: 6173 6b73 2856 4552 5445 5820 636f 6e73 asks(VERTEX cons │ │ │ │ -00018550: 7420 2661 6d70 3b76 6572 7465 782c 204d t &vertex, M │ │ │ │ -00018560: 4153 4b20 2661 6d70 3b74 616e 312c 204d ASK &tan1, M │ │ │ │ -00018570: 4153 4b20 2661 6d70 3b74 616e 3229 2063 ASK &tan2) c │ │ │ │ -00018580: 6f6e 7374 3c2f 6469 763e 3c2f 6469 763e onst
│ │ │ │ -00018590: 0a3c 2f64 6976 3e3c 212d 2d20 6672 6167 .
. │ │ │ │ -000185c0: 3c2f 6469 763e 3c21 2d2d 2064 6f63 2d63
... │ │ │ │ -00018850: 0a3c 2f68 746d 6c3e 0a .. │ │ │ │ +00011120: 6e65 6e6f 223e 2020 3431 323c 2f73 7061 neno"> 412 //
.
< │ │ │ │ +00011190: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +000111a0: 6e6f 223e 2020 3431 333c 2f73 7061 6e3e no"> 413 │ │ │ │ +000111b0: 2020 2020 3c73 7061 6e20 636c 6173 733d // We │ │ │ │ +000111d0: 2068 6176 6520 6120 4372 6561 7365 206f have a Crease o │ │ │ │ +000111e0: 6e20 7468 6520 7061 7265 6e74 2061 6e64 n the parent and │ │ │ │ +000111f0: 2074 6865 2063 6869 6c64 2077 6173 2065 the child was e │ │ │ │ +00011200: 6974 6865 7220 7370 6563 6966 6965 6420 ither specified │ │ │ │ +00011210: 6173 2053 6d6f 6f74 683c 2f73 7061 6e3e as Smooth │ │ │ │ +00011220: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00011270: 2034 3134 3c2f 7370 616e 3e20 2020 203c 414 < │ │ │ │ +00011280: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00011290: 656e 7422 3e2f 2f20 206f 7220 7761 7320 ent">// or was │ │ │ │ +000112a0: 6e6f 7420 7370 6563 6966 6965 6420 6174 not specified at │ │ │ │ +000112b0: 2061 6c6c 202d 2d20 6465 616c 2077 6974 all -- deal wit │ │ │ │ +000112c0: 6820 7468 6520 756e 7370 6563 6966 6965 h the unspecifie │ │ │ │ +000112d0: 6420 6361 7365 2066 6972 7374 2028 6167 d case first (ag │ │ │ │ +000112e0: 6169 6e3c 2f73 7061 6e3e 3c2f 6469 763e ain
│ │ │ │ +000112f0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00011320: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 415 / │ │ │ │ +00011360: 2f20 2072 6574 7572 6e69 6e67 2061 2043 / returning a C │ │ │ │ +00011370: 7265 6173 6520 6d61 736b 2069 6620 7468 rease mask if th │ │ │ │ +00011380: 6520 6368 696c 6420 6973 2061 6c73 6f20 e child is also │ │ │ │ +00011390: 6465 7465 726d 696e 6564 2074 6f20 6265 determined to be │ │ │ │ +000113a0: 2061 2043 7265 6173 6529 2061 6e64 3c2f a Crease) and
.
< │ │ │ │ +000113f0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00011400: 6e6f 223e 2020 3431 363c 2f73 7061 6e3e no"> 416 │ │ │ │ +00011410: 2020 2020 3c73 7061 6e20 636c 6173 733d // co │ │ │ │ +00011430: 6e74 696e 7565 2069 6620 7765 2068 6176 ntinue if we hav │ │ │ │ +00011440: 6520 6120 7472 616e 7369 7469 6f6e 2074 e a transition t │ │ │ │ +00011450: 6f20 536d 6f6f 7468 2e3c 2f73 7061 6e3e o Smooth. │ │ │ │ +00011460: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +000114b0: 2034 3137 3c2f 7370 616e 3e20 2020 203c 417 < │ │ │ │ +000114c0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +000114d0: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
4 │ │ │ │ +00011530: 3138 3c2f 7370 616e 3e20 2020 203c 7370 18 // Note when │ │ │ │ +00011560: 2071 7561 6c69 6679 696e 6720 7468 6520 qualifying the │ │ │ │ +00011570: 6368 696c 6420 7468 6174 2069 6620 7468 child that if th │ │ │ │ +00011580: 6520 7061 7265 6e74 2073 6861 7270 6e65 e parent sharpne │ │ │ │ +00011590: 7373 2026 6774 3b20 312e 302c 2072 6567 ss > 1.0, reg │ │ │ │ +000115a0: 6172 646c 6573 733c 2f73 7061 6e3e 3c2f ardless.
4 │ │ │ │ +00011600: 3139 3c2f 7370 616e 3e20 2020 203c 7370 19 // of the cr │ │ │ │ +00011630: 6561 7369 6e67 206d 6574 686f 642c 2077 easing method, w │ │ │ │ +00011640: 6865 7468 6572 2074 6865 2063 6869 6c64 hether the child │ │ │ │ +00011650: 2073 6861 7270 6e65 7373 2076 616c 7565 sharpness value │ │ │ │ +00011660: 7320 6465 6361 7920 746f 207a 6572 6f20 s decay to zero │ │ │ │ +00011670: 6973 3c2f 7370 616e 3e3c 2f64 6976 3e0a is
. │ │ │ │ +00011680: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ +00011780: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00011790: 6e6f 223e 2020 3432 313c 2f73 7061 6e3e no"> 421 │ │ │ │ +000117a0: 2020 2020 3c73 7061 6e20 636c 6173 733d // sh │ │ │ │ +000117c0: 6172 706e 6573 7329 2069 7320 2667 743b arpness) is > │ │ │ │ +000117d0: 2031 2e30 2c20 616e 6420 7768 656e 2063 1.0, and when c │ │ │ │ +000117e0: 6c61 6d70 6564 2074 6f20 3120 6566 6665 lamped to 1 effe │ │ │ │ +000117f0: 6374 6976 656c 7920 7969 656c 6473 2061 ctively yields a │ │ │ │ +00011800: 2066 756c 6c20 6372 6561 7365 2e3c 2f73 full crease.
.
422 │ │ │ │ +00011870: 2020 203c 7370 616e 2063 6c61 7373 3d22 //
.
423 │ │ │ │ +000118f0: 203c 7370 616e 2063 6c61 7373 3d22 6b65 if (childRule │ │ │ │ +00011920: 3d3d 203c 6120 636c 6173 733d 2263 6f64 == Crease::RU │ │ │ │ +000119a0: 4c45 5f55 4e4b 4e4f 574e 3c2f 613e 2920 LE_UNKNOWN) │ │ │ │ +000119b0: 7b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 {
.
│ │ │ │ +00011a00: 2020 3432 343c 2f73 7061 6e3e 2020 2020 424 │ │ │ │ +00011a10: 2020 2020 3c61 2063 6c61 7373 3d22 636f │ │ │ │ +00011a40: 4372 6561 7365 3c2f 613e 2063 7265 6173 Crease creas │ │ │ │ +00011a50: 6528 5f6f 7074 696f 6e73 293b 3c2f 6469 e(_options);.
425 │ │ │ │ +00011ab0: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ +00011ac0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00011ad0: 3e3c 6120 6964 3d22 6c30 3034 3236 2220 > 426 bool │ │ │ │ +00011b40: 2063 6869 6c64 4973 4372 6561 7365 203d childIsCrease = │ │ │ │ +00011b50: 203c 7370 616e 2063 6c61 7373 3d22 6b65 false;
.
427 │ │ │ │ +00011bd0: 2020 2020 2020 203c 7370 616e 2063 6c61 if (pare │ │ │ │ +00011c00: 6e74 5275 6c65 203d 3d20 3c61 2063 6c61 ntRule == Cre │ │ │ │ +00011c80: 6173 653a 3a52 554c 455f 4352 4541 5345 ase::RULE_CREASE │ │ │ │ +00011c90: 3c2f 613e 2920 7b3c 2f64 6976 3e0a 3c64 ) {
. │ │ │ │ +00011cb0: 3c61 2069 643d 226c 3030 3432 3822 206e 428 // Child un │ │ │ │ +00011d20: 6b6e 6f77 6e20 6173 2064 6566 6175 6c74 known as default │ │ │ │ +00011d30: 2076 616c 7565 2062 7574 2070 6172 656e value but paren │ │ │ │ +00011d40: 7420 5275 6c65 2073 7065 6369 6669 6564 t Rule specified │ │ │ │ +00011d50: 2061 7320 4372 6561 7365 3c2f 7370 616e as Crease
.
│ │ │ │ +00011db0: 2020 3432 393c 2f73 7061 6e3e 2020 2020 429 │ │ │ │ +00011dc0: 2020 2020 2020 2020 6368 696c 6449 7343 childIsC │ │ │ │ +00011dd0: 7265 6173 6520 3d20 3c73 7061 6e20 636c rease = tr │ │ │ │ +00011df0: 7565 3c2f 7370 616e 3e3b 3c2f 6469 763e ue;
│ │ │ │ +00011e00: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00011e30: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 430 } < │ │ │ │ +00011e60: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00011e70: 6f72 6466 6c6f 7722 3e65 6c73 653c 2f73 ordflow">else i │ │ │ │ +00011ea0: 663c 2f73 7061 6e3e 2028 6564 6765 2e47 f (edge.G │ │ │ │ +00011eb0: 6574 5368 6172 706e 6573 7328 2920 2667 etSharpness() &g │ │ │ │ +00011ec0: 743b 3d20 312e 3066 2920 7b3c 2f64 6976 t;= 1.0f) {
.
431< │ │ │ │ +00011f20: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ +00011f30: 2020 3c73 7061 6e20 636c 6173 733d 2263 // Shar │ │ │ │ +00011f50: 706e 6573 7320 2667 743b 3d20 312e 3020 pness >= 1.0 │ │ │ │ +00011f60: 616c 7761 7973 2061 2063 7265 6173 6520 always a crease │ │ │ │ +00011f70: 2d2d 2073 6565 206e 6f74 6520 6162 6f76 -- see note abov │ │ │ │ +00011f80: 653c 2f73 7061 6e3e 3c2f 6469 763e 0a3c e
.< │ │ │ │ +00011f90: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00011fa0: 3e3c 6120 6964 3d22 6c30 3034 3332 2220 > 432 c │ │ │ │ +00011ff0: 6869 6c64 4973 4372 6561 7365 203d 203c hildIsCrease = < │ │ │ │ +00012000: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00012010: 6f72 6422 3e74 7275 653c 2f73 7061 6e3e ord">true │ │ │ │ +00012020: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +00012070: 2020 3433 333c 2f73 7061 6e3e 2020 2020 433 │ │ │ │ +00012080: 2020 2020 7d20 3c73 7061 6e20 636c 6173 } │ │ │ │ +000120a0: 656c 7365 3c2f 7370 616e 3e20 3c73 7061 else if │ │ │ │ +000120d0: 2863 7265 6173 652e 3c61 2063 6c61 7373 (crease.IsUnifo │ │ │ │ +00012130: 726d 3c2f 613e 2829 2920 7b3c 2f64 6976 rm()) {
.
434< │ │ │ │ +00012190: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ +000121a0: 2020 3c73 7061 6e20 636c 6173 733d 2263 // Shar │ │ │ │ +000121c0: 706e 6573 7320 266c 743b 2031 2e30 2069 pness < 1.0 i │ │ │ │ +000121d0: 7320 6775 6172 616e 7465 6564 2074 6f20 s guaranteed to │ │ │ │ +000121e0: 6465 6361 7920 746f 2030 2e30 2066 6f72 decay to 0.0 for │ │ │ │ +000121f0: 2055 6e69 666f 726d 2063 6869 6c64 2065 Uniform child e │ │ │ │ +00012200: 6467 6573 3c2f 7370 616e 3e3c 2f64 6976 dges
.
435< │ │ │ │ +00012260: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ +00012270: 2020 6368 696c 6449 7343 7265 6173 6520 childIsCrease │ │ │ │ +00012280: 3d20 3c73 7061 6e20 636c 6173 733d 226b = false;
.
< │ │ │ │ +000122e0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +000122f0: 6e6f 223e 2020 3433 363c 2f73 7061 6e3e no"> 436 │ │ │ │ +00012300: 2020 2020 2020 2020 7d20 3c73 7061 6e20 } else │ │ │ │ +00012330: 7b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 {
.
│ │ │ │ +00012380: 2020 3433 373c 2f73 7061 6e3e 2020 2020 437 │ │ │ │ +00012390: 2020 2020 2020 2020 3c73 7061 6e20 636c // │ │ │ │ +000123b0: 2020 5368 6172 706e 6573 7320 266c 743b Sharpness < │ │ │ │ +000123c0: 3d20 312e 3020 646f 6573 206e 6f74 206e = 1.0 does not n │ │ │ │ +000123d0: 6563 6573 7361 7269 6c79 2064 6563 6179 ecessarily decay │ │ │ │ +000123e0: 2074 6f20 302e 3020 666f 7220 626f 7468 to 0.0 for both │ │ │ │ +000123f0: 2063 6869 6c64 2065 6467 6573 2e2e 2e3c child edges...< │ │ │ │ +00012400: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ +00012420: 6120 6964 3d22 6c30 3034 3338 2220 6e61 a id="l00438" na │ │ │ │ +00012430: 6d65 3d22 6c30 3034 3338 223e 3c2f 613e me="l00438"> │ │ │ │ +00012440: 3c73 7061 6e20 636c 6173 733d 226c 696e 438 float cEdgeSharpne │ │ │ │ +000124a0: 7373 5b32 5d3b 3c2f 6469 763e 0a3c 6469 ss[2];
.< │ │ │ │ +000124c0: 6120 6964 3d22 6c30 3034 3339 2220 6e61 a id="l00439" na │ │ │ │ +000124d0: 6d65 3d22 6c30 3034 3339 223e 3c2f 613e me="l00439"> │ │ │ │ +000124e0: 3c73 7061 6e20 636c 6173 733d 226c 696e 439 edg │ │ │ │ +00012510: 652e 4765 7443 6869 6c64 5368 6172 706e e.GetChildSharpn │ │ │ │ +00012520: 6573 7365 7328 6372 6561 7365 2c20 6345 esses(crease, cE │ │ │ │ +00012530: 6467 6553 6861 7270 6e65 7373 293b 3c2f dgeSharpness);.
4 │ │ │ │ +00012590: 3430 3c2f 7370 616e 3e20 2020 2020 2020 40 │ │ │ │ +000125a0: 2020 2020 2063 6869 6c64 4973 4372 6561 childIsCrea │ │ │ │ +000125b0: 7365 203d 2028 6345 6467 6553 6861 7270 se = (cEdgeSharp │ │ │ │ +000125c0: 6e65 7373 5b30 5d20 2667 743b 2030 2e30 ness[0] > 0.0 │ │ │ │ +000125d0: 6629 2026 616d 703b 2661 6d70 3b20 2863 f) && (c │ │ │ │ +000125e0: 4564 6765 5368 6172 706e 6573 735b 315d EdgeSharpness[1] │ │ │ │ +000125f0: 2026 6774 3b20 302e 3066 293b 3c2f 6469 > 0.0f);.
441 │ │ │ │ +00012650: 3c2f 7370 616e 3e20 2020 2020 2020 207d } │ │ │ │ +00012660: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +000126b0: 2034 3432 3c2f 7370 616e 3e20 2020 2020 442 │ │ │ │ +000126c0: 2020 203c 7370 616e 2063 6c61 7373 3d22 if< │ │ │ │ +000126e0: 2f73 7061 6e3e 2028 6368 696c 6449 7343 /span> (childIsC │ │ │ │ +000126f0: 7265 6173 6529 207b 3c2f 6469 763e 0a3c rease) {
.< │ │ │ │ +00012700: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00012710: 3e3c 6120 6964 3d22 6c30 3034 3433 2220 > 443 a │ │ │ │ +00012760: 7373 6967 6e43 7265 6173 654d 6173 6b46 ssignCreaseMaskF │ │ │ │ +00012770: 6f72 4564 6765 2865 6467 652c 206d 6173 orEdge(edge, mas │ │ │ │ +00012780: 6b29 3b3c 2f64 6976 3e0a 3c64 6976 2063 k);
.
444 │ │ │ │ +000127e0: 2020 2020 2020 2020 2020 3c73 7061 6e20 return;
.
445 │ │ │ │ +00012870: 2020 2020 207d 3c2f 6469 763e 0a3c 6469 }
.< │ │ │ │ +00012890: 6120 6964 3d22 6c30 3034 3436 2220 6e61 a id="l00446" na │ │ │ │ +000128a0: 6d65 3d22 6c30 3034 3436 223e 3c2f 613e me="l00446"> │ │ │ │ +000128b0: 3c73 7061 6e20 636c 6173 733d 226c 696e 446 }
.< │ │ │ │ +000128f0: 6120 6964 3d22 6c30 3034 3437 2220 6e61 a id="l00447" na │ │ │ │ +00012900: 6d65 3d22 6c30 3034 3437 223e 3c2f 613e me="l00447"> │ │ │ │ +00012910: 3c73 7061 6e20 636c 6173 733d 226c 696e 447
.
448 │ │ │ │ +00012990: 203c 7370 616e 2063 6c61 7373 3d22 636f // │ │ │ │ +000129b0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00012a00: 2034 3439 3c2f 7370 616e 3e20 2020 203c 449 < │ │ │ │ +00012a10: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00012a20: 656e 7422 3e2f 2f20 2057 6520 6172 6520 ent">// We are │ │ │ │ +00012a30: 6e6f 7720 6c65 6674 2077 6974 6820 7468 now left with th │ │ │ │ +00012a40: 6520 4372 6561 7365 2d74 6f2d 536d 6f6f e Crease-to-Smoo │ │ │ │ +00012a50: 7468 2063 6173 6520 2d2d 2063 6f6d 7075 th case -- compu │ │ │ │ +00012a60: 7465 2074 6865 2053 6d6f 6f74 6820 6d61 te the Smooth ma │ │ │ │ +00012a70: 736b 3c2f 7370 616e 3e3c 2f64 6976 3e0a sk
. │ │ │ │ +00012a80: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
│ │ │ │ +00012b90: 2020 3435 313c 2f73 7061 6e3e 2020 2020 451 │ │ │ │ +00012ba0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ +00012bc0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00012c10: 3435 323c 2f73 7061 6e3e 2020 2020 3c73 452 // A genera │ │ │ │ +00012c40: 6c20 636f 6d62 696e 6174 696f 6e20 6f66 l combination of │ │ │ │ +00012c50: 2073 6570 6172 6174 656c 7920 6173 7369 separately assi │ │ │ │ +00012c60: 676e 6564 206d 6173 6b73 2068 6572 6520 gned masks here │ │ │ │ +00012c70: 2861 7320 646f 6e65 2069 6e20 7468 6520 (as done in the │ │ │ │ +00012c80: 7665 7274 6578 2d3c 2f73 7061 6e3e 3c2f vertex-.
4 │ │ │ │ +00012ce0: 3533 3c2f 7370 616e 3e20 2020 203c 7370 53 // vertex ca │ │ │ │ +00012d10: 7365 2920 6973 206f 7665 726b 696c 6c20 se) is overkill │ │ │ │ +00012d20: 2d2d 2074 7269 7669 616c 6c79 2063 6f6d -- trivially com │ │ │ │ +00012d30: 6269 6e65 2074 6865 2030 2e35 6620 7665 bine the 0.5f ve │ │ │ │ +00012d40: 7274 6578 2063 6f65 6666 6963 6965 6e74 rtex coefficient │ │ │ │ +00012d50: 2066 6f72 3c2f 7370 616e 3e3c 2f64 6976 for
.
454< │ │ │ │ +00012db0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ +00012dd0: 2f2f 2020 7468 6520 4372 6561 7365 206f // the Crease o │ │ │ │ +00012de0: 6620 7468 6520 7061 7265 6e74 2077 6974 f the parent wit │ │ │ │ +00012df0: 6820 7468 6520 7665 7274 6578 2077 6569 h the vertex wei │ │ │ │ +00012e00: 6768 7473 2061 6e64 2061 7474 656e 7561 ghts and attenua │ │ │ │ +00012e10: 7465 2074 6865 2066 6163 6520 7765 6967 te the face weig │ │ │ │ +00012e20: 6874 733c 2f73 7061 6e3e 3c2f 6469 763e hts
│ │ │ │ +00012e30: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00012e60: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 455 / │ │ │ │ +00012ea0: 2f20 2061 6363 6f72 6469 6e67 6c79 2e3c / accordingly.< │ │ │ │ +00012eb0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ +00012ed0: 6120 6964 3d22 6c30 3034 3536 2220 6e61 a id="l00456" na │ │ │ │ +00012ee0: 6d65 3d22 6c30 3034 3536 223e 3c2f 613e me="l00456"> │ │ │ │ +00012ef0: 3c73 7061 6e20 636c 6173 733d 226c 696e 456 //
.
457 │ │ │ │ +00012f90: 2020 2061 7373 6967 6e53 6d6f 6f74 684d assignSmoothM │ │ │ │ +00012fa0: 6173 6b46 6f72 4564 6765 2865 6467 652c askForEdge(edge, │ │ │ │ +00012fb0: 206d 6173 6b29 3b3c 2f64 6976 3e0a 3c64 mask);
. │ │ │ │ +00012fd0: 3c61 2069 643d 226c 3030 3435 3822 206e 458
.
459 │ │ │ │ +00013070: 2020 3c73 7061 6e20 636c 6173 733d 226b typedef< │ │ │ │ +00013090: 2f73 7061 6e3e 203c 7370 616e 2063 6c61 /span> typ │ │ │ │ +000130b0: 656e 616d 653c 2f73 7061 6e3e 204d 4153 ename MAS │ │ │ │ +000130c0: 4b3a 3a57 6569 6768 7420 5765 6967 6874 K::Weight Weight │ │ │ │ +000130d0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +00013120: 2020 3436 303c 2f73 7061 6e3e 203c 2f64 460 .
46 │ │ │ │ +00013180: 313c 2f73 7061 6e3e 2020 2020 5765 6967 1 Weig │ │ │ │ +00013190: 6874 2070 5765 6967 6874 203d 2065 6467 ht pWeight = edg │ │ │ │ +000131a0: 652e 4765 7453 6861 7270 6e65 7373 2829 e.GetSharpness() │ │ │ │ +000131b0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +00013200: 2020 3436 323c 2f73 7061 6e3e 2020 2020 462 │ │ │ │ +00013210: 5765 6967 6874 2063 5765 6967 6874 203d Weight cWeight = │ │ │ │ +00013220: 2031 2e30 6620 2d20 7057 6569 6768 743b 1.0f - pWeight; │ │ │ │ +00013230: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00013280: 2034 3633 3c2f 7370 616e 3e20 3c2f 6469 463 .
464 │ │ │ │ +000132e0: 3c2f 7370 616e 3e20 2020 206d 6173 6b2e mask. │ │ │ │ +000132f0: 5665 7274 6578 5765 6967 6874 2830 2920 VertexWeight(0) │ │ │ │ +00013300: 3d20 7057 6569 6768 7420 2a20 302e 3566 = pWeight * 0.5f │ │ │ │ +00013310: 202b 2063 5765 6967 6874 202a 206d 6173 + cWeight * mas │ │ │ │ +00013320: 6b2e 5665 7274 6578 5765 6967 6874 2830 k.VertexWeight(0 │ │ │ │ +00013330: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
465 │ │ │ │ +00013390: 206d 6173 6b2e 5665 7274 6578 5765 6967 mask.VertexWeig │ │ │ │ +000133a0: 6874 2831 2920 3d20 7057 6569 6768 7420 ht(1) = pWeight │ │ │ │ +000133b0: 2a20 302e 3566 202b 2063 5765 6967 6874 * 0.5f + cWeight │ │ │ │ +000133c0: 202a 206d 6173 6b2e 5665 7274 6578 5765 * mask.VertexWe │ │ │ │ +000133d0: 6967 6874 2831 293b 3c2f 6469 763e 0a3c ight(1);
.< │ │ │ │ +000133e0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +000133f0: 3e3c 6120 6964 3d22 6c30 3034 3636 2220 > 466
.
467 │ │ │ │ +00013490: 2020 203c 7370 616e 2063 6c61 7373 3d22 int │ │ │ │ +000134b0: 3c2f 7370 616e 3e20 6661 6365 436f 756e faceCoun │ │ │ │ +000134c0: 7420 3d20 6d61 736b 2e47 6574 4e75 6d46 t = mask.GetNumF │ │ │ │ +000134d0: 6163 6557 6569 6768 7473 2829 3b3c 2f64 aceWeights();.
46 │ │ │ │ +00013530: 383c 2f73 7061 6e3e 2020 2020 3c73 7061 8 for │ │ │ │ +00013560: 2028 3c73 7061 6e20 636c 6173 733d 226b (int< │ │ │ │ +00013580: 2f73 7061 6e3e 2069 203d 2030 3b20 6920 /span> i = 0; i │ │ │ │ +00013590: 266c 743b 2066 6163 6543 6f75 6e74 3b20 < faceCount; │ │ │ │ +000135a0: 2b2b 6929 207b 3c2f 6469 763e 0a3c 6469 ++i) {
.< │ │ │ │ +000135c0: 6120 6964 3d22 6c30 3034 3639 2220 6e61 a id="l00469" na │ │ │ │ +000135d0: 6d65 3d22 6c30 3034 3639 223e 3c2f 613e me="l00469"> │ │ │ │ +000135e0: 3c73 7061 6e20 636c 6173 733d 226c 696e 469 mask.Fa │ │ │ │ +00013610: 6365 5765 6967 6874 2869 2920 2a3d 2063 ceWeight(i) *= c │ │ │ │ +00013620: 5765 6967 6874 3b3c 2f64 6976 3e0a 3c64 Weight;
. │ │ │ │ +00013640: 3c61 2069 643d 226c 3030 3437 3022 206e 470 }
. │ │ │ │ +000136a0: 3c61 2069 643d 226c 3030 3437 3122 206e 471}
.
│ │ │ │ +000136f0: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ +00013760: 6120 6964 3d22 6c30 3034 3733 2220 6e61 a id="l00473" na │ │ │ │ +00013770: 6d65 3d22 6c30 3034 3733 223e 3c2f 613e me="l00473"> │ │ │ │ +00013780: 3c73 7061 6e20 636c 6173 733d 226c 696e 473// │ │ │ │ +000137c0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00013810: 2034 3734 3c2f 7370 616e 3e3c 7370 616e 474// The computa │ │ │ │ +00013840: 7469 6f6e 206f 6620 6120 7665 7274 6578 tion of a vertex │ │ │ │ +00013850: 2d76 6572 7465 7820 6d61 736b 2072 6571 -vertex mask req │ │ │ │ +00013860: 7569 7265 7320 696e 7370 6563 7469 6f6e uires inspection │ │ │ │ +00013870: 206f 6620 6372 6561 7369 6e67 2073 6861 of creasing sha │ │ │ │ +00013880: 7270 6e65 7373 2076 616c 7565 733c 2f73 rpness values
.
475< │ │ │ │ +000138f0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00013900: 656e 7422 3e2f 2f20 2074 6f20 6465 7465 ent">// to dete │ │ │ │ +00013910: 726d 696e 6520 7768 6174 2073 7562 6469 rmine what subdi │ │ │ │ +00013920: 7669 7369 6f6e 2052 756c 6573 2061 7070 vision Rules app │ │ │ │ +00013930: 6c79 2074 6f20 7468 6520 7061 7265 6e74 ly to the parent │ │ │ │ +00013940: 2061 6e64 2069 7473 2063 6869 6c64 2076 and its child v │ │ │ │ +00013950: 6572 7465 782c 2061 6e64 2061 6c73 6f20 ertex, and also │ │ │ │ +00013960: 746f 3c2f 7370 616e 3e3c 2f64 6976 3e0a to
. │ │ │ │ +00013970: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +000139a0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 476// de │ │ │ │ +000139e0: 7465 6374 2061 6e64 2061 7070 6c79 2061 tect and apply a │ │ │ │ +000139f0: 2074 7261 6e73 6974 696f 6e20 6265 7477 transition betw │ │ │ │ +00013a00: 6565 6e20 7477 6f20 6469 6666 6572 696e een two differin │ │ │ │ +00013a10: 6720 5275 6c65 732e 2020 5573 696e 6720 g Rules. Using │ │ │ │ +00013a20: 7468 6520 7072 6f74 6563 7465 6420 6d65 the protected me │ │ │ │ +00013a30: 7468 6f64 7320 746f 3c2f 7370 616e 3e3c thods to< │ │ │ │ +00013a40: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00013a90: 3437 373c 2f73 7061 6e3e 3c73 7061 6e20 477 │ │ │ │ +00013ab0: 2f2f 2020 6173 7369 676e 2073 7065 6369 // assign speci │ │ │ │ +00013ac0: 6669 6320 6d61 736b 732c 2074 6869 7320 fic masks, this │ │ │ │ +00013ad0: 696d 706c 656d 656e 7461 7469 6f6e 2073 implementation s │ │ │ │ +00013ae0: 686f 756c 6420 7365 7276 6520 616c 6c20 hould serve all │ │ │ │ +00013af0: 6e6f 6e2d 6c69 6e65 6172 2073 6368 656d non-linear schem │ │ │ │ +00013b00: 6573 2028 6375 7272 656e 746c 793c 2f73 es (currently
.
478< │ │ │ │ +00013b70: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00013b80: 656e 7422 3e2f 2f20 2043 6174 6d61 726b ent">// Catmark │ │ │ │ +00013b90: 2061 6e64 204c 6f6f 7029 2061 6e64 206f and Loop) and o │ │ │ │ +00013ba0: 6e6c 7920 6e65 6564 7320 746f 2062 6520 nly needs to be │ │ │ │ +00013bb0: 7370 6563 6961 6c69 7a65 6420 666f 7220 specialized for │ │ │ │ +00013bc0: 4269 6c69 6e65 6172 2074 6f20 7265 6d6f Bilinear to remo │ │ │ │ +00013bd0: 7665 2061 6c6c 2075 6e6e 6563 6573 7361 ve all unnecessa │ │ │ │ +00013be0: 7279 3c2f 7370 616e 3e3c 2f64 6976 3e0a ry
. │ │ │ │ +00013bf0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
│ │ │ │ +00013ce0: 2020 3438 303c 2f73 7061 6e3e 3c73 7061 480//
.
481< │ │ │ │ +00013d60: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ +00013d80: 5468 6520 696d 706c 656d 656e 7461 7469 The implementati │ │ │ │ +00013d90: 6f6e 2068 6572 6520 6973 2073 6c69 6768 on here is sligh │ │ │ │ +00013da0: 746c 7920 636f 6d70 6c69 6361 7465 6420 tly complicated │ │ │ │ +00013db0: 6279 2063 6f6d 6269 6e69 6e67 2074 776f by combining two │ │ │ │ +00013dc0: 2073 6365 6e61 7269 6f73 2069 6e74 6f20 scenarios into │ │ │ │ +00013dd0: 6f6e 6520 2d2d 3c2f 7370 616e 3e3c 2f64 one --.
48 │ │ │ │ +00013e30: 323c 2f73 7061 6e3e 3c73 7061 6e20 636c 2// │ │ │ │ +00013e50: 2020 6569 7468 6572 2074 6865 2063 616c either the cal │ │ │ │ +00013e60: 6c65 7220 6b6e 6f77 7320 7468 6520 7061 ler knows the pa │ │ │ │ +00013e70: 7265 6e74 2061 6e64 2063 6869 6c64 2072 rent and child r │ │ │ │ +00013e80: 756c 6573 2061 6e64 2070 726f 7669 6465 ules and provide │ │ │ │ +00013e90: 7320 7468 656d 2c20 6f72 2074 6865 7920 s them, or they │ │ │ │ +00013ea0: 646f 6e26 2333 393b 7420 616e 643c 2f73 don't and
.
483< │ │ │ │ +00013f10: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00013f20: 656e 7422 3e2f 2f20 2074 6865 2052 756c ent">// the Rul │ │ │ │ +00013f30: 6573 2068 6176 6520 746f 2062 6520 6465 es have to be de │ │ │ │ +00013f40: 7465 726d 696e 6564 2066 726f 6d20 7368 termined from sh │ │ │ │ +00013f50: 6172 706e 6573 7320 7661 6c75 6573 2e20 arpness values. │ │ │ │ +00013f60: 2045 7665 6e20 7768 656e 2074 6865 2052 Even when the R │ │ │ │ +00013f70: 756c 6573 2061 7265 206b 6e6f 776e 2061 ules are known a │ │ │ │ +00013f80: 6e64 3c2f 7370 616e 3e3c 2f64 6976 3e0a nd
. │ │ │ │ +00013f90: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +00013fc0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 484// pr │ │ │ │ +00014000: 6f76 6964 6564 2074 686f 7567 682c 2074 ovided though, t │ │ │ │ +00014010: 6865 7265 2061 7265 2063 6173 6573 2077 here are cases w │ │ │ │ +00014020: 6865 7265 2074 6865 2070 6172 656e 7420 here the parent │ │ │ │ +00014030: 616e 6420 6368 696c 6420 7368 6172 706e and child sharpn │ │ │ │ +00014040: 6573 7320 7661 6c75 6573 206e 6565 6420 ess values need │ │ │ │ +00014050: 746f 2062 653c 2f73 7061 6e3e 3c2f 6469 to be.
485 │ │ │ │ +000140b0: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ +000140d0: 2069 6465 6e74 6966 6965 642c 2073 6f20 identified, so │ │ │ │ +000140e0: 6163 636f 756e 7469 6e67 2066 6f72 2074 accounting for t │ │ │ │ +000140f0: 6865 2075 6e6b 6e6f 776e 2052 756c 6573 he unknown Rules │ │ │ │ +00014100: 2074 6f6f 2069 7320 6e6f 7420 6d75 6368 too is not much │ │ │ │ +00014110: 206f 6620 616e 2061 6464 6564 2063 6f6d of an added com │ │ │ │ +00014120: 706c 6963 6174 696f 6e2e 3c2f 7370 616e plication.
.
│ │ │ │ +00014180: 2020 3438 363c 2f73 7061 6e3e 3c73 7061 486//
.
487< │ │ │ │ +00014200: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ +00014220: 5468 6520 6265 6e65 6669 7420 6f66 2073 The benefit of s │ │ │ │ +00014230: 7570 706f 7274 696e 6720 7370 6563 6966 upporting specif │ │ │ │ +00014240: 6965 6420 5275 6c65 7320 6973 2074 6861 ied Rules is tha │ │ │ │ +00014250: 7420 7468 6579 2063 616e 206f 6674 656e t they can often │ │ │ │ +00014260: 2062 6520 7472 6976 6961 6c6c 793c 2f73 be trivially
.
488< │ │ │ │ +000142d0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +000142e0: 656e 7422 3e2f 2f20 2064 6574 6572 6d69 ent">// determi │ │ │ │ +000142f0: 6e65 6420 6672 6f6d 2063 6f6e 7465 7874 ned from context │ │ │ │ +00014300: 2028 652e 672e 2061 2076 6572 7465 7820 (e.g. a vertex │ │ │ │ +00014310: 6465 7269 7665 6420 6672 6f6d 2061 2066 derived from a f │ │ │ │ +00014320: 6163 6520 6174 2061 2070 7265 7669 6f75 ace at a previou │ │ │ │ +00014330: 7320 6c65 7665 6c20 7769 6c6c 2061 6c77 s level will alw │ │ │ │ +00014340: 6179 733c 2f73 7061 6e3e 3c2f 6469 763e ays
│ │ │ │ +00014350: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00014380: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 489// b │ │ │ │ +000143c0: 6520 736d 6f6f 7468 2920 7261 7468 6572 e smooth) rather │ │ │ │ +000143d0: 2074 6861 6e20 6d6f 7265 2067 656e 6572 than more gener │ │ │ │ +000143e0: 616c 6c79 2c20 616e 6420 6174 2067 7265 ally, and at gre │ │ │ │ +000143f0: 6174 6572 2063 6f73 742c 2069 6e73 7065 ater cost, inspe │ │ │ │ +00014400: 6374 696e 6720 6e65 6967 6862 6f72 696e cting neighborin │ │ │ │ +00014410: 6720 616e 643c 2f73 7061 6e3e 3c2f 6469 g and.
490 │ │ │ │ +00014470: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ +00014490: 2074 6865 7920 6172 6520 6f66 7465 6e20 they are often │ │ │ │ +000144a0: 7468 6520 7361 6d65 2066 6f72 2070 6172 the same for par │ │ │ │ +000144b0: 656e 7420 616e 6420 6368 696c 642e 3c2f ent and child.
.
< │ │ │ │ +00014500: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00014510: 6e6f 223e 2020 3439 313c 2f73 7061 6e3e no"> 491 │ │ │ │ +00014520: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ +00014540: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00014590: 3439 323c 2f73 7061 6e3e 3c73 7061 6e20 492 │ │ │ │ +000145b0: 2f2f 2020 5468 6520 6f76 6572 616c 6c20 // The overall │ │ │ │ +000145c0: 7072 6f63 6573 7320 6973 2061 7320 666f process is as fo │ │ │ │ +000145d0: 6c6c 6f77 733a 3c2f 7370 616e 3e3c 2f64 llows:.
49 │ │ │ │ +00014630: 333c 2f73 7061 6e3e 3c73 7061 6e20 636c 3// │ │ │ │ +00014650: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00014670: 3c61 2069 643d 226c 3030 3439 3422 206e 494// │ │ │ │ +000146d0: 2d20 7175 6963 6b6c 7920 6465 7465 6374 - quickly detect │ │ │ │ +000146e0: 2074 6865 206d 6f73 7420 636f 6d6d 6f6e the most common │ │ │ │ +000146f0: 2053 6d6f 6f74 6820 6361 7365 2077 6865 Smooth case whe │ │ │ │ +00014700: 6e20 7370 6563 6966 6965 6420 616e 6420 n specified and │ │ │ │ +00014710: 7265 7475 726e 3c2f 7370 616e 3e3c 2f64 return.
49 │ │ │ │ +00014770: 353c 2f73 7061 6e3e 3c73 7061 6e20 636c 5// │ │ │ │ +00014790: 2020 2020 2020 2d20 6465 7465 726d 696e - determin │ │ │ │ +000147a0: 6520 6966 2073 6861 7270 6e65 7373 2066 e if sharpness f │ │ │ │ +000147b0: 6f72 2070 6172 656e 7420 6973 2072 6571 or parent is req │ │ │ │ +000147c0: 7569 7265 6420 616e 6420 6761 7468 6572 uired and gather │ │ │ │ +000147d0: 2069 6620 736f 3c2f 7370 616e 3e3c 2f64 if so.
49 │ │ │ │ +00014830: 363c 2f73 7061 6e3e 3c73 7061 6e20 636c 6// │ │ │ │ +00014850: 2020 2020 2020 2d20 6966 2075 6e73 7065 - if unspe │ │ │ │ +00014860: 6369 6669 6564 2c20 6465 7465 726d 696e cified, determin │ │ │ │ +00014870: 6520 7468 6520 7061 7265 6e74 2072 756c e the parent rul │ │ │ │ +00014880: 653c 2f73 7061 6e3e 3c2f 6469 763e 0a3c e
.< │ │ │ │ +00014890: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +000148a0: 3e3c 6120 6964 3d22 6c30 3034 3937 2220 > 497// │ │ │ │ +00014900: 202d 2061 7373 6967 6e20 6d61 736b 2066 - assign mask f │ │ │ │ +00014910: 6f72 2074 6865 2070 6172 656e 7420 7275 or the parent ru │ │ │ │ +00014920: 6c65 202d 2d20 7265 7475 726e 696e 6720 le -- returning │ │ │ │ +00014930: 6966 2053 6d6f 6f74 682f 4461 7274 3c2f if Smooth/Dart
.
< │ │ │ │ +00014980: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00014990: 6e6f 223e 2020 3439 383c 2f73 7061 6e3e no"> 498 │ │ │ │ +000149a0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // - │ │ │ │ +000149c0: 7265 7475 726e 2069 6620 6368 696c 6420 return if child │ │ │ │ +000149d0: 7275 6c65 206d 6174 6368 6573 2070 6172 rule matches par │ │ │ │ +000149e0: 656e 743c 2f73 7061 6e3e 3c2f 6469 763e ent
│ │ │ │ +000149f0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00014a20: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 499// │ │ │ │ +00014a60: 2020 202d 2067 6174 6865 7220 7368 6172 - gather shar │ │ │ │ +00014a70: 706e 6573 7320 666f 7220 6368 696c 6420 pness for child │ │ │ │ +00014a80: 746f 2064 6574 6572 6d69 6e65 206f 7220 to determine or │ │ │ │ +00014a90: 636f 6d62 696e 6520 6368 696c 6420 7275 combine child ru │ │ │ │ +00014aa0: 6c65 3c2f 7370 616e 3e3c 2f64 6976 3e0a le
. │ │ │ │ +00014ab0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
501// - as │ │ │ │ +00014bf0: 7369 676e 206c 6f63 616c 206d 6173 6b20 sign local mask │ │ │ │ +00014c00: 666f 7220 6368 696c 6420 7275 6c65 3c2f for child rule
.
< │ │ │ │ +00014c50: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00014c60: 6e6f 223e 2020 3530 323c 2f73 7061 6e3e no"> 502 │ │ │ │ +00014c70: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // - │ │ │ │ +00014c90: 636f 6d62 696e 6520 6c6f 6361 6c20 6368 combine local ch │ │ │ │ +00014ca0: 696c 6420 6d61 736b 2077 6974 6820 7468 ild mask with th │ │ │ │ +00014cb0: 6520 7061 7265 6e74 206d 6173 6b3c 2f73 e parent mask
.
503< │ │ │ │ +00014d20: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00014d30: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
5 │ │ │ │ +00014d90: 3034 3c2f 7370 616e 3e3c 7370 616e 2063 04/ │ │ │ │ +00014db0: 2f20 2052 656d 656d 6265 7220 2d2d 2069 / Remember -- i │ │ │ │ +00014dc0: 6620 7468 6520 7061 7265 6e74 2072 756c f the parent rul │ │ │ │ +00014dd0: 6520 6973 2073 7065 6369 6669 6564 2062 e is specified b │ │ │ │ +00014de0: 7574 2074 6865 2063 6869 6c64 2069 7320 ut the child is │ │ │ │ +00014df0: 6e6f 742c 2074 6869 7320 696d 706c 6965 not, this implie │ │ │ │ +00014e00: 7320 6f6e 6c79 206f 6e65 3c2f 7370 616e s only one
.
│ │ │ │ +00014e60: 2020 3530 353c 2f73 7061 6e3e 3c73 7061 505// of the two │ │ │ │ +00014e90: 206f 7074 696f 6e61 6c20 7275 6c65 7320 optional rules │ │ │ │ +00014ea0: 7761 7320 7370 6563 6966 6965 6420 616e was specified an │ │ │ │ +00014eb0: 6420 6973 206d 6561 6e74 2074 6f20 696e d is meant to in │ │ │ │ +00014ec0: 6469 6361 7465 2074 6865 7265 2069 7320 dicate there is │ │ │ │ +00014ed0: 6e6f 2074 7261 6e73 6974 696f 6e2c 3c2f no transition,
.
< │ │ │ │ +00014f20: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00014f30: 6e6f 223e 2020 3530 363c 2f73 7061 6e3e no"> 506 │ │ │ │ +00014f40: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // so the │ │ │ │ +00014f60: 2063 6869 6c64 2072 756c 6520 7368 6f75 child rule shou │ │ │ │ +00014f70: 6c64 2062 6520 6173 7369 676e 6564 2074 ld be assigned t │ │ │ │ +00014f80: 6f20 6265 2074 6865 2073 616d 6520 2877 o be the same (w │ │ │ │ +00014f90: 6973 6820 7468 6520 636f 6d70 696c 6572 ish the compiler │ │ │ │ +00014fa0: 2077 6f75 6c64 2061 6c6c 6f77 2074 6869 would allow thi │ │ │ │ +00014fb0: 733c 2f73 7061 6e3e 3c2f 6469 763e 0a3c s
.< │ │ │ │ +00014fc0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00014fd0: 3e3c 6120 6964 3d22 6c30 3035 3037 2220 > 507// in │ │ │ │ +00015030: 6465 6661 756c 7420 7661 6c75 6520 6173 default value as │ │ │ │ +00015040: 7369 676e 6d65 6e74 292e 3c2f 7370 616e signment).
.
│ │ │ │ +000150a0: 2020 3530 383c 2f73 7061 6e3e 3c73 7061 508//
.
509< │ │ │ │ +00015120: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>temp │ │ │ │ +00015140: 6c61 7465 3c2f 7370 616e 3e20 266c 743b late < │ │ │ │ +00015150: 5363 6865 6d65 5479 7065 2053 4348 454d SchemeType SCHEM │ │ │ │ +00015160: 4526 6774 3b3c 2f64 6976 3e0a 3c64 6976 E>
.
< │ │ │ │ +000151a0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +000151b0: 6e6f 223e 2020 3531 303c 2f73 7061 6e3e no"> 510 │ │ │ │ +000151c0: 3c73 7061 6e20 636c 6173 733d 226b 6579 template < │ │ │ │ +00015200: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ +00015210: 5645 5254 4558 2c20 3c73 7061 6e20 636c VERTEX, ty │ │ │ │ +00015230: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ +00015240: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ +00015260: 6120 6964 3d22 6c30 3035 3131 2220 6e61 a id="l00511" na │ │ │ │ +00015270: 6d65 3d22 6c30 3035 3131 223e 3c2f 613e me="l00511"> │ │ │ │ +00015280: 3c73 7061 6e20 636c 6173 733d 226c 696e 511void< │ │ │ │ +000152c0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
...
513< │ │ │ │ +000154c0: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ +000154d0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +000154e0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +000154f0: 204d 4153 4b26 616d 703b 2020 2020 2020 MASK& │ │ │ │ +00015500: 2020 2020 206d 6173 6b2c 3c2f 6469 763e mask,
│ │ │ │ +00015510: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00015540: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 514 │ │ │ │ +00015570: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00015580: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00015590: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Crease::Rule │ │ │ │ +000155f0: 3c2f 613e 2070 5275 6c65 2c3c 2f64 6976 pRule,
.
515< │ │ │ │ +00015650: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ +00015660: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00015670: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00015680: 203c 6120 636c 6173 733d 2263 6f64 6520 Crease::Rul │ │ │ │ +000156e0: 653c 2f61 3e20 6352 756c 6529 3c73 7061 e cRule) const │ │ │ │ +00015710: 7b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 {
.
│ │ │ │ +00015760: 2020 3531 363c 2f73 7061 6e3e 203c 2f64 516 .
51 │ │ │ │ +000157c0: 373c 2f73 7061 6e3e 2020 2020 3c73 7061 7 // Quick assi │ │ │ │ +000157f0: 676e 6d65 6e74 2061 6e64 2072 6574 7572 gnment and retur │ │ │ │ +00015800: 6e20 666f 7220 7468 6520 6d6f 7374 2063 n for the most c │ │ │ │ +00015810: 6f6d 6d6f 6e20 6361 7365 3a3c 2f73 7061 ommon case:
.
518 │ │ │ │ +00015880: 203c 7370 616e 2063 6c61 7373 3d22 6b65 if ((pRule == │ │ │ │ +000158b0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Crease::RULE_ │ │ │ │ +00015930: 534d 4f4f 5448 3c2f 613e 2920 7c7c 2028 SMOOTH) || ( │ │ │ │ +00015940: 7052 756c 6520 3d3d 203c 6120 636c 6173 pRule == Crea │ │ │ │ +000159c0: 7365 3a3a 5255 4c45 5f44 4152 543c 2f61 se::RULE_DART)) {
.
< │ │ │ │ +00015a10: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00015a20: 6e6f 223e 2020 3531 393c 2f73 7061 6e3e no"> 519 │ │ │ │ +00015a30: 2020 2020 2020 2020 6173 7369 676e 536d assignSm │ │ │ │ +00015a40: 6f6f 7468 4d61 736b 466f 7256 6572 7465 oothMaskForVerte │ │ │ │ +00015a50: 7828 7665 7274 6578 2c20 6d61 736b 293b x(vertex, mask); │ │ │ │ +00015a60: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00015ab0: 2035 3230 3c2f 7370 616e 3e20 2020 2020 520 │ │ │ │ +00015ac0: 2020 203c 7370 616e 2063 6c61 7373 3d22 ret │ │ │ │ +00015ae0: 7572 6e3c 2f73 7061 6e3e 3b3c 2f64 6976 urn;
.
521< │ │ │ │ +00015b40: 2f73 7061 6e3e 2020 2020 7d3c 2f64 6976 /span> }
.
522< │ │ │ │ +00015ba0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ +00015bc0: 2f2f 2020 4966 2075 6e73 7065 6369 6669 // If unspecifi │ │ │ │ +00015bd0: 6564 2c20 6173 7369 676e 2074 6865 2063 ed, assign the c │ │ │ │ +00015be0: 6869 6c64 2072 756c 6520 746f 206d 6174 hild rule to mat │ │ │ │ +00015bf0: 6368 2074 6865 2070 6172 656e 7420 7275 ch the parent ru │ │ │ │ +00015c00: 6c65 2069 6620 7370 6563 6966 6965 643a le if specified: │ │ │ │ +00015c10: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00015c30: 3c61 2069 643d 226c 3030 3532 3322 206e 523 │ │ │ │ +00015c90: 6966 3c2f 7370 616e 3e20 2828 6352 756c if ((cRul │ │ │ │ +00015ca0: 6520 3d3d 203c 6120 636c 6173 733d 2263 e == Crease:: │ │ │ │ +00015d20: 5255 4c45 5f55 4e4b 4e4f 574e 3c2f 613e RULE_UNKNOWN │ │ │ │ +00015d30: 2920 2661 6d70 3b26 616d 703b 2028 7052 ) && (pR │ │ │ │ +00015d40: 756c 6520 213d 203c 6120 636c 6173 733d ule != Crease │ │ │ │ +00015dc0: 3a3a 5255 4c45 5f55 4e4b 4e4f 574e 3c2f ::RULE_UNKNOWN)) {
.< │ │ │ │ +00015df0: 6120 6964 3d22 6c30 3035 3234 2220 6e61 a id="l00524" na │ │ │ │ +00015e00: 6d65 3d22 6c30 3035 3234 223e 3c2f 613e me="l00524"> │ │ │ │ +00015e10: 3c73 7061 6e20 636c 6173 733d 226c 696e 524 cRule = │ │ │ │ +00015e40: 2070 5275 6c65 3b3c 2f64 6976 3e0a 3c64 pRule;
. │ │ │ │ +00015e60: 3c61 2069 643d 226c 3030 3532 3522 206e 525 }
. │ │ │ │ +00015ec0: 3c61 2069 643d 226c 3030 3532 3622 206e 526 │ │ │ │ +00015f20: 696e 743c 2f73 7061 6e3e 2076 616c 656e int valen │ │ │ │ +00015f30: 6365 203d 2076 6572 7465 782e 4765 744e ce = vertex.GetN │ │ │ │ +00015f40: 756d 4564 6765 7328 293b 3c2f 6469 763e umEdges();
│ │ │ │ +00015f50: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ +00015fc0: 6120 6964 3d22 6c30 3035 3238 2220 6e61 a id="l00528" na │ │ │ │ +00015fd0: 6d65 3d22 6c30 3035 3238 223e 3c2f 613e me="l00528"> │ │ │ │ +00015fe0: 3c73 7061 6e20 636c 6173 733d 226c 696e 528 //
.
529 │ │ │ │ +00016080: 2020 203c 7370 616e 2063 6c61 7373 3d22 // Det │ │ │ │ +000160a0: 6572 6d69 6e65 2069 6620 7765 206e 6565 ermine if we nee │ │ │ │ +000160b0: 6420 7468 6520 7061 7265 6e74 2065 6467 d the parent edg │ │ │ │ +000160c0: 6520 7368 6172 706e 6573 7320 7661 6c75 e sharpness valu │ │ │ │ +000160d0: 6573 202d 2d20 6964 656e 7469 6679 2f67 es -- identify/g │ │ │ │ +000160e0: 6174 6865 7220 6966 2073 6f3c 2f73 7061 ather if so
.
530 │ │ │ │ +00016150: 203c 7370 616e 2063 6c61 7373 3d22 636f // and u │ │ │ │ +00016170: 7365 2069 7420 746f 2063 6f6d 7075 7465 se it to compute │ │ │ │ +00016180: 2074 6865 2070 6172 656e 7420 7275 6c65 the parent rule │ │ │ │ +00016190: 2069 6620 756e 7370 6563 6966 6965 643a if unspecified: │ │ │ │ +000161a0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +000161c0: 3c61 2069 643d 226c 3030 3533 3122 206e 531 //
.
< │ │ │ │ +00016260: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00016270: 6e6f 223e 2020 3533 323c 2f73 7061 6e3e no"> 532 │ │ │ │ +00016280: 2020 2020 3c73 7061 6e20 636c 6173 733d fl │ │ │ │ +000162a0: 6f61 743c 2f73 7061 6e3e 202a 2070 4564 oat * pEd │ │ │ │ +000162b0: 6765 5368 6172 706e 6573 7342 7566 6665 geSharpnessBuffe │ │ │ │ +000162c0: 7220 3d20 283c 7370 616e 2063 6c61 7373 r = (f │ │ │ │ +000162e0: 6c6f 6174 3c2f 7370 616e 3e20 2a29 616c loat *)al │ │ │ │ +000162f0: 6c6f 6361 2876 616c 656e 6365 2a3c 7370 loca(valence*sizeof │ │ │ │ +00016320: 283c 7370 616e 2063 6c61 7373 3d22 6b65 (float │ │ │ │ +00016340: 3c2f 7370 616e 3e29 292c 3c2f 6469 763e )),
│ │ │ │ +00016350: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00016380: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 533 * │ │ │ │ +000163b0: 2070 4564 6765 5368 6172 706e 6573 7320 pEdgeSharpness │ │ │ │ +000163c0: 2020 3d20 302c 3c2f 6469 763e 0a3c 6469 = 0,
.< │ │ │ │ +000163e0: 6120 6964 3d22 6c30 3035 3334 2220 6e61 a id="l00534" na │ │ │ │ +000163f0: 6d65 3d22 6c30 3035 3334 223e 3c2f 613e me="l00534"> │ │ │ │ +00016400: 3c73 7061 6e20 636c 6173 733d 226c 696e 534 pVe │ │ │ │ +00016430: 7274 6578 5368 6172 706e 6573 7320 3d20 rtexSharpness = │ │ │ │ +00016440: 302e 3066 3b3c 2f64 6976 3e0a 3c64 6976 0.0f;
.
< │ │ │ │ +00016480: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00016490: 6e6f 223e 2020 3533 353c 2f73 7061 6e3e no"> 535 │ │ │ │ +000164a0: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ +000164f0: 2020 3533 363c 2f73 7061 6e3e 2020 2020 536 │ │ │ │ +00016500: 3c73 7061 6e20 636c 6173 733d 226b 6579 bool requirePar │ │ │ │ +00016530: 656e 7453 6861 7270 6e65 7373 203d 2028 entSharpness = ( │ │ │ │ +00016540: 7052 756c 6520 3d3d 203c 6120 636c 6173 pRule == Crea │ │ │ │ +000165c0: 7365 3a3a 5255 4c45 5f55 4e4b 4e4f 574e se::RULE_UNKNOWN │ │ │ │ +000165d0: 3c2f 613e 2920 7c7c 3c2f 6469 763e 0a3c ) ||
.< │ │ │ │ +000165e0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +000165f0: 3e3c 6120 6964 3d22 6c30 3035 3337 2220 > 537 │ │ │ │ +00016640: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00016650: 2020 2020 2028 7052 756c 6520 3d3d 203c (pRule == < │ │ │ │ +00016660: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00016670: 5f65 6e75 6d76 616c 7565 2220 6872 6566 _enumvalue" href │ │ │ │ +00016680: 3d22 6130 3133 3333 2e68 746d 6c23 6131 ="a01333.html#a1 │ │ │ │ +00016690: 3166 6364 3531 6566 3836 3131 3866 3635 1fcd51ef86118f65 │ │ │ │ +000166a0: 6536 3033 6331 3437 3433 3737 6137 3861 e603c1474377a78a │ │ │ │ +000166b0: 3936 3666 6131 6165 3861 6562 3835 3837 966fa1ae8aeb8587 │ │ │ │ +000166c0: 6334 3938 6366 3661 3932 6363 3333 3335 c498cf6a92cc3335 │ │ │ │ +000166d0: 223e 4372 6561 7365 3a3a 5255 4c45 5f43 ">Crease::RULE_C │ │ │ │ +000166e0: 5245 4153 453c 2f61 3e29 207c 7c3c 2f64 REASE) ||.
53 │ │ │ │ +00016740: 383c 2f73 7061 6e3e 2020 2020 2020 2020 8 │ │ │ │ +00016750: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00016760: 2020 2020 2020 2020 2020 2870 5275 6c65 (pRule │ │ │ │ +00016770: 2021 3d20 6352 756c 6529 3b3c 2f64 6976 != cRule);
.
539< │ │ │ │ +000167d0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> if (r │ │ │ │ +00016800: 6571 7569 7265 5061 7265 6e74 5368 6172 equireParentShar │ │ │ │ +00016810: 706e 6573 7329 207b 3c2f 6469 763e 0a3c pness) {
.< │ │ │ │ +00016820: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00016830: 3e3c 6120 6964 3d22 6c30 3035 3430 2220 > 540 pVert │ │ │ │ +00016880: 6578 5368 6172 706e 6573 7320 3d20 7665 exSharpness = ve │ │ │ │ +00016890: 7274 6578 2e47 6574 5368 6172 706e 6573 rtex.GetSharpnes │ │ │ │ +000168a0: 7328 293b 3c2f 6469 763e 0a3c 6469 7620 s();
.
541 │ │ │ │ +00016900: 2020 2020 2020 2070 4564 6765 5368 6172 pEdgeShar │ │ │ │ +00016910: 706e 6573 7320 2020 3d20 7665 7274 6578 pness = vertex │ │ │ │ +00016920: 2e47 6574 5368 6172 706e 6573 7350 6572 .GetSharpnessPer │ │ │ │ +00016930: 4564 6765 2870 4564 6765 5368 6172 706e Edge(pEdgeSharpn │ │ │ │ +00016940: 6573 7342 7566 6665 7229 3b3c 2f64 6976 essBuffer);
.
542< │ │ │ │ +000169a0: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ +000169c0: 3c61 2069 643d 226c 3030 3534 3322 206e 543 if (p │ │ │ │ +00016a30: 5275 6c65 203d 3d20 3c61 2063 6c61 7373 Rule == Creas │ │ │ │ +00016ab0: 653a 3a52 554c 455f 554e 4b4e 4f57 4e3c e::RULE_UNKNOWN< │ │ │ │ +00016ac0: 2f61 3e29 207b 3c2f 6469 763e 0a3c 6469 /a>) {
.< │ │ │ │ +00016ae0: 6120 6964 3d22 6c30 3035 3434 2220 6e61 a id="l00544" na │ │ │ │ +00016af0: 6d65 3d22 6c30 3035 3434 223e 3c2f 613e me="l00544"> │ │ │ │ +00016b00: 3c73 7061 6e20 636c 6173 733d 226c 696e 544 pRu │ │ │ │ +00016b30: 6c65 203d 203c 6120 636c 6173 733d 2263 le = Crease(_opt │ │ │ │ +00016b70: 696f 6e73 292e 3c61 2063 6c61 7373 3d22 ions).Determine │ │ │ │ +00016bd0: 5665 7274 6578 5665 7274 6578 5275 6c65 VertexVertexRule │ │ │ │ +00016be0: 3c2f 613e 2870 5665 7274 6578 5368 6172 (pVertexShar │ │ │ │ +00016bf0: 706e 6573 732c 2076 616c 656e 6365 2c20 pness, valence, │ │ │ │ +00016c00: 7045 6467 6553 6861 7270 6e65 7373 293b pEdgeSharpness); │ │ │ │ +00016c10: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00016c60: 2035 3435 3c2f 7370 616e 3e20 2020 2020 545 │ │ │ │ +00016c70: 2020 207d 3c2f 6469 763e 0a3c 6469 7620 }
.
546 │ │ │ │ +00016cd0: 2020 207d 3c2f 6469 763e 0a3c 6469 7620 }
.
547 │ │ │ │ +00016d30: 2020 203c 7370 616e 2063 6c61 7373 3d22 if< │ │ │ │ +00016d50: 2f73 7061 6e3e 2028 2870 5275 6c65 203d /span> ((pRule = │ │ │ │ +00016d60: 3d20 3c61 2063 6c61 7373 3d22 636f 6465 = Crease::RUL │ │ │ │ +00016de0: 455f 534d 4f4f 5448 3c2f 613e 2920 7c7c E_SMOOTH) || │ │ │ │ +00016df0: 2028 7052 756c 6520 3d3d 203c 6120 636c (pRule == Cr │ │ │ │ +00016e70: 6561 7365 3a3a 5255 4c45 5f44 4152 543c ease::RULE_DART< │ │ │ │ +00016e80: 2f61 3e29 2920 7b3c 2f64 6976 3e0a 3c64 /a>)) {
. │ │ │ │ +00016ea0: 3c61 2069 643d 226c 3030 3534 3822 206e 548 assign │ │ │ │ +00016ef0: 536d 6f6f 7468 4d61 736b 466f 7256 6572 SmoothMaskForVer │ │ │ │ +00016f00: 7465 7828 7665 7274 6578 2c20 6d61 736b tex(vertex, mask │ │ │ │ +00016f10: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
549 │ │ │ │ +00016f70: 2020 2020 203c 7370 616e 2063 6c61 7373 r │ │ │ │ +00016f90: 6574 7572 6e3c 2f73 7061 6e3e 3b20 203c eturn; < │ │ │ │ +00016fa0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00016fb0: 656e 7422 3e2f 2f20 2041 7320 646f 6e65 ent">// As done │ │ │ │ +00016fc0: 206f 6e20 656e 7472 792c 2077 6520 6361 on entry, we ca │ │ │ │ +00016fd0: 6e20 7265 7475 726e 2069 6d6d 6564 6961 n return immedia │ │ │ │ +00016fe0: 7465 6c79 2069 6620 7061 7265 6e74 2069 tely if parent i │ │ │ │ +00016ff0: 7320 536d 6f6f 7468 2f44 6172 743c 2f73 s Smooth/Dart
.
550 │ │ │ │ +00017060: 2020 207d 203c 7370 616e 2063 6c61 7373 } e │ │ │ │ +00017080: 6c73 653c 2f73 7061 6e3e 203c 7370 616e lse if ( │ │ │ │ +000170b0: 7052 756c 6520 3d3d 203c 6120 636c 6173 pRule == Crea │ │ │ │ +00017130: 7365 3a3a 5255 4c45 5f43 5245 4153 453c se::RULE_CREASE< │ │ │ │ +00017140: 2f61 3e29 207b 3c2f 6469 763e 0a3c 6469 /a>) {
.< │ │ │ │ +00017160: 6120 6964 3d22 6c30 3035 3531 2220 6e61 a id="l00551" na │ │ │ │ +00017170: 6d65 3d22 6c30 3035 3531 223e 3c2f 613e me="l00551"> │ │ │ │ +00017180: 3c73 7061 6e20 636c 6173 733d 226c 696e 551 int cr │ │ │ │ +000171d0: 6561 7365 456e 6473 5b32 5d3b 3c2f 6469 easeEnds[2];.
552 │ │ │ │ +00017230: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ +00017240: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00017250: 5f63 6c61 7373 2220 6872 6566 3d22 6130 _class" href="a0 │ │ │ │ +00017260: 3133 3333 2e68 746d 6c22 3e43 7265 6173 1333.html">Creas │ │ │ │ +00017270: 653c 2f61 3e28 5f6f 7074 696f 6e73 292e e(_options). │ │ │ │ +00017280: 3c61 2063 6c61 7373 3d22 636f 6465 2068 GetSharpEdgePai │ │ │ │ +000172e0: 724f 6643 7265 6173 653c 2f61 3e28 7045 rOfCrease(pE │ │ │ │ +000172f0: 6467 6553 6861 7270 6e65 7373 2c20 7661 dgeSharpness, va │ │ │ │ +00017300: 6c65 6e63 652c 2063 7265 6173 6545 6e64 lence, creaseEnd │ │ │ │ +00017310: 7329 3b3c 2f64 6976 3e0a 3c64 6976 2063 s);
.
553 < │ │ │ │ +00017370: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +000173c0: 3535 343c 2f73 7061 6e3e 2020 2020 2020 554 │ │ │ │ +000173d0: 2020 6173 7369 676e 4372 6561 7365 4d61 assignCreaseMa │ │ │ │ +000173e0: 736b 466f 7256 6572 7465 7828 7665 7274 skForVertex(vert │ │ │ │ +000173f0: 6578 2c20 6d61 736b 2c20 6372 6561 7365 ex, mask, crease │ │ │ │ +00017400: 456e 6473 293b 3c2f 6469 763e 0a3c 6469 Ends);
.< │ │ │ │ +00017420: 6120 6964 3d22 6c30 3035 3535 2220 6e61 a id="l00555" na │ │ │ │ +00017430: 6d65 3d22 6c30 3035 3535 223e 3c2f 613e me="l00555"> │ │ │ │ +00017440: 3c73 7061 6e20 636c 6173 733d 226c 696e 555 } else {.
5 │ │ │ │ +000174e0: 3536 3c2f 7370 616e 3e20 2020 2020 2020 56 │ │ │ │ +000174f0: 2061 7373 6967 6e43 6f72 6e65 724d 6173 assignCornerMas │ │ │ │ +00017500: 6b46 6f72 5665 7274 6578 2876 6572 7465 kForVertex(verte │ │ │ │ +00017510: 782c 206d 6173 6b29 3b3c 2f64 6976 3e0a x, mask);
. │ │ │ │ +00017520: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
. │ │ │ │ +00017580: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ +00017670: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00017680: 6e6f 223e 2020 3535 393c 2f73 7061 6e3e no"> 559 │ │ │ │ +00017690: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ +000176e0: 2020 3536 303c 2f73 7061 6e3e 2020 2020 560 │ │ │ │ +000176f0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ +00017710: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00017760: 3536 313c 2f73 7061 6e3e 2020 2020 3c73 561 // Identify │ │ │ │ +00017790: 2f67 6174 6865 7220 6368 696c 6420 7368 /gather child sh │ │ │ │ +000177a0: 6172 706e 6573 7320 746f 2063 6f6d 6269 arpness to combi │ │ │ │ +000177b0: 6e65 206d 6173 6b73 2066 6f72 2074 6865 ne masks for the │ │ │ │ +000177c0: 2074 776f 2064 6966 6665 7269 6e67 2052 two differing R │ │ │ │ +000177d0: 756c 6573 3a3c 2f73 7061 6e3e 3c2f 6469 ules:.
562 │ │ │ │ +00017830: 3c2f 7370 616e 3e20 2020 203c 7370 616e //
│ │ │ │ +00017860: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00017890: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 563 Crease │ │ │ │ +000178f0: 6372 6561 7365 285f 6f70 7469 6f6e 7329 crease(_options) │ │ │ │ +00017900: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +00017950: 2020 3536 343c 2f73 7061 6e3e 203c 2f64 564 .
56 │ │ │ │ +000179b0: 353c 2f73 7061 6e3e 2020 2020 3c73 7061 5 float * cEdgeSharpn │ │ │ │ +000179f0: 6573 7342 7566 6665 7220 3d20 283c 7370 essBuffer = (float *)alloca(val │ │ │ │ +00017a30: 656e 6365 2a3c 7370 616e 2063 6c61 7373 ence*sizeo │ │ │ │ +00017a50: 663c 2f73 7061 6e3e 283c 7370 616e 2063 f(float) │ │ │ │ +00017a80: 292c 3c2f 6469 763e 0a3c 6469 7620 636c ),
.
566 │ │ │ │ +00017ae0: 2020 2020 2020 202a 2063 4564 6765 5368 * cEdgeSh │ │ │ │ +00017af0: 6172 706e 6573 7320 3d20 7665 7274 6578 arpness = vertex │ │ │ │ +00017b00: 2e47 6574 4368 696c 6453 6861 7270 6e65 .GetChildSharpne │ │ │ │ +00017b10: 7373 5065 7245 6467 6528 6372 6561 7365 ssPerEdge(crease │ │ │ │ +00017b20: 2c20 6345 6467 6553 6861 7270 6e65 7373 , cEdgeSharpness │ │ │ │ +00017b30: 4275 6666 6572 292c 3c2f 6469 763e 0a3c Buffer),
.< │ │ │ │ +00017b40: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00017b50: 3e3c 6120 6964 3d22 6c30 3035 3637 2220 > 567 c │ │ │ │ +00017ba0: 5665 7274 6578 5368 6172 706e 6573 7320 VertexSharpness │ │ │ │ +00017bb0: 3d20 7665 7274 6578 2e47 6574 4368 696c = vertex.GetChil │ │ │ │ +00017bc0: 6453 6861 7270 6e65 7373 2863 7265 6173 dSharpness(creas │ │ │ │ +00017bd0: 6529 3b3c 2f64 6976 3e0a 3c64 6976 2063 e);
.
568 < │ │ │ │ +00017c30: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>. │ │ │ │ +00017d50: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00017d80: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 570 cRu │ │ │ │ +00017db0: 6c65 203d 2063 7265 6173 652e 3c61 2063 le = crease.Det │ │ │ │ +00017e10: 6572 6d69 6e65 5665 7274 6578 5665 7274 ermineVertexVert │ │ │ │ +00017e20: 6578 5275 6c65 3c2f 613e 2863 5665 7274 exRule(cVert │ │ │ │ +00017e30: 6578 5368 6172 706e 6573 732c 2076 616c exSharpness, val │ │ │ │ +00017e40: 656e 6365 2c20 6345 6467 6553 6861 7270 ence, cEdgeSharp │ │ │ │ +00017e50: 6e65 7373 293b 3c2f 6469 763e 0a3c 6469 ness);
.< │ │ │ │ +00017e70: 6120 6964 3d22 6c30 3035 3731 2220 6e61 a id="l00571" na │ │ │ │ +00017e80: 6d65 3d22 6c30 3035 3731 223e 3c2f 613e me="l00571"> │ │ │ │ +00017e90: 3c73 7061 6e20 636c 6173 733d 226c 696e 571 if (cR │ │ │ │ +00017ee0: 756c 6520 3d3d 2070 5275 6c65 2920 3c73 ule == pRule) return;
.< │ │ │ │ +00017f30: 6120 6964 3d22 6c30 3035 3732 2220 6e61 a id="l00572" na │ │ │ │ +00017f40: 6d65 3d22 6c30 3035 3732 223e 3c2f 613e me="l00572"> │ │ │ │ +00017f50: 3c73 7061 6e20 636c 6173 733d 226c 696e 572 }
.< │ │ │ │ +00017f90: 6120 6964 3d22 6c30 3035 3733 2220 6e61 a id="l00573" na │ │ │ │ +00017fa0: 6d65 3d22 6c30 3035 3733 223e 3c2f 613e me="l00573"> │ │ │ │ +00017fb0: 3c73 7061 6e20 636c 6173 733d 226c 696e 573
.
574 │ │ │ │ +00018030: 203c 7370 616e 2063 6c61 7373 3d22 636f // │ │ │ │ +00018050: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +000180a0: 2035 3735 3c2f 7370 616e 3e20 2020 203c 575 < │ │ │ │ +000180b0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +000180c0: 656e 7422 3e2f 2f20 2049 6e69 7469 616c ent">// Initial │ │ │ │ +000180d0: 697a 6520 6120 6c6f 6361 6c20 6368 696c ize a local chil │ │ │ │ +000180e0: 6420 6d61 736b 2c20 636f 6d70 7574 6520 d mask, compute │ │ │ │ +000180f0: 7468 6520 6672 6163 7469 6f6e 616c 2077 the fractional w │ │ │ │ +00018100: 6569 6768 7420 6672 6f6d 2070 6172 656e eight from paren │ │ │ │ +00018110: 7420 616e 6420 6368 696c 643c 2f73 7061 t and child
.
576 │ │ │ │ +00018180: 203c 7370 616e 2063 6c61 7373 3d22 636f // sharp │ │ │ │ +000181a0: 6e65 7373 2076 616c 7565 7320 616e 6420 ness values and │ │ │ │ +000181b0: 636f 6d62 696e 6520 7468 6520 7477 6f20 combine the two │ │ │ │ +000181c0: 6d61 736b 733a 3c2f 7370 616e 3e3c 2f64 masks:.
57 │ │ │ │ +00018220: 373c 2f73 7061 6e3e 2020 2020 3c73 7061 7 //
.
578< │ │ │ │ +000182a0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ +000182c0: 7479 7065 6465 663c 2f73 7061 6e3e 203c typedef < │ │ │ │ +000182d0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +000182e0: 6f72 6422 3e74 7970 656e 616d 653c 2f73 ord">typename MASK::Weigh │ │ │ │ +00018300: 7420 5765 6967 6874 3b3c 2f64 6976 3e0a t Weight;
. │ │ │ │ +00018310: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ +000183a0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +000183b0: 6e6f 223e 2020 3538 303c 2f73 7061 6e3e no"> 580 │ │ │ │ +000183c0: 2020 2020 5765 6967 6874 202a 2063 4d61 Weight * cMa │ │ │ │ +000183d0: 736b 5765 6967 6874 7320 3d20 2857 6569 skWeights = (Wei │ │ │ │ +000183e0: 6768 7420 2a29 616c 6c6f 6361 2828 3120 ght *)alloca((1 │ │ │ │ +000183f0: 2b20 3220 2a20 7661 6c65 6e63 6529 2a3c + 2 * valence)*< │ │ │ │ +00018400: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00018410: 6f72 6422 3e73 697a 656f 663c 2f73 7061 ord">sizeof(Weight));..
< │ │ │ │ +00018550: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00018560: 6e6f 223e 2020 3538 323c 2f73 7061 6e3e no"> 582 │ │ │ │ +00018570: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ +000185c0: 2020 3538 333c 2f73 7061 6e3e 2020 2020 583 │ │ │ │ +000185d0: 3c73 7061 6e20 636c 6173 733d 226b 6579 if ((cRule == < │ │ │ │ +00018600: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00018610: 5f65 6e75 6d76 616c 7565 2220 6872 6566 _enumvalue" href │ │ │ │ +00018620: 3d22 6130 3133 3333 2e68 746d 6c23 6131 ="a01333.html#a1 │ │ │ │ +00018630: 3166 6364 3531 6566 3836 3131 3866 3635 1fcd51ef86118f65 │ │ │ │ +00018640: 6536 3033 6331 3437 3433 3737 6137 3861 e603c1474377a78a │ │ │ │ +00018650: 3631 6431 3337 6638 3636 3939 3765 6433 61d137f866997ed3 │ │ │ │ +00018660: 3639 3365 3366 6361 6437 3664 6566 3566 693e3fcad76def5f │ │ │ │ +00018670: 223e 4372 6561 7365 3a3a 5255 4c45 5f53 ">Crease::RULE_S │ │ │ │ +00018680: 4d4f 4f54 483c 2f61 3e29 207c 7c20 2863 MOOTH) || (c │ │ │ │ +00018690: 5275 6c65 203d 3d20 3c61 2063 6c61 7373 Rule == Creas │ │ │ │ +00018710: 653a 3a52 554c 455f 4441 5254 3c2f 613e e::RULE_DART │ │ │ │ +00018720: 2929 207b 3c2f 6469 763e 0a3c 6469 7620 )) {
.
584 │ │ │ │ +00018780: 2020 2020 2020 2061 7373 6967 6e53 6d6f assignSmo │ │ │ │ +00018790: 6f74 684d 6173 6b46 6f72 5665 7274 6578 othMaskForVertex │ │ │ │ +000187a0: 2876 6572 7465 782c 2063 4d61 736b 293b (vertex, cMask); │ │ │ │ +000187b0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00018800: 2035 3835 3c2f 7370 616e 3e20 2020 207d 585 } │ │ │ │ +00018810: 203c 7370 616e 2063 6c61 7373 3d22 6b65 else< │ │ │ │ +00018830: 2f73 7061 6e3e 203c 7370 616e 2063 6c61 /span> if (cRul │ │ │ │ +00018860: 6520 3d3d 203c 6120 636c 6173 733d 2263 e == Crease:: │ │ │ │ +000188e0: 5255 4c45 5f43 5245 4153 453c 2f61 3e29 RULE_CREASE) │ │ │ │ +000188f0: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
586 │ │ │ │ +00018950: 2020 2020 203c 7370 616e 2063 6c61 7373 i │ │ │ │ +00018970: 6e74 3c2f 7370 616e 3e20 6372 6561 7365 nt crease │ │ │ │ +00018980: 456e 6473 5b32 5d3b 3c2f 6469 763e 0a3c Ends[2];
.< │ │ │ │ +00018990: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +000189a0: 3e3c 6120 6964 3d22 6c30 3035 3837 2220 > 587 Crease(_options).Get │ │ │ │ +00018a80: 5368 6172 7045 6467 6550 6169 724f 6643 SharpEdgePairOfC │ │ │ │ +00018a90: 7265 6173 653c 2f61 3e28 6345 6467 6553 rease(cEdgeS │ │ │ │ +00018aa0: 6861 7270 6e65 7373 2c20 7661 6c65 6e63 harpness, valenc │ │ │ │ +00018ab0: 652c 2063 7265 6173 6545 6e64 7329 3b3c e, creaseEnds);< │ │ │ │ +00018ac0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00018b10: 3538 383c 2f73 7061 6e3e 203c 2f64 6976 588
.
589< │ │ │ │ +00018b70: 2f73 7061 6e3e 2020 2020 2020 2020 6173 /span> as │ │ │ │ +00018b80: 7369 676e 4372 6561 7365 4d61 736b 466f signCreaseMaskFo │ │ │ │ +00018b90: 7256 6572 7465 7828 7665 7274 6578 2c20 rVertex(vertex, │ │ │ │ +00018ba0: 634d 6173 6b2c 2063 7265 6173 6545 6e64 cMask, creaseEnd │ │ │ │ +00018bb0: 7329 3b3c 2f64 6976 3e0a 3c64 6976 2063 s);
.
590 │ │ │ │ +00018c10: 2020 7d20 3c73 7061 6e20 636c 6173 733d } el │ │ │ │ +00018c30: 7365 3c2f 7370 616e 3e20 7b3c 2f64 6976 se {
.
591< │ │ │ │ +00018c90: 2f73 7061 6e3e 2020 2020 2020 2020 6173 /span> as │ │ │ │ +00018ca0: 7369 676e 436f 726e 6572 4d61 736b 466f signCornerMaskFo │ │ │ │ +00018cb0: 7256 6572 7465 7828 7665 7274 6578 2c20 rVertex(vertex, │ │ │ │ +00018cc0: 634d 6173 6b29 3b3c 2f64 6976 3e0a 3c64 cMask);
. │ │ │ │ +00018ce0: 3c61 2069 643d 226c 3030 3539 3222 206e 592 }
. │ │ │ │ +00018d40: 3c61 2069 643d 226c 3030 3539 3322 206e 593
.
594 │ │ │ │ +00018de0: 2020 5765 6967 6874 2070 5765 6967 6874 Weight pWeight │ │ │ │ +00018df0: 203d 2063 7265 6173 652e 3c61 2063 6c61 = crease.Compu │ │ │ │ +00018e50: 7465 4672 6163 7469 6f6e 616c 5765 6967 teFractionalWeig │ │ │ │ +00018e60: 6874 4174 5665 7274 6578 3c2f 613e 2870 htAtVertex(p │ │ │ │ +00018e70: 5665 7274 6578 5368 6172 706e 6573 732c VertexSharpness, │ │ │ │ +00018e80: 2063 5665 7274 6578 5368 6172 706e 6573 cVertexSharpnes │ │ │ │ +00018e90: 732c 3c2f 6469 763e 0a3c 6469 7620 636c s,
.
595 │ │ │ │ +00018ef0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00018f00: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00018f10: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00018f20: 7661 6c65 6e63 652c 2070 4564 6765 5368 valence, pEdgeSh │ │ │ │ +00018f30: 6172 706e 6573 732c 2063 4564 6765 5368 arpness, cEdgeSh │ │ │ │ +00018f40: 6172 706e 6573 7329 3b3c 2f64 6976 3e0a arpness);
. │ │ │ │ +00018f50: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.< │ │ │ │ +00018fd0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00018fe0: 3e3c 6120 6964 3d22 6c30 3035 3937 2220 > 597
.
598 │ │ │ │ +00019080: 2020 2063 4d61 736b 2e3c 6120 636c 6173 cMask.Combin │ │ │ │ +000190e0: 6556 6572 7465 7856 6572 7465 784d 6173 eVertexVertexMas │ │ │ │ +000190f0: 6b73 3c2f 613e 2863 5765 6967 6874 2c20 ks(cWeight, │ │ │ │ +00019100: 7057 6569 6768 742c 206d 6173 6b29 3b3c pWeight, mask);< │ │ │ │ +00019110: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00019160: 3539 393c 2f73 7061 6e3e 7d3c 2f64 6976 599}
.
.
600 .
6 │ │ │ │ +00019220: 3031 3c2f 7370 616e 3e3c 7370 616e 2063 01/ │ │ │ │ +00019240: 2f3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c /
.< │ │ │ │ +00019250: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00019260: 3e3c 6120 6964 3d22 6c30 3036 3032 2220 > 602// The │ │ │ │ +000192c0: 2063 6f6d 7075 7461 7469 6f6e 206f 6620 computation of │ │ │ │ +000192d0: 6c69 6d69 7420 6d61 736b 7320 666f 7220 limit masks for │ │ │ │ +000192e0: 7665 7274 6963 6573 3a3c 2f73 7061 6e3e vertices: │ │ │ │ +000192f0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00019340: 2036 3033 3c2f 7370 616e 3e3c 7370 616e 603//
│ │ │ │ +00019370: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +000193a0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 604templ │ │ │ │ +000193e0: 6174 653c 2f73 7061 6e3e 2026 6c74 3b53 ate <S │ │ │ │ +000193f0: 6368 656d 6554 7970 6520 5343 4845 4d45 chemeType SCHEME │ │ │ │ +00019400: 2667 743b 3c2f 6469 763e 0a3c 6469 7620 >
.
605< │ │ │ │ +00019460: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00019470: 6f72 6422 3e74 656d 706c 6174 653c 2f73 ord">template <t │ │ │ │ +000194a0: 7970 656e 616d 653c 2f73 7061 6e3e 2056 ypename V │ │ │ │ +000194b0: 4552 5445 582c 203c 7370 616e 2063 6c61 ERTEX, typ │ │ │ │ +000194d0: 656e 616d 653c 2f73 7061 6e3e 204d 4153 ename MAS │ │ │ │ +000194e0: 4b26 6774 3b3c 2f64 6976 3e0a 3c64 6976 K>
.
< │ │ │ │ +00019520: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00019530: 6e6f 223e 2020 3630 363c 2f73 7061 6e3e no"> 606 │ │ │ │ +00019540: 3c73 7061 6e20 636c 6173 733d 226b 6579 void
.
.
│ │ │ │ +00019640: 2036 3037 3c2f 613e 3c2f 7370 616e 3e3c 607< │ │ │ │ +00019650: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00019660: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ +00019670: 2261 3031 3334 312e 6874 6d6c 2361 3363 "a01341.html#a3c │ │ │ │ +00019680: 3864 3736 3363 6131 3863 3435 3763 3933 8d763ca18c457c93 │ │ │ │ +00019690: 3664 6230 6534 3739 3937 3436 6632 223e 6db0e4799746f2"> │ │ │ │ +000196a0: 5363 6865 6d65 266c 743b 5343 4845 4d45 Scheme<SCHEME │ │ │ │ +000196b0: 2667 743b 3a3a 436f 6d70 7574 6556 6572 >::ComputeVer │ │ │ │ +000196c0: 7465 784c 696d 6974 4d61 736b 3c2f 613e texLimitMask │ │ │ │ +000196d0: 2856 4552 5445 5820 3c73 7061 6e20 636c (VERTEX co │ │ │ │ +000196f0: 6e73 743c 2f73 7061 6e3e 2661 6d70 3b20 nst& │ │ │ │ +00019700: 7665 7274 6578 2c3c 2f64 6976 3e0a 3c64 vertex,
. │ │ │ │ +00019720: 3c61 2069 643d 226c 3030 3630 3822 206e 608 │ │ │ │ +00019770: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00019780: 2020 2020 2020 2020 204d 4153 4b26 616d MASK&am │ │ │ │ +00019790: 703b 2020 2020 2020 2020 206d 6173 6b2c p; mask, │ │ │ │ +000197a0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +000197f0: 2036 3039 3c2f 7370 616e 3e20 2020 2020 609 │ │ │ │ +00019800: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00019810: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +00019820: 2020 3c61 2063 6c61 7373 3d22 636f 6465 Crease::Ru │ │ │ │ +00019880: 6c65 3c2f 613e 2020 7275 6c65 293c 7370 le rule) const {
.
610 .
6 │ │ │ │ +00019960: 3131 3c2f 7370 616e 3e20 2020 203c 7370 11 if │ │ │ │ +00019990: 2028 2872 756c 6520 3d3d 203c 6120 636c ((rule == Cr │ │ │ │ +00019a10: 6561 7365 3a3a 5255 4c45 5f53 4d4f 4f54 ease::RULE_SMOOT │ │ │ │ +00019a20: 483c 2f61 3e29 207c 7c20 2872 756c 6520 H) || (rule │ │ │ │ +00019a30: 3d3d 203c 6120 636c 6173 733d 2263 6f64 == Crease::RU │ │ │ │ +00019ab0: 4c45 5f44 4152 543c 2f61 3e29 2920 7b3c LE_DART)) {< │ │ │ │ +00019ac0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00019b10: 3631 323c 2f73 7061 6e3e 2020 2020 2020 612 │ │ │ │ +00019b20: 2020 6173 7369 676e 536d 6f6f 7468 4c69 assignSmoothLi │ │ │ │ +00019b30: 6d69 744d 6173 6b28 7665 7274 6578 2c20 mitMask(vertex, │ │ │ │ +00019b40: 6d61 736b 293b 3c2f 6469 763e 0a3c 6469 mask);
.< │ │ │ │ +00019b60: 6120 6964 3d22 6c30 3036 3133 2220 6e61 a id="l00613" na │ │ │ │ +00019b70: 6d65 3d22 6c30 3036 3133 223e 3c2f 613e me="l00613"> │ │ │ │ +00019b80: 3c73 7061 6e20 636c 6173 733d 226c 696e 613 } else if │ │ │ │ +00019bf0: 2028 7275 6c65 203d 3d20 3c61 2063 6c61 (rule == Cre │ │ │ │ +00019c70: 6173 653a 3a52 554c 455f 4352 4541 5345 ase::RULE_CREASE │ │ │ │ +00019c80: 3c2f 613e 2920 7b3c 2f64 6976 3e0a 3c64 ) {
. │ │ │ │ +00019ca0: 3c61 2069 643d 226c 3030 3631 3422 206e 614
float │ │ │ │ +00019d10: 202a 2065 6467 6553 6861 7270 6e65 7373 * edgeSharpness │ │ │ │ +00019d20: 203d 2028 3c73 7061 6e20 636c 6173 733d = (fl │ │ │ │ +00019d40: 6f61 743c 2f73 7061 6e3e 202a 2961 6c6c oat *)all │ │ │ │ +00019d50: 6f63 6128 7665 7274 6578 2e47 6574 4e75 oca(vertex.GetNu │ │ │ │ +00019d60: 6d45 6467 6573 2829 202a 203c 7370 616e mEdges() * sizeof(f │ │ │ │ +00019d90: 6c6f 6174 2929 3b3c 2f64 6976 3e0a 3c64 loat));
. │ │ │ │ +00019db0: 3c61 2069 643d 226c 3030 3631 3522 206e 615 vertex │ │ │ │ +00019e00: 2e47 6574 5368 6172 706e 6573 7350 6572 .GetSharpnessPer │ │ │ │ +00019e10: 4564 6765 2865 6467 6553 6861 7270 6e65 Edge(edgeSharpne │ │ │ │ +00019e20: 7373 293b 3c2f 6469 763e 0a3c 6469 7620 ss);
.
616 │ │ │ │ +00019e80: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00019ed0: 2036 3137 3c2f 7370 616e 3e20 2020 2020 617 │ │ │ │ +00019ee0: 2020 203c 7370 616e 2063 6c61 7373 3d22 int │ │ │ │ +00019f00: 3c2f 7370 616e 3e20 6372 6561 7365 456e creaseEn │ │ │ │ +00019f10: 6473 5b32 5d3b 3c2f 6469 763e 0a3c 6469 ds[2];
.< │ │ │ │ +00019f30: 6120 6964 3d22 6c30 3036 3138 2220 6e61 a id="l00618" na │ │ │ │ +00019f40: 6d65 3d22 6c30 3036 3138 223e 3c2f 613e me="l00618"> │ │ │ │ +00019f50: 3c73 7061 6e20 636c 6173 733d 226c 696e 618 Crease( │ │ │ │ +00019fb0: 5f6f 7074 696f 6e73 292e 3c61 2063 6c61 _options).GetSh │ │ │ │ +0001a010: 6172 7045 6467 6550 6169 724f 6643 7265 arpEdgePairOfCre │ │ │ │ +0001a020: 6173 653c 2f61 3e28 6564 6765 5368 6172 ase(edgeShar │ │ │ │ +0001a030: 706e 6573 732c 2076 6572 7465 782e 4765 pness, vertex.Ge │ │ │ │ +0001a040: 744e 756d 4564 6765 7328 292c 2063 7265 tNumEdges(), cre │ │ │ │ +0001a050: 6173 6545 6e64 7329 3b3c 2f64 6976 3e0a aseEnds);
. │ │ │ │ +0001a060: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
< │ │ │ │ +0001a0f0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0001a100: 6e6f 223e 2020 3632 303c 2f73 7061 6e3e no"> 620 │ │ │ │ +0001a110: 2020 2020 2020 2020 6173 7369 676e 4372 assignCr │ │ │ │ +0001a120: 6561 7365 4c69 6d69 744d 6173 6b28 7665 easeLimitMask(ve │ │ │ │ +0001a130: 7274 6578 2c20 6d61 736b 2c20 6372 6561 rtex, mask, crea │ │ │ │ +0001a140: 7365 456e 6473 293b 3c2f 6469 763e 0a3c seEnds);
.< │ │ │ │ +0001a150: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0001a160: 3e3c 6120 6964 3d22 6c30 3036 3231 2220 > 621 } else { │ │ │ │ +0001a1d0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0001a220: 2036 3232 3c2f 7370 616e 3e20 2020 2020 622 │ │ │ │ +0001a230: 2020 2061 7373 6967 6e43 6f72 6e65 724c assignCornerL │ │ │ │ +0001a240: 696d 6974 4d61 736b 2876 6572 7465 782c imitMask(vertex, │ │ │ │ +0001a250: 206d 6173 6b29 3b3c 2f64 6976 3e0a 3c64 mask);
. │ │ │ │ +0001a270: 3c61 2069 643d 226c 3030 3632 3322 206e 623 }
. │ │ │ │ +0001a2d0: 3c61 2069 643d 226c 3030 3632 3422 206e 624}
.
│ │ │ │ +0001a320: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ +0001a390: 6120 6964 3d22 6c30 3036 3236 2220 6e61 a id="l00626" na │ │ │ │ +0001a3a0: 6d65 3d22 6c30 3036 3236 223e 3c2f 613e me="l00626"> │ │ │ │ +0001a3b0: 3c73 7061 6e20 636c 6173 733d 226c 696e 626template< │ │ │ │ +0001a3f0: 2f73 7061 6e3e 2026 6c74 3b53 6368 656d /span> <Schem │ │ │ │ +0001a400: 6554 7970 6520 5343 4845 4d45 2667 743b eType SCHEME> │ │ │ │ +0001a410: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0001a460: 2036 3237 3c2f 7370 616e 3e3c 7370 616e 627template │ │ │ │ +0001a490: 2026 6c74 3b3c 7370 616e 2063 6c61 7373 <typen │ │ │ │ +0001a4b0: 616d 653c 2f73 7061 6e3e 2056 4552 5445 ame VERTE │ │ │ │ +0001a4c0: 582c 203c 7370 616e 2063 6c61 7373 3d22 X, typenam │ │ │ │ +0001a4e0: 653c 2f73 7061 6e3e 204d 4153 4b26 6774 e MASK> │ │ │ │ +0001a4f0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +0001a540: 2020 3632 383c 2f73 7061 6e3e 3c73 7061 628void
.
. │ │ │ │ +0001a5d0: 3c61 2069 643d 226c 3030 3632 3922 206e 629 │ │ │ │ +0001a650: 3c2f 613e 3c2f 7370 616e 3e3c 6120 636c Sche │ │ │ │ +0001a6b0: 6d65 266c 743b 5343 4845 4d45 2667 743b me<SCHEME> │ │ │ │ +0001a6c0: 3a3a 436f 6d70 7574 6556 6572 7465 784c ::ComputeVertexL │ │ │ │ +0001a6d0: 696d 6974 4d61 736b 3c2f 613e 2856 4552 imitMask(VER │ │ │ │ +0001a6e0: 5445 5820 3c73 7061 6e20 636c 6173 733d TEX const< │ │ │ │ +0001a700: 2f73 7061 6e3e 2661 6d70 3b20 7665 7274 /span>& vert │ │ │ │ +0001a710: 6578 2c3c 2f64 6976 3e0a 3c64 6976 2063 ex,
.
630 │ │ │ │ +0001a770: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0001a780: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0001a790: 2020 2020 204d 4153 4b26 616d 703b 2020 MASK& │ │ │ │ +0001a7a0: 2020 2020 2020 2070 6f73 4d61 736b 2c3c posMask,< │ │ │ │ +0001a7b0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0001a800: 3633 313c 2f73 7061 6e3e 2020 2020 2020 631 │ │ │ │ +0001a810: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0001a820: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0001a830: 204d 4153 4b26 616d 703b 2020 2020 2020 MASK& │ │ │ │ +0001a840: 2020 2074 616e 314d 6173 6b2c 3c2f 6469 tan1Mask,.
632 │ │ │ │ +0001a8a0: 3c2f 7370 616e 3e20 2020 2020 2020 2020 │ │ │ │ +0001a8b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ +0001a8c0: 2020 2020 2020 2020 2020 2020 2020 4d41 MA │ │ │ │ +0001a8d0: 534b 2661 6d70 3b20 2020 2020 2020 2020 SK& │ │ │ │ +0001a8e0: 7461 6e32 4d61 736b 2c3c 2f64 6976 3e0a tan2Mask,
. │ │ │ │ +0001a8f0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
634< │ │ │ │ +0001aa50: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ +0001aa70: 3c61 2069 643d 226c 3030 3633 3522 206e 635 │ │ │ │ +0001aad0: 6966 3c2f 7370 616e 3e20 2828 7275 6c65 if ((rule │ │ │ │ +0001aae0: 203d 3d20 3c61 2063 6c61 7373 3d22 636f == Crease::R │ │ │ │ +0001ab60: 554c 455f 534d 4f4f 5448 3c2f 613e 2920 ULE_SMOOTH) │ │ │ │ +0001ab70: 7c7c 2028 7275 6c65 203d 3d20 3c61 2063 || (rule == C │ │ │ │ +0001abf0: 7265 6173 653a 3a52 554c 455f 4441 5254 rease::RULE_DART │ │ │ │ +0001ac00: 3c2f 613e 2929 207b 3c2f 6469 763e 0a3c )) {
.< │ │ │ │ +0001ac10: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +0001ac20: 3e3c 6120 6964 3d22 6c30 3036 3336 2220 > 636 assig │ │ │ │ +0001ac70: 6e53 6d6f 6f74 684c 696d 6974 4d61 736b nSmoothLimitMask │ │ │ │ +0001ac80: 2876 6572 7465 782c 2070 6f73 4d61 736b (vertex, posMask │ │ │ │ +0001ac90: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
637 │ │ │ │ +0001acf0: 2020 2020 2061 7373 6967 6e53 6d6f 6f74 assignSmoot │ │ │ │ +0001ad00: 684c 696d 6974 5461 6e67 656e 744d 6173 hLimitTangentMas │ │ │ │ +0001ad10: 6b73 2876 6572 7465 782c 2074 616e 314d ks(vertex, tan1M │ │ │ │ +0001ad20: 6173 6b2c 2074 616e 324d 6173 6b29 3b3c ask, tan2Mask);< │ │ │ │ +0001ad30: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0001ad80: 3633 383c 2f73 7061 6e3e 2020 2020 7d20 638 } │ │ │ │ +0001ad90: 3c73 7061 6e20 636c 6173 733d 226b 6579 else │ │ │ │ +0001add0: 6966 3c2f 7370 616e 3e20 2872 756c 6520 if (rule │ │ │ │ +0001ade0: 3d3d 203c 6120 636c 6173 733d 2263 6f64 == Crease::RU │ │ │ │ +0001ae60: 4c45 5f43 5245 4153 453c 2f61 3e29 207b LE_CREASE) { │ │ │ │ +0001ae70: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0001aec0: 2036 3339 3c2f 7370 616e 3e20 2020 2020 639 │ │ │ │ +0001aed0: 2020 203c 7370 616e 2063 6c61 7373 3d22 flo │ │ │ │ +0001aef0: 6174 3c2f 7370 616e 3e20 2a20 6564 6765 at * edge │ │ │ │ +0001af00: 5368 6172 706e 6573 7320 3d20 283c 7370 Sharpness = (float *)alloca(ver │ │ │ │ +0001af40: 7465 782e 4765 744e 756d 4564 6765 7328 tex.GetNumEdges( │ │ │ │ +0001af50: 2920 2a20 3c73 7061 6e20 636c 6173 733d ) * sizeof │ │ │ │ +0001af70: 3c2f 7370 616e 3e28 666c 6f61 7429 293b (float)); │ │ │ │ +0001af80: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +0001afd0: 2036 3430 3c2f 7370 616e 3e20 2020 2020 640 │ │ │ │ +0001afe0: 2020 2076 6572 7465 782e 4765 7453 6861 vertex.GetSha │ │ │ │ +0001aff0: 7270 6e65 7373 5065 7245 6467 6528 6564 rpnessPerEdge(ed │ │ │ │ +0001b000: 6765 5368 6172 706e 6573 7329 3b3c 2f64 geSharpness);.
64 │ │ │ │ +0001b060: 313c 2f73 7061 6e3e 203c 2f64 6976 3e0a 1
. │ │ │ │ +0001b070: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +0001b0a0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 642 int │ │ │ │ +0001b0f0: 2063 7265 6173 6545 6e64 735b 325d 3b3c creaseEnds[2];< │ │ │ │ +0001b100: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0001b150: 3634 333c 2f73 7061 6e3e 2020 2020 2020 643 │ │ │ │ +0001b160: 2020 3c61 2063 6c61 7373 3d22 636f 6465 Cr │ │ │ │ +0001b190: 6561 7365 3c2f 613e 285f 6f70 7469 6f6e ease(_option │ │ │ │ +0001b1a0: 7329 2e3c 6120 636c 6173 733d 2263 6f64 s).GetSharpEdge │ │ │ │ +0001b200: 5061 6972 4f66 4372 6561 7365 3c2f 613e PairOfCrease │ │ │ │ +0001b210: 2865 6467 6553 6861 7270 6e65 7373 2c20 (edgeSharpness, │ │ │ │ +0001b220: 7665 7274 6578 2e47 6574 4e75 6d45 6467 vertex.GetNumEdg │ │ │ │ +0001b230: 6573 2829 2c20 6372 6561 7365 456e 6473 es(), creaseEnds │ │ │ │ +0001b240: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
644 .
6 │ │ │ │ +0001b2f0: 3435 3c2f 7370 616e 3e20 2020 2020 2020 45 │ │ │ │ +0001b300: 2061 7373 6967 6e43 7265 6173 654c 696d assignCreaseLim │ │ │ │ +0001b310: 6974 4d61 736b 2876 6572 7465 782c 2070 itMask(vertex, p │ │ │ │ +0001b320: 6f73 4d61 736b 2c20 6372 6561 7365 456e osMask, creaseEn │ │ │ │ +0001b330: 6473 293b 3c2f 6469 763e 0a3c 6469 7620 ds);
.
646 │ │ │ │ +0001b390: 2020 2020 2020 2061 7373 6967 6e43 7265 assignCre │ │ │ │ +0001b3a0: 6173 654c 696d 6974 5461 6e67 656e 744d aseLimitTangentM │ │ │ │ +0001b3b0: 6173 6b73 2876 6572 7465 782c 2074 616e asks(vertex, tan │ │ │ │ +0001b3c0: 314d 6173 6b2c 2074 616e 324d 6173 6b2c 1Mask, tan2Mask, │ │ │ │ +0001b3d0: 2063 7265 6173 6545 6e64 7329 3b3c 2f64 creaseEnds);.
64 │ │ │ │ +0001b430: 373c 2f73 7061 6e3e 2020 2020 7d20 3c73 7 } else {
.
< │ │ │ │ +0001b4a0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0001b4b0: 6e6f 223e 2020 3634 383c 2f73 7061 6e3e no"> 648 │ │ │ │ +0001b4c0: 2020 2020 2020 2020 6173 7369 676e 436f assignCo │ │ │ │ +0001b4d0: 726e 6572 4c69 6d69 744d 6173 6b28 7665 rnerLimitMask(ve │ │ │ │ +0001b4e0: 7274 6578 2c20 706f 734d 6173 6b29 3b3c rtex, posMask);< │ │ │ │ +0001b4f0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0001b540: 3634 393c 2f73 7061 6e3e 2020 2020 2020 649 │ │ │ │ +0001b550: 2020 6173 7369 676e 436f 726e 6572 4c69 assignCornerLi │ │ │ │ +0001b560: 6d69 7454 616e 6765 6e74 4d61 736b 7328 mitTangentMasks( │ │ │ │ +0001b570: 7665 7274 6578 2c20 7461 6e31 4d61 736b vertex, tan1Mask │ │ │ │ +0001b580: 2c20 7461 6e32 4d61 736b 293b 3c2f 6469 , tan2Mask);.
650 │ │ │ │ +0001b5e0: 3c2f 7370 616e 3e20 2020 207d 3c2f 6469 }.
651 │ │ │ │ +0001b640: 3c2f 7370 616e 3e7d 3c2f 6469 763e 0a3c }
.< │ │ │ │ +0001b650: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +0001b6a0: 3635 323c 2f73 7061 6e3e 203c 2f64 6976 652
.
653< │ │ │ │ +0001b700: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ +0001b720: 3c61 2069 643d 226c 3030 3635 3422 206e 654} // end │ │ │ │ +0001b780: 206e 616d 6573 7061 6365 2073 6463 3c2f namespace sdc
.
< │ │ │ │ +0001b7d0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +0001b7e0: 6e6f 223e 2020 3635 353c 2f73 7061 6e3e no"> 655 │ │ │ │ +0001b7f0: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ +0001b840: 2020 3635 363c 2f73 7061 6e3e 7d20 3c73 656} // end names │ │ │ │ +0001b870: 7061 6365 204f 5045 4e53 5542 4449 565f pace OPENSUBDIV_ │ │ │ │ +0001b880: 5645 5253 494f 4e3c 2f73 7061 6e3e 3c2f VERSION.
6 │ │ │ │ +0001b8e0: 3537 3c2f 7370 616e 3e3c 7370 616e 2063 57u │ │ │ │ +0001b900: 7369 6e67 206e 616d 6573 7061 6365 203c sing namespace < │ │ │ │ +0001b910: 2f73 7061 6e3e 4f50 454e 5355 4244 4956 /span>OPENSUBDIV │ │ │ │ +0001b920: 5f56 4552 5349 4f4e 3b3c 2f64 6976 3e0a _VERSION;
. │ │ │ │ +0001b930: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +0001b960: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 658} // e │ │ │ │ +0001b9a0: 6e64 206e 616d 6573 7061 6365 204f 7065 nd namespace Ope │ │ │ │ +0001b9b0: 6e53 7562 6469 763c 2f73 7061 6e3e 3c2f nSubdiv.
6 │ │ │ │ +0001ba10: 3539 3c2f 7370 616e 3e20 3c2f 6469 763e 59
│ │ │ │ +0001ba20: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +0001ba50: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 660 │ │ │ │ +0001ba90: 2365 6e64 6966 203c 2f73 7061 6e3e 3c73 #endif /* OPENSUBDI │ │ │ │ +0001bac0: 5633 5f53 4443 5f53 4348 454d 455f 4820 V3_SDC_SCHEME_H │ │ │ │ +0001bad0: 2a2f 3c2f 7370 616e 3e3c 7370 616e 2063 */
.
E │ │ │ │ +0001bcc0: 6e75 6d65 7261 7465 6420 7479 7065 2066 numerated type f │ │ │ │ +0001bcd0: 6f72 2061 6c6c 2066 6163 6520 7370 6c69 or all face spli │ │ │ │ +0001bce0: 7474 696e 6720 7363 6865 6d65 732e 3c2f tting schemes.
Defini │ │ │ │ +0001bd10: 7469 6f6e 3c2f 623e 203c 6120 6872 6566 tion typ │ │ │ │ +0001bd40: 6573 2e68 3a34 373c 2f61 3e3c 2f64 6976 es.h:47
.
< │ │ │ │ +0001bd90: 6120 6872 6566 3d22 6130 3133 3333 2e68 a href="a01333.h │ │ │ │ +0001bda0: 746d 6c22 3e4f 7065 6e53 7562 6469 763a tml">OpenSubdiv: │ │ │ │ +0001bdb0: 3a4f 5045 4e53 5542 4449 565f 5645 5253 :OPENSUBDIV_VERS │ │ │ │ +0001bdc0: 494f 4e3a 3a53 6463 3a3a 4372 6561 7365 ION::Sdc::Crease │ │ │ │ +0001bdd0: 3c2f 613e 3c2f 6469 763e 3c64 6976 2063
Typ │ │ │ │ +0001bdf0: 6573 2c20 636f 6e73 7461 6e74 7320 616e es, constants an │ │ │ │ +0001be00: 6420 7574 696c 6974 6965 7320 7265 6c61 d utilities rela │ │ │ │ +0001be10: 7465 6420 746f 2073 656d 692d 7368 6172 ted to semi-shar │ │ │ │ +0001be20: 7020 6372 6561 7369 6e67 20e2 8093 2077 p creasing ... w │ │ │ │ +0001be30: 686f 7365 2069 6d70 6c65 6d65 6e74 6174 hose implementat │ │ │ │ +0001be40: 696f 6e20 6973 2069 6e64 6570 656e 6465 ion is independe │ │ │ │ +0001be50: 6e74 206f 2e2e 2e3c 2f64 6976 3e3c 6469 nt o...
│ │ │ │ +0001be70: 3c62 3e44 6566 696e 6974 696f 6e3c 2f62 Definition crease.h:6 │ │ │ │ +0001beb0: 323c 2f61 3e3c 2f64 6976 3e3c 2f64 6976 2
.
< │ │ │ │ +0001bfc0: 623e 4465 6669 6e69 7469 6f6e 3c2f 623e b>Definition │ │ │ │ +0001bfd0: 203c 6120 6872 6566 3d22 6130 3037 3739 crease.h:82 │ │ │ │ +0001c000: 3c2f 613e 3c2f 6469 763e 3c2f 6469 763e
│ │ │ │ +0001c010: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
.
OpenSubdiv::OPE │ │ │ │ +0001c290: 4e53 5542 4449 565f 5645 5253 494f 4e3a NSUBDIV_VERSION: │ │ │ │ +0001c2a0: 3a53 6463 3a3a 4372 6561 7365 3a3a 5255 :Sdc::Crease::RU │ │ │ │ +0001c2b0: 4c45 5f53 4d4f 4f54 483c 2f61 3e3c 2f64 LE_SMOOTH
@ RULE_SM │ │ │ │ +0001c2e0: 4f4f 5448 3c2f 6469 763e 3c64 6976 2063 OOTH
│ │ │ │ +0001c300: 4465 6669 6e69 7469 6f6e 3c2f 623e 203c Definition < │ │ │ │ +0001c310: 6120 6872 6566 3d22 6130 3037 3739 5f73 a href="a00779_s │ │ │ │ +0001c320: 6f75 7263 652e 6874 6d6c 236c 3030 3038 ource.html#l0008 │ │ │ │ +0001c330: 3422 3e63 7265 6173 652e 683a 3834 3c2f 4">crease.h:84
.< │ │ │ │ +0001c350: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ +0001c360: 6964 3d22 6161 3031 3333 335f 6874 6d6c id="aa01333_html │ │ │ │ +0001c370: 5f61 3131 6663 6435 3165 6638 3631 3138 _a11fcd51ef86118 │ │ │ │ +0001c380: 6636 3565 3630 3363 3134 3734 3337 3761 f65e603c1474377a │ │ │ │ +0001c390: 3738 6139 3636 6661 3161 6538 6165 6238 78a966fa1ae8aeb8 │ │ │ │ +0001c3a0: 3538 3763 3439 3863 6636 6139 3263 6333 587c498cf6a92cc3 │ │ │ │ +0001c3b0: 3333 3522 3e3c 6469 7620 636c 6173 733d 335">. │ │ │ │ +0001c4f0: 3c64 6976 2063 6c61 7373 3d22 7474 6322 .
OpenSubdiv:: │ │ │ │ +0001c730: 4f50 454e 5355 4244 4956 5f56 4552 5349 OPENSUBDIV_VERSI │ │ │ │ +0001c740: 4f4e 3a3a 5364 633a 3a43 7265 6173 653a ON::Sdc::Crease: │ │ │ │ +0001c750: 3a47 6574 5368 6172 7045 6467 6550 6169 :GetSharpEdgePai │ │ │ │ +0001c760: 724f 6643 7265 6173 653c 2f61 3e3c 2f64 rOfCrease
void GetS │ │ │ │ +0001c790: 6861 7270 4564 6765 5061 6972 4f66 4372 harpEdgePairOfCr │ │ │ │ +0001c7a0: 6561 7365 2866 6c6f 6174 2063 6f6e 7374 ease(float const │ │ │ │ +0001c7b0: 202a 696e 6369 6465 6e74 4564 6765 5368 *incidentEdgeSh │ │ │ │ +0001c7c0: 6172 706e 6573 732c 2069 6e74 2069 6e63 arpness, int inc │ │ │ │ +0001c7d0: 6964 656e 7445 6467 6543 6f75 6e74 2c20 identEdgeCount, │ │ │ │ +0001c7e0: 696e 7420 7368 6172 7045 6467 6550 6169 int sharpEdgePai │ │ │ │ +0001c7f0: 725b 325d 2920 636f 6e73 743c 2f64 6976 r[2]) const
Definitio │ │ │ │ +0001c820: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n crease │ │ │ │ +0001c850: 2e68 3a32 3238 3c2f 613e 3c2f 6469 763e .h:228
│ │ │ │ +0001c860: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
..< │ │ │ │ +0001c9e0: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ +0001c9f0: 6964 3d22 6161 3031 3333 335f 6874 6d6c id="aa01333_html │ │ │ │ +0001ca00: 5f61 3564 6661 3638 3130 6635 3130 6661 _a5dfa6810f510fa │ │ │ │ +0001ca10: 6331 6563 3632 3166 6339 6536 6235 3330 c1ec621fc9e6b530 │ │ │ │ +0001ca20: 6334 223e 3c64 6976 2063 6c61 7373 3d22 c4"> │ │ │ │ +0001cab0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
bool IsUnifo │ │ │ │ +0001cad0: 726d 2829 2063 6f6e 7374 3c2f 6469 763e rm() const
│ │ │ │ +0001cae0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ +0001cb00: 3c2f 623e 203c 6120 6872 6566 3d22 6130 crease. │ │ │ │ +0001cb30: 683a 3935 3c2f 613e 3c2f 6469 763e 3c2f h:95
.
│ │ │ │ +0001cc40: 666c 6f61 7420 436f 6d70 7574 6546 7261 float ComputeFra │ │ │ │ +0001cc50: 6374 696f 6e61 6c57 6569 6768 7441 7456 ctionalWeightAtV │ │ │ │ +0001cc60: 6572 7465 7828 666c 6f61 7420 7665 7274 ertex(float vert │ │ │ │ +0001cc70: 6578 5368 6172 706e 6573 732c 2066 6c6f exSharpness, flo │ │ │ │ +0001cc80: 6174 2063 6869 6c64 5665 7274 6578 5368 at childVertexSh │ │ │ │ +0001cc90: 6172 706e 6573 732c 2069 6e74 2069 6e63 arpness, int inc │ │ │ │ +0001cca0: 6964 656e 7445 6467 6543 6f75 6e74 2c20 identEdgeCount, │ │ │ │ +0001ccb0: 666c 6f61 7420 636f 6e73 7420 2a69 6e63 float const *inc │ │ │ │ +0001ccc0: 6964 656e 7445 6467 6553 6861 7270 6e65 identEdgeSharpne │ │ │ │ +0001ccd0: 7373 2c20 666c 6f61 7420 636f 6e73 7420 ss, float const │ │ │ │ +0001cce0: 2a63 6869 6c64 4564 6765 7353 6861 7270 *childEdgesSharp │ │ │ │ +0001ccf0: 6e65 7373 2920 636f 6e73 743c 2f64 6976 ness) const
Transitional │ │ │ │ +0001cd20: 2077 6569 6768 7469 6e67 3a20 5768 656e weighting: When │ │ │ │ +0001cd30: 2074 6865 2072 756c 6573 2061 7070 6c69 the rules appli │ │ │ │ +0001cd40: 6361 626c 6520 746f 2061 2070 6172 656e cable to a paren │ │ │ │ +0001cd50: 7420 7665 7274 6578 2061 6e64 2069 7473 t vertex and its │ │ │ │ +0001cd60: 2063 6869 6c64 2064 6966 6665 722c 2e2e child differ,.. │ │ │ │ +0001cd70: 2e3c 2f64 6976 3e3c 2f64 6976 3e0a 3c64 .
.
All supporte │ │ │ │ +0001ce20: 6420 6f70 7469 6f6e 7320 6170 706c 7969 d options applyi │ │ │ │ +0001ce30: 6e67 2074 6f20 7375 6264 6976 6973 696f ng to subdivisio │ │ │ │ +0001ce40: 6e20 7363 6865 6d65 2e3c 2f64 6976 3e3c n scheme.
< │ │ │ │ +0001ce50: 6469 7620 636c 6173 733d 2274 7464 6566 div class="ttdef │ │ │ │ +0001ce60: 223e 3c62 3e44 6566 696e 6974 696f 6e3c ">Definition< │ │ │ │ +0001ce70: 2f62 3e20 3c61 2068 7265 663d 2261 3030 /b> options. │ │ │ │ +0001cea0: 683a 3531 3c2f 613e 3c2f 6469 763e 3c2f h:51
.
Scheme │ │ │ │ +0001cf50: 2069 7320 6120 636c 6173 7320 7465 6d70 is a class temp │ │ │ │ +0001cf60: 6c61 7465 2077 6869 6368 2070 726f 7669 late which provi │ │ │ │ +0001cf70: 6465 7320 616c 6c20 696d 706c 656d 656e des all implemen │ │ │ │ +0001cf80: 7461 7469 6f6e 2066 6f72 2074 6865 2073 tation for the s │ │ │ │ +0001cf90: 7562 6469 7669 7369 6f6e 2073 6368 656d ubdivision schem │ │ │ │ +0001cfa0: 6573 2073 7570 706f 7274 6564 2062 792e es supported by. │ │ │ │ +0001cfb0: 2e2e 3c2f 6469 763e 3c64 6976 2063 6c61 ..
De │ │ │ │ +0001cfd0: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:66 │ │ │ │ +0001d010: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.
│ │ │ │ +0001d110: 766f 6964 2061 7373 6967 6e53 6d6f 6f74 void assignSmoot │ │ │ │ +0001d120: 684d 6173 6b46 6f72 4564 6765 2845 4447 hMaskForEdge(EDG │ │ │ │ +0001d130: 4520 636f 6e73 7420 2661 6d70 3b65 6467 E const &edg │ │ │ │ +0001d140: 652c 204d 4153 4b20 2661 6d70 3b6d 6173 e, MASK &mas │ │ │ │ +0001d150: 6b29 2063 6f6e 7374 3c2f 6469 763e 3c2f k) const
.
OpenSubdiv │ │ │ │ +0001d200: 3a3a 4f50 454e 5355 4244 4956 5f56 4552 ::OPENSUBDIV_VER │ │ │ │ +0001d210: 5349 4f4e 3a3a 5364 633a 3a53 6368 656d SION::Sdc::Schem │ │ │ │ +0001d220: 653a 3a47 6574 546f 706f 6c6f 6769 6361 e::GetTopologica │ │ │ │ +0001d230: 6c53 706c 6974 5479 7065 3c2f 613e 3c2f lSplitType
static S │ │ │ │ +0001d260: 706c 6974 2047 6574 546f 706f 6c6f 6769 plit GetTopologi │ │ │ │ +0001d270: 6361 6c53 706c 6974 5479 7065 2829 3c2f calSplitType()
.
│ │ │ │ +0001d2d0: 3c64 6976 2063 6c61 7373 3d22 7474 6e61
│ │ │ │ +0001d380: 766f 6964 2061 7373 6967 6e43 7265 6173 void assignCreas │ │ │ │ +0001d390: 654d 6173 6b46 6f72 5665 7274 6578 2856 eMaskForVertex(V │ │ │ │ +0001d3a0: 4552 5445 5820 636f 6e73 7420 2661 6d70 ERTEX const & │ │ │ │ +0001d3b0: 3b65 6467 652c 204d 4153 4b20 2661 6d70 ;edge, MASK & │ │ │ │ +0001d3c0: 3b6d 6173 6b2c 2069 6e74 2063 6f6e 7374 ;mask, int const │ │ │ │ +0001d3d0: 2063 7265 6173 6545 6e64 735b 325d 2920 creaseEnds[2]) │ │ │ │ +0001d3e0: 636f 6e73 743c 2f64 6976 3e3c 2f64 6976 const
.
void Comput │ │ │ │ +0001d4f0: 6556 6572 7465 7856 6572 7465 784d 6173 eVertexVertexMas │ │ │ │ +0001d500: 6b28 5645 5254 4558 2063 6f6e 7374 2026 k(VERTEX const & │ │ │ │ +0001d510: 616d 703b 7665 7274 6578 4e65 6967 6862 amp;vertexNeighb │ │ │ │ +0001d520: 6f72 686f 6f64 2c20 4d41 534b 2026 616d orhood, MASK &am │ │ │ │ +0001d530: 703b 7665 7274 6578 5665 7274 6578 4d61 p;vertexVertexMa │ │ │ │ +0001d540: 736b 2c20 4372 6561 7365 3a3a 5275 6c65 sk, Crease::Rule │ │ │ │ +0001d550: 2070 6172 656e 7452 756c 653d 4372 6561 parentRule=Crea │ │ │ │ +0001d560: 7365 3a3a 5255 4c45 5f55 4e4b 4e4f 574e se::RULE_UNKNOWN │ │ │ │ +0001d570: 2c20 4372 6561 7365 3a3a 5275 6c65 2063 , Crease::Rule c │ │ │ │ +0001d580: 6869 6c64 5275 6c65 3d43 7265 6173 653a hildRule=Crease: │ │ │ │ +0001d590: 3a52 554c 455f 554e 4b4e 4f57 4e29 2063 :RULE_UNKNOWN) c │ │ │ │ +0001d5a0: 6f6e 7374 3c2f 6469 763e 3c64 6976 2063 onst
Ver │ │ │ │ +0001d5c0: 7465 782d 7665 7274 6578 206d 6173 6b73 tex-vertex masks │ │ │ │ +0001d5d0: 2049 6620 6b6e 6f77 6e2c 2061 2073 696e If known, a sin │ │ │ │ +0001d5e0: 676c 6520 5275 6c65 206f 7220 7061 6972 gle Rule or pair │ │ │ │ +0001d5f0: 206f 6620 5275 6c65 7320 6361 6e20 6265 of Rules can be │ │ │ │ +0001d600: 2073 7065 6369 6669 6564 2028 696e 6469 specified (indi │ │ │ │ +0001d610: 6361 7469 6e67 2061 2063 7265 6173 6520 cating a crease │ │ │ │ +0001d620: 7472 2e2e 2e3c 2f64 6976 3e3c 6469 7620 tr...
Definition │ │ │ │ +0001d650: 3c61 2068 7265 663d 2261 3030 3737 305f scheme.h:512 │ │ │ │ +0001d680: 3c2f 613e 3c2f 6469 763e 3c2f 6469 763e
│ │ │ │ +0001d690: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
< │ │ │ │ +0001d770: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ +0001d780: 6922 3e76 6f69 6420 436f 6d70 7574 6556 i">void ComputeV │ │ │ │ +0001d790: 6572 7465 784c 696d 6974 4d61 736b 2856 ertexLimitMask(V │ │ │ │ +0001d7a0: 4552 5445 5820 636f 6e73 7420 2661 6d70 ERTEX const & │ │ │ │ +0001d7b0: 3b76 6572 7465 784e 6569 6768 626f 7268 ;vertexNeighborh │ │ │ │ +0001d7c0: 6f6f 642c 204d 4153 4b20 2661 6d70 3b70 ood, MASK &p │ │ │ │ +0001d7d0: 6f73 6974 696f 6e4d 6173 6b2c 2043 7265 ositionMask, Cre │ │ │ │ +0001d7e0: 6173 653a 3a52 756c 6520 7665 7274 6578 ase::Rule vertex │ │ │ │ +0001d7f0: 5275 6c65 2920 636f 6e73 743c 2f64 6976 Rule) const
Limit masks │ │ │ │ +0001d820: 666f 7220 7665 7274 6963 6573 20e2 8093 for vertices ... │ │ │ │ +0001d830: 2070 6f73 6974 696f 6e20 616e 6420 7461 position and ta │ │ │ │ +0001d840: 6e67 656e 7473 2054 6865 7365 2070 7265 ngents These pre │ │ │ │ +0001d850: 7375 6d65 2074 6861 7420 6120 7665 7274 sume that a vert │ │ │ │ +0001d860: 6578 2069 7320 7375 6974 6162 6c79 2069 ex is suitably i │ │ │ │ +0001d870: 736f 6c61 7465 6420 666f 722e 2e2e 3c2f solated for...
Defini │ │ │ │ +0001d8a0: 7469 6f6e 3c2f 623e 203c 6120 6872 6566 tion sch │ │ │ │ +0001d8d0: 656d 652e 683a 3630 373c 2f61 3e3c 2f64 eme.h:607
.< │ │ │ │ +0001d9d0: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ +0001d9e0: 6922 3e76 6f69 6420 6173 7369 676e 4372 i">void assignCr │ │ │ │ +0001d9f0: 6561 7365 4c69 6d69 7454 616e 6765 6e74 easeLimitTangent │ │ │ │ +0001da00: 4d61 736b 7328 5645 5254 4558 2063 6f6e Masks(VERTEX con │ │ │ │ +0001da10: 7374 2026 616d 703b 7665 7274 6578 2c20 st &vertex, │ │ │ │ +0001da20: 4d41 534b 2026 616d 703b 7461 6e31 2c20 MASK &tan1, │ │ │ │ +0001da30: 4d41 534b 2026 616d 703b 7461 6e32 2c20 MASK &tan2, │ │ │ │ +0001da40: 696e 7420 636f 6e73 7420 6372 6561 7365 int const crease │ │ │ │ +0001da50: 456e 6473 5b32 5d29 2063 6f6e 7374 3c2f Ends[2]) const
.
│ │ │ │ +0001dab0: 3c64 6976 2063 6c61 7373 3d22 7474 6e61
Open │ │ │ │ +0001db00: 5375 6264 6976 3a3a 4f50 454e 5355 4244 Subdiv::OPENSUBD │ │ │ │ +0001db10: 4956 5f56 4552 5349 4f4e 3a3a 5364 633a IV_VERSION::Sdc: │ │ │ │ +0001db20: 3a53 6368 656d 653a 3a47 6574 5265 6775 :Scheme::GetRegu │ │ │ │ +0001db30: 6c61 7246 6163 6553 697a 653c 2f61 3e3c larFaceSize< │ │ │ │ +0001db40: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
static │ │ │ │ +0001db60: 696e 7420 4765 7452 6567 756c 6172 4661 int GetRegularFa │ │ │ │ +0001db70: 6365 5369 7a65 2829 3c2f 6469 763e 3c2f ceSize()
.
OpenSubdiv │ │ │ │ +0001dc20: 3a3a 4f50 454e 5355 4244 4956 5f56 4552 ::OPENSUBDIV_VER │ │ │ │ +0001dc30: 5349 4f4e 3a3a 5364 633a 3a53 6368 656d SION::Sdc::Schem │ │ │ │ +0001dc40: 653a 3a61 7373 6967 6e43 7265 6173 654d e::assignCreaseM │ │ │ │ +0001dc50: 6173 6b46 6f72 4564 6765 3c2f 613e 3c2f askForEdge
void ass │ │ │ │ +0001dc80: 6967 6e43 7265 6173 654d 6173 6b46 6f72 ignCreaseMaskFor │ │ │ │ +0001dc90: 4564 6765 2845 4447 4520 636f 6e73 7420 Edge(EDGE const │ │ │ │ +0001dca0: 2661 6d70 3b65 6467 652c 204d 4153 4b20 &edge, MASK │ │ │ │ +0001dcb0: 2661 6d70 3b6d 6173 6b29 2063 6f6e 7374 &mask) const │ │ │ │ +0001dcc0: 3c2f 6469 763e 3c64 6976 2063 6c61 7373
Defi │ │ │ │ +0001dce0: 6e69 7469 6f6e 3c2f 623e 203c 6120 6872 nition s │ │ │ │ +0001dd10: 6368 656d 652e 683a 3331 373c 2f61 3e3c cheme.h:317< │ │ │ │ +0001dd20: 2f64 6976 3e3c 2f64 6976 3e0a 3c64 6976 /div>
.
voi │ │ │ │ +0001de20: 6420 436f 6d70 7574 6545 6467 6556 6572 d ComputeEdgeVer │ │ │ │ +0001de30: 7465 784d 6173 6b28 4544 4745 2063 6f6e texMask(EDGE con │ │ │ │ +0001de40: 7374 2026 616d 703b 6564 6765 4e65 6967 st &edgeNeig │ │ │ │ +0001de50: 6862 6f72 686f 6f64 2c20 4d41 534b 2026 hborhood, MASK & │ │ │ │ +0001de60: 616d 703b 6564 6765 5665 7274 6578 4d61 amp;edgeVertexMa │ │ │ │ +0001de70: 736b 2c20 4372 6561 7365 3a3a 5275 6c65 sk, Crease::Rule │ │ │ │ +0001de80: 2070 6172 656e 7452 756c 653d 4372 6561 parentRule=Crea │ │ │ │ +0001de90: 7365 3a3a 5255 4c45 5f55 4e4b 4e4f 574e se::RULE_UNKNOWN │ │ │ │ +0001dea0: 2c20 4372 6561 7365 3a3a 5275 6c65 2063 , Crease::Rule c │ │ │ │ +0001deb0: 6869 6c64 5275 6c65 3d43 7265 6173 653a hildRule=Crease: │ │ │ │ +0001dec0: 3a52 554c 455f 554e 4b4e 4f57 4e29 2063 :RULE_UNKNOWN) c │ │ │ │ +0001ded0: 6f6e 7374 3c2f 6469 763e 3c64 6976 2063 onst
│ │ │ │ +0001dfc0: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
Definitio │ │ │ │ +0001e0d0: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n scheme │ │ │ │ +0001e100: 2e68 3a37 303c 2f61 3e3c 2f64 6976 3e3c .h:70
< │ │ │ │ +0001e110: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
< │ │ │ │ +0001e170: 6120 6872 6566 3d22 6130 3133 3431 2e68 a href="a01341.h │ │ │ │ +0001e180: 746d 6c23 6137 3336 6331 3039 3434 6362 tml#a736c10944cb │ │ │ │ +0001e190: 3932 3162 3333 3466 6264 3862 3831 3836 921b334fbd8b8186 │ │ │ │ +0001e1a0: 3664 3539 6622 3e4f 7065 6e53 7562 6469 6d59f">OpenSubdi │ │ │ │ +0001e1b0: 763a 3a4f 5045 4e53 5542 4449 565f 5645 v::OPENSUBDIV_VE │ │ │ │ +0001e1c0: 5253 494f 4e3a 3a53 6463 3a3a 5363 6865 RSION::Sdc::Sche │ │ │ │ +0001e1d0: 6d65 3a3a 6173 7369 676e 536d 6f6f 7468 me::assignSmooth │ │ │ │ +0001e1e0: 4c69 6d69 744d 6173 6b3c 2f61 3e3c 2f64 LimitMask
void assi │ │ │ │ +0001e210: 676e 536d 6f6f 7468 4c69 6d69 744d 6173 gnSmoothLimitMas │ │ │ │ +0001e220: 6b28 5645 5254 4558 2063 6f6e 7374 2026 k(VERTEX const & │ │ │ │ +0001e230: 616d 703b 7665 7274 6578 2c20 4d41 534b amp;vertex, MASK │ │ │ │ +0001e240: 2026 616d 703b 706f 7329 2063 6f6e 7374 &pos) const │ │ │ │ +0001e250: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.static int GetL │ │ │ │ +0001e360: 6f63 616c 4e65 6967 6862 6f72 686f 6f64 ocalNeighborhood │ │ │ │ +0001e370: 5369 7a65 2829 3c2f 6469 763e 3c2f 6469 Size()
.
OpenSubdiv:: │ │ │ │ +0001e420: 4f50 454e 5355 4244 4956 5f56 4552 5349 OPENSUBDIV_VERSI │ │ │ │ +0001e430: 4f4e 3a3a 5364 633a 3a53 6368 656d 653a ON::Sdc::Scheme: │ │ │ │ +0001e440: 3a61 7373 6967 6e43 6f72 6e65 724d 6173 :assignCornerMas │ │ │ │ +0001e450: 6b46 6f72 5665 7274 6578 3c2f 613e 3c2f kForVertex
void ass │ │ │ │ +0001e480: 6967 6e43 6f72 6e65 724d 6173 6b46 6f72 ignCornerMaskFor │ │ │ │ +0001e490: 5665 7274 6578 2856 4552 5445 5820 636f Vertex(VERTEX co │ │ │ │ +0001e4a0: 6e73 7420 2661 6d70 3b65 6467 652c 204d nst &edge, M │ │ │ │ +0001e4b0: 4153 4b20 2661 6d70 3b6d 6173 6b29 2063 ASK &mask) c │ │ │ │ +0001e4c0: 6f6e 7374 3c2f 6469 763e 3c64 6976 2063 onst
│ │ │ │ +0001e4e0: 4465 6669 6e69 7469 6f6e 3c2f 623e 203c Definition < │ │ │ │ +0001e4f0: 6120 6872 6566 3d22 6130 3037 3730 5f73 a href="a00770_s │ │ │ │ +0001e500: 6f75 7263 652e 6874 6d6c 236c 3030 3333 ource.html#l0033 │ │ │ │ +0001e510: 3122 3e73 6368 656d 652e 683a 3333 313c 1">scheme.h:331< │ │ │ │ +0001e520: 2f61 3e3c 2f64 6976 3e3c 2f64 6976 3e0a /a>
. │ │ │ │ +0001e530: 3c64 6976 2063 6c61 7373 3d22 7474 6322
void assignCrea │ │ │ │ +0001e630: 7365 4c69 6d69 744d 6173 6b28 5645 5254 seLimitMask(VERT │ │ │ │ +0001e640: 4558 2063 6f6e 7374 2026 616d 703b 7665 EX const &ve │ │ │ │ +0001e650: 7274 6578 2c20 4d41 534b 2026 616d 703b rtex, MASK & │ │ │ │ +0001e660: 706f 732c 2069 6e74 2063 6f6e 7374 2063 pos, int const c │ │ │ │ +0001e670: 7265 6173 6545 6e64 735b 325d 2920 636f reaseEnds[2]) co │ │ │ │ +0001e680: 6e73 743c 2f64 6976 3e3c 2f64 6976 3e0a nst
. │ │ │ │ +0001e690: 3c64 6976 2063 6c61 7373 3d22 7474 6322
void assign │ │ │ │ +0001e790: 536d 6f6f 7468 4d61 736b 466f 7256 6572 SmoothMaskForVer │ │ │ │ +0001e7a0: 7465 7828 5645 5254 4558 2063 6f6e 7374 tex(VERTEX const │ │ │ │ +0001e7b0: 2026 616d 703b 6564 6765 2c20 4d41 534b &edge, MASK │ │ │ │ +0001e7c0: 2026 616d 703b 6d61 736b 2920 636f 6e73 &mask) cons │ │ │ │ +0001e7d0: 743c 2f64 6976 3e3c 2f64 6976 3e0a 3c64 t
.static int GetR │ │ │ │ +0001e8e0: 6567 756c 6172 5665 7274 6578 5661 6c65 egularVertexVale │ │ │ │ +0001e8f0: 6e63 6528 293c 2f64 6976 3e3c 2f64 6976 nce()
.
OpenSubdiv::O │ │ │ │ +0001e9a0: 5045 4e53 5542 4449 565f 5645 5253 494f PENSUBDIV_VERSIO │ │ │ │ +0001e9b0: 4e3a 3a53 6463 3a3a 5363 6865 6d65 3a3a N::Sdc::Scheme:: │ │ │ │ +0001e9c0: 4765 744f 7074 696f 6e73 3c2f 613e 3c2f GetOptions
Options │ │ │ │ +0001e9f0: 4765 744f 7074 696f 6e73 2829 2063 6f6e GetOptions() con │ │ │ │ +0001ea00: 7374 3c2f 6469 763e 3c64 6976 2063 6c61 st
De │ │ │ │ +0001ea20: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:74 │ │ │ │ +0001ea60: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.
Op │ │ │ │ +0001eb00: 656e 5375 6264 6976 3a3a 4f50 454e 5355 enSubdiv::OPENSU │ │ │ │ +0001eb10: 4244 4956 5f56 4552 5349 4f4e 3a3a 5364 BDIV_VERSION::Sd │ │ │ │ +0001eb20: 633a 3a53 6368 656d 653a 3a61 7373 6967 c::Scheme::assig │ │ │ │ +0001eb30: 6e53 6d6f 6f74 684c 696d 6974 5461 6e67 nSmoothLimitTang │ │ │ │ +0001eb40: 656e 744d 6173 6b73 3c2f 613e 3c2f 6469 entMasks
void assig │ │ │ │ +0001eb70: 6e53 6d6f 6f74 684c 696d 6974 5461 6e67 nSmoothLimitTang │ │ │ │ +0001eb80: 656e 744d 6173 6b73 2856 4552 5445 5820 entMasks(VERTEX │ │ │ │ +0001eb90: 636f 6e73 7420 2661 6d70 3b76 6572 7465 const &verte │ │ │ │ +0001eba0: 782c 204d 4153 4b20 2661 6d70 3b74 616e x, MASK &tan │ │ │ │ +0001ebb0: 312c 204d 4153 4b20 2661 6d70 3b74 616e 1, MASK &tan │ │ │ │ +0001ebc0: 3229 2063 6f6e 7374 3c2f 6469 763e 3c2f 2) const
.
OpenSubdiv │ │ │ │ +0001ec70: 3a3a 4f50 454e 5355 4244 4956 5f56 4552 ::OPENSUBDIV_VER │ │ │ │ +0001ec80: 5349 4f4e 3a3a 5364 633a 3a53 6368 656d SION::Sdc::Schem │ │ │ │ +0001ec90: 653a 3a61 7373 6967 6e43 6f72 6e65 724c e::assignCornerL │ │ │ │ +0001eca0: 696d 6974 4d61 736b 3c2f 613e 3c2f 6469 imitMask
void assig │ │ │ │ +0001ecd0: 6e43 6f72 6e65 724c 696d 6974 4d61 736b nCornerLimitMask │ │ │ │ +0001ece0: 2856 4552 5445 5820 636f 6e73 7420 2661 (VERTEX const &a │ │ │ │ +0001ecf0: 6d70 3b76 6572 7465 782c 204d 4153 4b20 mp;vertex, MASK │ │ │ │ +0001ed00: 2661 6d70 3b70 6f73 2920 636f 6e73 743c &pos) const< │ │ │ │ +0001ed10: 2f64 6976 3e3c 2f64 6976 3e0a 3c64 6976 /div>
.
Sc │ │ │ │ +0001ee00: 6865 6d65 284f 7074 696f 6e73 2063 6f6e heme(Options con │ │ │ │ +0001ee10: 7374 2026 616d 703b 6f70 7469 6f6e 7329 st &options) │ │ │ │ +0001ee20: 3c2f 6469 763e 3c64 6976 2063 6c61 7373
Defi │ │ │ │ +0001ee40: 6e69 7469 6f6e 3c2f 623e 203c 6120 6872 nition s │ │ │ │ +0001ee70: 6368 656d 652e 683a 3732 3c2f 613e 3c2f cheme.h:72
.
│ │ │ │ +0001f090: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
void a │ │ │ │ +0001f190: 7373 6967 6e43 6f72 6e65 724c 696d 6974 ssignCornerLimit │ │ │ │ +0001f1a0: 5461 6e67 656e 744d 6173 6b73 2856 4552 TangentMasks(VER │ │ │ │ +0001f1b0: 5445 5820 636f 6e73 7420 2661 6d70 3b76 TEX const &v │ │ │ │ +0001f1c0: 6572 7465 782c 204d 4153 4b20 2661 6d70 ertex, MASK & │ │ │ │ +0001f1d0: 3b74 616e 312c 204d 4153 4b20 2661 6d70 ;tan1, MASK & │ │ │ │ +0001f1e0: 3b74 616e 3229 2063 6f6e 7374 3c2f 6469 ;tan2) const
.
v │ │ │ │ +0001f2e0: 6f69 6420 5365 744f 7074 696f 6e73 2863 oid SetOptions(c │ │ │ │ +0001f2f0: 6f6e 7374 204f 7074 696f 6e73 2026 616d onst Options &am │ │ │ │ +0001f300: 703b 6e65 774f 7074 696f 6e73 293c 2f64 p;newOptions)
Definit │ │ │ │ +0001f330: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion sche │ │ │ │ +0001f360: 6d65 2e68 3a37 353c 2f61 3e3c 2f64 6976 me.h:75
.
< │ │ │ │ +0001f3b0: 6120 6872 6566 3d22 6130 3133 3435 2e68 a href="a01345.h │ │ │ │ +0001f3c0: 746d 6c22 3e4f 7065 6e53 7562 6469 763a tml">OpenSubdiv: │ │ │ │ +0001f3d0: 3a4f 5045 4e53 5542 4449 565f 5645 5253 :OPENSUBDIV_VERS │ │ │ │ +0001f3e0: 494f 4e3a 3a53 6463 3a3a 5363 6865 6d65 ION::Sdc::Scheme │ │ │ │ +0001f3f0: 3a3a 4c6f 6361 6c4d 6173 6b3c 2f61 3e3c ::LocalMask< │ │ │ │ +0001f400: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
Defin │ │ │ │ +0001f420: 6974 696f 6e3c 2f62 3e20 3c61 2068 7265 ition sc │ │ │ │ +0001f450: 6865 6d65 2e68 3a32 3039 3c2f 613e 3c2f heme.h:209
.
│ │ │ │ +0001f4b0: 3c64 6976 2063 6c61 7373 3d22 7474 6e61 │ │ │ │ +0001f5d0: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
│ │ │ │ +0001f6c0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
bool AreFace │ │ │ │ +0001f6e0: 5765 6967 6874 7346 6f72 4661 6365 4365 WeightsForFaceCe │ │ │ │ +0001f6f0: 6e74 6572 7328 2920 636f 6e73 743c 2f64 nters() const
Definit │ │ │ │ +0001f720: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion sche │ │ │ │ +0001f750: 6d65 2e68 3a32 3339 3c2f 613e 3c2f 6469 me.h:239
.void SetNumEdge │ │ │ │ +0001f870: 5765 6967 6874 7328 696e 7420 636f 756e Weights(int coun │ │ │ │ +0001f880: 7429 3c2f 6469 763e 3c64 6976 2063 6c61 t)
De │ │ │ │ +0001f8a0: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:228
.
W │ │ │ │ +0001f9e0: 6569 6768 7420 636f 6e73 7420 2661 6d70 eight const & │ │ │ │ +0001f9f0: 3b20 4564 6765 5765 6967 6874 2869 6e74 ; EdgeWeight(int │ │ │ │ +0001fa00: 2069 6e64 6578 2920 636f 6e73 743c 2f64 index) const
Definit │ │ │ │ +0001fa30: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion sche │ │ │ │ +0001fa60: 6d65 2e68 3a32 3332 3c2f 613e 3c2f 6469 me.h:232
.
Weight │ │ │ │ +0001fb70: 2026 616d 703b 2045 6467 6557 6569 6768 & EdgeWeigh │ │ │ │ +0001fb80: 7428 696e 7420 696e 6465 7829 3c2f 6469 t(int index)
Definiti │ │ │ │ +0001fbb0: 6f6e 3c2f 623e 203c 6120 6872 6566 3d22 on schem │ │ │ │ +0001fbe0: 652e 683a 3233 363c 2f61 3e3c 2f64 6976 e.h:236
.
OpenSub │ │ │ │ +0001fc90: 6469 763a 3a4f 5045 4e53 5542 4449 565f div::OPENSUBDIV_ │ │ │ │ +0001fca0: 5645 5253 494f 4e3a 3a53 6463 3a3a 5363 VERSION::Sdc::Sc │ │ │ │ +0001fcb0: 6865 6d65 3a3a 4c6f 6361 6c4d 6173 6b3a heme::LocalMask: │ │ │ │ +0001fcc0: 3a43 6f6d 6269 6e65 5665 7274 6578 5665 :CombineVertexVe │ │ │ │ +0001fcd0: 7274 6578 4d61 736b 733c 2f61 3e3c 2f64 rtexMasks
void Comb │ │ │ │ +0001fd00: 696e 6556 6572 7465 7856 6572 7465 784d ineVertexVertexM │ │ │ │ +0001fd10: 6173 6b73 2857 6569 6768 7420 7468 6973 asks(Weight this │ │ │ │ +0001fd20: 436f 6566 662c 2057 6569 6768 7420 6473 Coeff, Weight ds │ │ │ │ +0001fd30: 7443 6f65 6666 2c20 5553 4552 5f4d 4153 tCoeff, USER_MAS │ │ │ │ +0001fd40: 4b20 2661 6d70 3b64 7374 2920 636f 6e73 K &dst) cons │ │ │ │ +0001fd50: 743c 2f64 6976 3e3c 6469 7620 636c 6173 t
Def │ │ │ │ +0001fd70: 696e 6974 696f 6e3c 2f62 3e20 3c61 2068 inition │ │ │ │ +0001fda0: 7363 6865 6d65 2e68 3a32 3439 3c2f 613e scheme.h:249 │ │ │ │ +0001fdb0: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
..
void S │ │ │ │ +00020040: 6574 4e75 6d46 6163 6557 6569 6768 7473 etNumFaceWeights │ │ │ │ +00020050: 2869 6e74 2063 6f75 6e74 293c 2f64 6976 (int count)
Definitio │ │ │ │ +00020080: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n scheme │ │ │ │ +000200b0: 2e68 3a32 3239 3c2f 613e 3c2f 6469 763e .h:229
│ │ │ │ +000200c0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +00020120: 3c61 2068 7265 663d 2261 3031 3334 352e OpenSubd │ │ │ │ +00020160: 6976 3a3a 4f50 454e 5355 4244 4956 5f56 iv::OPENSUBDIV_V │ │ │ │ +00020170: 4552 5349 4f4e 3a3a 5364 633a 3a53 6368 ERSION::Sdc::Sch │ │ │ │ +00020180: 656d 653a 3a4c 6f63 616c 4d61 736b 3a3a eme::LocalMask:: │ │ │ │ +00020190: 4661 6365 5765 6967 6874 3c2f 613e 3c2f FaceWeight
Weight c │ │ │ │ +000201c0: 6f6e 7374 2026 616d 703b 2046 6163 6557 onst & FaceW │ │ │ │ +000201d0: 6569 6768 7428 696e 7420 696e 6465 7829 eight(int index) │ │ │ │ +000201e0: 2063 6f6e 7374 3c2f 6469 763e 3c64 6976 const
< │ │ │ │ +00020200: 623e 4465 6669 6e69 7469 6f6e 3c2f 623e b>Definition │ │ │ │ +00020210: 203c 6120 6872 6566 3d22 6130 3037 3730 scheme.h:23 │ │ │ │ +00020240: 333c 2f61 3e3c 2f64 6976 3e3c 2f64 6976 3
.
int Ge │ │ │ │ +00020350: 744e 756d 4564 6765 5765 6967 6874 7328 tNumEdgeWeights( │ │ │ │ +00020360: 2920 636f 6e73 743c 2f64 6976 3e3c 6469 ) const
│ │ │ │ +00020380: 3c62 3e44 6566 696e 6974 696f 6e3c 2f62 Definition scheme.h:2 │ │ │ │ +000203c0: 3234 3c2f 613e 3c2f 6469 763e 3c2f 6469 24
.
OpenSubdiv:: │ │ │ │ +00020470: 4f50 454e 5355 4244 4956 5f56 4552 5349 OPENSUBDIV_VERSI │ │ │ │ +00020480: 4f4e 3a3a 5364 633a 3a53 6368 656d 653a ON::Sdc::Scheme: │ │ │ │ +00020490: 3a4c 6f63 616c 4d61 736b 3a3a 5665 7274 :LocalMask::Vert │ │ │ │ +000204a0: 6578 5765 6967 6874 3c2f 613e 3c2f 6469 exWeight
Weight &am │ │ │ │ +000204d0: 703b 2056 6572 7465 7857 6569 6768 7428 p; VertexWeight( │ │ │ │ +000204e0: 696e 7420 696e 6465 7829 3c2f 6469 763e int index)
│ │ │ │ +000204f0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ +00020510: 3c2f 623e 203c 6120 6872 6566 3d22 6130 scheme. │ │ │ │ +00020540: 683a 3233 353c 2f61 3e3c 2f64 6976 3e3c h:235
< │ │ │ │ +00020550: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
< │ │ │ │ +000205b0: 6120 6872 6566 3d22 6130 3133 3435 2e68 a href="a01345.h │ │ │ │ +000205c0: 746d 6c23 6139 3366 3537 6535 3333 3733 tml#a93f57e53373 │ │ │ │ +000205d0: 3931 6332 3064 3436 6465 6664 6233 6161 91c20d46defdb3aa │ │ │ │ +000205e0: 3263 3166 6522 3e4f 7065 6e53 7562 6469 2c1fe">OpenSubdi │ │ │ │ +000205f0: 763a 3a4f 5045 4e53 5542 4449 565f 5645 v::OPENSUBDIV_VE │ │ │ │ +00020600: 5253 494f 4e3a 3a53 6463 3a3a 5363 6865 RSION::Sdc::Sche │ │ │ │ +00020610: 6d65 3a3a 4c6f 6361 6c4d 6173 6b3a 3a47 me::LocalMask::G │ │ │ │ +00020620: 6574 4e75 6d46 6163 6557 6569 6768 7473 etNumFaceWeights │ │ │ │ +00020630: 3c2f 613e 3c2f 6469 763e 3c64 6976 2063
in │ │ │ │ +00020650: 7420 4765 744e 756d 4661 6365 5765 6967 t GetNumFaceWeig │ │ │ │ +00020660: 6874 7328 2920 636f 6e73 743c 2f64 6976 hts() const
Definitio │ │ │ │ +00020690: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n scheme │ │ │ │ +000206c0: 2e68 3a32 3235 3c2f 613e 3c2f 6469 763e .h:225
│ │ │ │ +000206d0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
void S │ │ │ │ +000207e0: 6574 4661 6365 5765 6967 6874 7346 6f72 etFaceWeightsFor │ │ │ │ +000207f0: 4661 6365 4365 6e74 6572 7328 626f 6f6c FaceCenters(bool │ │ │ │ +00020800: 206f 6e29 3c2f 6469 763e 3c64 6976 2063 on)
│ │ │ │ +00020820: 4465 6669 6e69 7469 6f6e 3c2f 623e 203c Definition < │ │ │ │ +00020830: 6120 6872 6566 3d22 6130 3037 3730 5f73 a href="a00770_s │ │ │ │ +00020840: 6f75 7263 652e 6874 6d6c 236c 3030 3234 ource.html#l0024 │ │ │ │ +00020850: 3022 3e73 6368 656d 652e 683a 3234 303c 0">scheme.h:240< │ │ │ │ +00020860: 2f61 3e3c 2f64 6976 3e3c 2f64 6976 3e0a /a>
. │ │ │ │ +00020870: 3c64 6976 2063 6c61 7373 3d22 7474 6322
void S │ │ │ │ +00020970: 6574 4e75 6d56 6572 7465 7857 6569 6768 etNumVertexWeigh │ │ │ │ +00020980: 7473 2869 6e74 2063 6f75 6e74 293c 2f64 ts(int count)
Definit │ │ │ │ +000209b0: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion sche │ │ │ │ +000209e0: 6d65 2e68 3a32 3237 3c2f 613e 3c2f 6469 me.h:227
.
OpenSu │ │ │ │ +00020a90: 6264 6976 3a3a 4f50 454e 5355 4244 4956 bdiv::OPENSUBDIV │ │ │ │ +00020aa0: 5f56 4552 5349 4f4e 3a3a 5364 633a 3a53 _VERSION::Sdc::S │ │ │ │ +00020ab0: 6368 656d 653a 3a4c 6f63 616c 4d61 736b cheme::LocalMask │ │ │ │ +00020ac0: 3a3a 4c6f 6361 6c4d 6173 6b3c 2f61 3e3c ::LocalMask< │ │ │ │ +00020ad0: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
LocalMa │ │ │ │ +00020af0: 736b 2857 6569 6768 7420 2a76 2c20 5765 sk(Weight *v, We │ │ │ │ +00020b00: 6967 6874 202a 652c 2057 6569 6768 7420 ight *e, Weight │ │ │ │ +00020b10: 2a66 293c 2f64 6976 3e3c 6469 7620 636c *f)
D │ │ │ │ +00020b30: 6566 696e 6974 696f 6e3c 2f62 3e20 3c61 efinition scheme.h:215
.< │ │ │ │ +00020b80: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ +00020b90: 6964 3d22 6161 3031 3334 355f 6874 6d6c id="aa01345_html │ │ │ │ +00020ba0: 5f61 6563 3563 3261 6266 6466 6264 6534 _aec5c2abfdfbde4 │ │ │ │ +00020bb0: 6464 3933 3463 3036 3136 3235 3939 3437 dd934c0616259947 │ │ │ │ +00020bc0: 3931 223e 3c64 6976 2063 6c61 7373 3d22 91">Weight const & │ │ │ │ +00020c80: 616d 703b 2056 6572 7465 7857 6569 6768 amp; VertexWeigh │ │ │ │ +00020c90: 7428 696e 7420 696e 6465 7829 2063 6f6e t(int index) con │ │ │ │ +00020ca0: 7374 3c2f 6469 763e 3c64 6976 2063 6c61 st
De │ │ │ │ +00020cc0: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:231
.
W │ │ │ │ +00020e00: 6569 6768 7420 2661 6d70 3b20 4661 6365 eight & Face │ │ │ │ +00020e10: 5765 6967 6874 2869 6e74 2069 6e64 6578 Weight(int index │ │ │ │ +00020e20: 293c 2f64 6976 3e3c 6469 7620 636c 6173 )
Def │ │ │ │ +00020e40: 696e 6974 696f 6e3c 2f62 3e20 3c61 2068 inition │ │ │ │ +00020e70: 7363 6865 6d65 2e68 3a32 3337 3c2f 613e scheme.h:237 │ │ │ │ +00020e80: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.
~L │ │ │ │ +00020f80: 6f63 616c 4d61 736b 2829 3c2f 6469 763e ocalMask()
│ │ │ │ +00020f90: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ +00020fb0: 3c2f 623e 203c 6120 6872 6566 3d22 6130 scheme. │ │ │ │ +00020fe0: 683a 3231 363c 2f61 3e3c 2f64 6976 3e3c h:216
< │ │ │ │ +00020ff0: 2f64 6976 3e0a 3c2f 6469 763e 3c21 2d2d /div>.
.
. │ │ │ │ +00021040: 3c21 2d2d 2073 7461 7274 2066 6f6f 7465 .... │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -loopScheme.h │ │ │ │ │ +scheme.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -23,671 +23,847 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_SDC_LOOP_SCHEME_H │ │ │ │ │ -25#define OPENSUBDIV3_SDC_LOOP_SCHEME_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_SDC_SCHEME_H │ │ │ │ │ +25#define OPENSUBDIV3_SDC_SCHEME_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ -29#include "../sdc/scheme.h" │ │ │ │ │ -30 │ │ │ │ │ -31#include │ │ │ │ │ -32#include │ │ │ │ │ -33 │ │ │ │ │ -34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -35namespace OPENSUBDIV_VERSION { │ │ │ │ │ -36namespace Sdc { │ │ │ │ │ -37 │ │ │ │ │ -38 │ │ │ │ │ -39// │ │ │ │ │ -40// Specializations for Sdc::Scheme: │ │ │ │ │ -41// │ │ │ │ │ -42// │ │ │ │ │ -43 │ │ │ │ │ -44// │ │ │ │ │ -45// Loop traits: │ │ │ │ │ -46// │ │ │ │ │ -47template <> │ │ │ │ │ -_4_8inline _S_p_l_i_t _S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_G_e_t_T_o_p_o_l_o_g_i_c_a_l_S_p_l_i_t_T_y_p_e() { return │ │ │ │ │ -_S_P_L_I_T___T_O___T_R_I_S; } │ │ │ │ │ -49 │ │ │ │ │ -50template <> │ │ │ │ │ -_5_1inline int _S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_G_e_t_R_e_g_u_l_a_r_F_a_c_e_S_i_z_e() { return 3; } │ │ │ │ │ -52 │ │ │ │ │ -53template <> │ │ │ │ │ -_5_4inline int _S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_G_e_t_R_e_g_u_l_a_r_V_e_r_t_e_x_V_a_l_e_n_c_e() { return 6; } │ │ │ │ │ -55 │ │ │ │ │ -56template <> │ │ │ │ │ -_5_7inline int _S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_G_e_t_L_o_c_a_l_N_e_i_g_h_b_o_r_h_o_o_d_S_i_z_e() { return 1; } │ │ │ │ │ -58 │ │ │ │ │ -59 │ │ │ │ │ -60// │ │ │ │ │ -61// Protected methods to assign the two types of masks for an edge-vertex -- │ │ │ │ │ -62// Crease and Smooth. │ │ │ │ │ -63// │ │ │ │ │ -64// The Crease case does not really need to be specialized, though it may be │ │ │ │ │ -65// preferable to define all explicitly here. │ │ │ │ │ -66// │ │ │ │ │ -67template <> │ │ │ │ │ -68template │ │ │ │ │ -69inline void │ │ │ │ │ -_7_0_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e(EDGE const&, MASK& mask) const │ │ │ │ │ -71{ │ │ │ │ │ -72 mask.SetNumVertexWeights(2); │ │ │ │ │ -73 mask.SetNumEdgeWeights(0); │ │ │ │ │ -74 mask.SetNumFaceWeights(0); │ │ │ │ │ -75 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +29#include "../sdc/types.h" │ │ │ │ │ +30#include "../sdc/options.h" │ │ │ │ │ +31#include "../sdc/crease.h" │ │ │ │ │ +32 │ │ │ │ │ +33#include │ │ │ │ │ +34#include │ │ │ │ │ +35#include │ │ │ │ │ +36 │ │ │ │ │ +37namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +38namespace OPENSUBDIV_VERSION { │ │ │ │ │ +39 │ │ │ │ │ +40namespace Sdc { │ │ │ │ │ +41 │ │ │ │ │ +65template │ │ │ │ │ +_6_6class _S_c_h_e_m_e { │ │ │ │ │ +67 │ │ │ │ │ +68public: │ │ │ │ │ +69 │ │ │ │ │ +_7_0 _S_c_h_e_m_e() : _options() { } │ │ │ │ │ +71 │ │ │ │ │ +_7_2 _S_c_h_e_m_e(_O_p_t_i_o_n_s const& options) : _options(options) { } │ │ │ │ │ +73 │ │ │ │ │ +_7_4 _O_p_t_i_o_n_s _G_e_t_O_p_t_i_o_n_s() const { return _options; } │ │ │ │ │ +_7_5 void _S_e_t_O_p_t_i_o_n_s(const _O_p_t_i_o_n_s& newOptions) { _options = newOptions; } │ │ │ │ │ 76 │ │ │ │ │ -77 mask.VertexWeight(0) = 0.5f; │ │ │ │ │ -78 mask.VertexWeight(1) = 0.5f; │ │ │ │ │ -79} │ │ │ │ │ -80 │ │ │ │ │ -81template <> │ │ │ │ │ -82template │ │ │ │ │ -83inline void │ │ │ │ │ -_8_4_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_E_d_g_e(EDGE const& edge, MASK& mask) │ │ │ │ │ -const │ │ │ │ │ -85{ │ │ │ │ │ -86 int faceCount = edge.GetNumFaces(); │ │ │ │ │ -87 │ │ │ │ │ -88 mask.SetNumVertexWeights(2); │ │ │ │ │ -89 mask.SetNumEdgeWeights(0); │ │ │ │ │ -90 mask.SetNumFaceWeights(faceCount); │ │ │ │ │ -91 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -92 │ │ │ │ │ -93 // │ │ │ │ │ -94 // This is where we run into the issue of "face weights" -- we want to │ │ │ │ │ -weight the │ │ │ │ │ -95 // face-centers for Catmark, but face-centers are not generated for Loop. So │ │ │ │ │ -do │ │ │ │ │ -96 // we make assumptions on how the mask is used, assign some property to the │ │ │ │ │ -mask │ │ │ │ │ -97 // to indicate how they were assigned, or take input from the mask itself? │ │ │ │ │ -98 // │ │ │ │ │ -99 // Regardless, we have two choices: │ │ │ │ │ -100 // - face-weights are for the vertices opposite the edge (as in Hbr): │ │ │ │ │ -101 // vertex weights = 0.375f; │ │ │ │ │ -102 // face weights = 0.125f; │ │ │ │ │ -103 // │ │ │ │ │ -104 // - face-weights are for the face centers: │ │ │ │ │ -105 // vertex weights = 0.125f; │ │ │ │ │ -106 // face weights = 0.375f; │ │ │ │ │ -107 // │ │ │ │ │ -108 // Coincidentally the coefficients are the same but reversed. │ │ │ │ │ -109 // │ │ │ │ │ -110 typedef typename MASK::Weight Weight; │ │ │ │ │ -111 │ │ │ │ │ -112 Weight vWeight = mask.AreFaceWeightsForFaceCenters() ? 0.125f : 0.375f; │ │ │ │ │ -113 Weight fWeight = mask.AreFaceWeightsForFaceCenters() ? 0.375f : 0.125f; │ │ │ │ │ -114 │ │ │ │ │ -115 mask.VertexWeight(0) = vWeight; │ │ │ │ │ -116 mask.VertexWeight(1) = vWeight; │ │ │ │ │ -117 │ │ │ │ │ -118 if (faceCount == 2) { │ │ │ │ │ -119 mask.FaceWeight(0) = fWeight; │ │ │ │ │ -120 mask.FaceWeight(1) = fWeight; │ │ │ │ │ -121 } else { │ │ │ │ │ -122 // The non-manifold case is not clearly defined -- we adjust the above │ │ │ │ │ -123 // face-weight to preserve the ratio of edge-center and face-centers: │ │ │ │ │ -124 fWeight *= 2.0f / (Weight) faceCount; │ │ │ │ │ -125 for (int i = 0; i < faceCount; ++i) { │ │ │ │ │ -126 mask.FaceWeight(i) = fWeight; │ │ │ │ │ -127 } │ │ │ │ │ -128 } │ │ │ │ │ -129} │ │ │ │ │ -130 │ │ │ │ │ -131 │ │ │ │ │ -132// │ │ │ │ │ -133// Protected methods to assign the three types of masks for a vertex-vertex │ │ │ │ │ --- │ │ │ │ │ -134// Corner, Crease and Smooth (Dart is the same as Smooth). │ │ │ │ │ -135// │ │ │ │ │ -136// Corner and Crease do not really need to be specialized, though it may be │ │ │ │ │ -137// preferable to define all explicitly here. │ │ │ │ │ -138// │ │ │ │ │ -139template <> │ │ │ │ │ -140template │ │ │ │ │ -141inline void │ │ │ │ │ -_1_4_2_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const&, MASK& mask) │ │ │ │ │ -const │ │ │ │ │ -143{ │ │ │ │ │ -144 mask.SetNumVertexWeights(1); │ │ │ │ │ -145 mask.SetNumEdgeWeights(0); │ │ │ │ │ -146 mask.SetNumFaceWeights(0); │ │ │ │ │ -147 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -148 │ │ │ │ │ -149 mask.VertexWeight(0) = 1.0f; │ │ │ │ │ -150} │ │ │ │ │ -151 │ │ │ │ │ -152template <> │ │ │ │ │ -153template │ │ │ │ │ -154inline void │ │ │ │ │ -_1_5_5_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& vertex, MASK& │ │ │ │ │ -mask, │ │ │ │ │ -156 int const creaseEnds[2]) const { │ │ │ │ │ -157 typedef typename MASK::Weight Weight; │ │ │ │ │ -158 │ │ │ │ │ -159 int valence = vertex.GetNumEdges(); │ │ │ │ │ -160 │ │ │ │ │ -161 mask.SetNumVertexWeights(1); │ │ │ │ │ -162 mask.SetNumEdgeWeights(valence); │ │ │ │ │ -163 mask.SetNumFaceWeights(0); │ │ │ │ │ -164 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -165 │ │ │ │ │ -166 Weight vWeight = 0.75f; │ │ │ │ │ -167 Weight eWeight = 0.125f; │ │ │ │ │ -168 │ │ │ │ │ -169 mask.VertexWeight(0) = vWeight; │ │ │ │ │ -170 for (int i = 0; i < valence; ++i) { │ │ │ │ │ -171 mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ -172 } │ │ │ │ │ -173 mask.EdgeWeight(creaseEnds[0]) = eWeight; │ │ │ │ │ -174 mask.EdgeWeight(creaseEnds[1]) = eWeight; │ │ │ │ │ -175} │ │ │ │ │ -176 │ │ │ │ │ -177template <> │ │ │ │ │ -178template │ │ │ │ │ -179inline void │ │ │ │ │ -_1_8_0_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& vertex, MASK& │ │ │ │ │ -mask) const │ │ │ │ │ -181{ │ │ │ │ │ -182 typedef typename MASK::Weight Weight; │ │ │ │ │ -183 │ │ │ │ │ -184 int valence = vertex.GetNumFaces(); │ │ │ │ │ -185 │ │ │ │ │ -186 mask.SetNumVertexWeights(1); │ │ │ │ │ -187 mask.SetNumEdgeWeights(valence); │ │ │ │ │ -188 mask.SetNumFaceWeights(0); │ │ │ │ │ -189 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -190 │ │ │ │ │ -191 // Specialize for the regular case: 1/16 per edge-vert, 5/8 for the vert │ │ │ │ │ -itself: │ │ │ │ │ -192 Weight eWeight = (Weight) 0.0625f; │ │ │ │ │ -193 Weight vWeight = (Weight) 0.625f; │ │ │ │ │ +80 template │ │ │ │ │ +81 void _C_o_m_p_u_t_e_F_a_c_e_V_e_r_t_e_x_M_a_s_k(FACE const& faceNeighborhood, MASK& │ │ │ │ │ +faceVertexMask) const; │ │ │ │ │ +82 │ │ │ │ │ +98 template │ │ │ │ │ +99 void _C_o_m_p_u_t_e_E_d_g_e_V_e_r_t_e_x_M_a_s_k(EDGE const& edgeNeighborhood, MASK& │ │ │ │ │ +edgeVertexMask, │ │ │ │ │ +100 _C_r_e_a_s_e_:_:_R_u_l_e parentRule = _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N, │ │ │ │ │ +101 _C_r_e_a_s_e_:_:_R_u_l_e childRule = _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) const; │ │ │ │ │ +102 │ │ │ │ │ +112 template │ │ │ │ │ +113 void _C_o_m_p_u_t_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k(VERTEX const& vertexNeighborhood, MASK& │ │ │ │ │ +vertexVertexMask, │ │ │ │ │ +114 _C_r_e_a_s_e_:_:_R_u_l_e parentRule = _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N, │ │ │ │ │ +115 _C_r_e_a_s_e_:_:_R_u_l_e childRule = _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) const; │ │ │ │ │ +116 │ │ │ │ │ +141 template │ │ │ │ │ +142 void _C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k(VERTEX const& vertexNeighborhood, MASK& │ │ │ │ │ +positionMask, │ │ │ │ │ +143 _C_r_e_a_s_e_:_:_R_u_l_e vertexRule) const; │ │ │ │ │ +144 │ │ │ │ │ +145 template │ │ │ │ │ +146 void _C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k(VERTEX const& vertexNeighborhood, MASK& │ │ │ │ │ +positionMask, │ │ │ │ │ +147 MASK& tangent1Mask, MASK& tangent2Mask, │ │ │ │ │ +148 _C_r_e_a_s_e_:_:_R_u_l_e vertexRule) const; │ │ │ │ │ +149 │ │ │ │ │ +150 // │ │ │ │ │ +151 // Static methods defining traits/properties of the scheme: │ │ │ │ │ +152 // │ │ │ │ │ +_1_5_3 static _S_p_l_i_t _G_e_t_T_o_p_o_l_o_g_i_c_a_l_S_p_l_i_t_T_y_p_e(); │ │ │ │ │ +_1_5_4 static int _G_e_t_R_e_g_u_l_a_r_F_a_c_e_S_i_z_e(); │ │ │ │ │ +_1_5_5 static int _G_e_t_R_e_g_u_l_a_r_V_e_r_t_e_x_V_a_l_e_n_c_e(); │ │ │ │ │ +_1_5_6 static int _G_e_t_L_o_c_a_l_N_e_i_g_h_b_o_r_h_o_o_d_S_i_z_e(); │ │ │ │ │ +157 │ │ │ │ │ +158protected: │ │ │ │ │ +159 │ │ │ │ │ +160 // │ │ │ │ │ +161 // Supporting internal methods -- optionally implemented, depending on │ │ │ │ │ +specialization: │ │ │ │ │ +162 // │ │ │ │ │ +163 │ │ │ │ │ +164 // Subdivision/refinement masks -- two for edge-vertices and three for │ │ │ │ │ +vertex-vertices: │ │ │ │ │ +165 // │ │ │ │ │ +166 template │ │ │ │ │ +167 void _a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e(EDGE const& edge, MASK& mask) const; │ │ │ │ │ +168 template │ │ │ │ │ +_1_6_9 void _a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_E_d_g_e(EDGE const& edge, MASK& mask) const; │ │ │ │ │ +170 │ │ │ │ │ +171 template │ │ │ │ │ +172 void _a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& edge, MASK& mask) const; │ │ │ │ │ +173 template │ │ │ │ │ +_1_7_4 void _a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& edge, MASK& mask, int const │ │ │ │ │ +creaseEnds[2]) const; │ │ │ │ │ +175 template │ │ │ │ │ +_1_7_6 void _a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& edge, MASK& mask) const; │ │ │ │ │ +177 │ │ │ │ │ +178 // │ │ │ │ │ +179 // Limit masks for position and tangents at vertices -- three cases for │ │ │ │ │ +each: │ │ │ │ │ +180 // │ │ │ │ │ +181 template │ │ │ │ │ +_1_8_2 void _a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& pos) const; │ │ │ │ │ +183 template │ │ │ │ │ +_1_8_4 void _a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& pos, int const │ │ │ │ │ +creaseEnds[2]) const; │ │ │ │ │ +185 template │ │ │ │ │ +_1_8_6 void _a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& pos) const; │ │ │ │ │ +187 │ │ │ │ │ +188 template │ │ │ │ │ +_1_8_9 void _a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, MASK& tan1, MASK& │ │ │ │ │ +tan2) const; │ │ │ │ │ +190 template │ │ │ │ │ +_1_9_1 void _a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, MASK& tan1, MASK& │ │ │ │ │ +tan2, int const creaseEnds[2]) const; │ │ │ │ │ +192 template │ │ │ │ │ +_1_9_3 void _a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, MASK& tan1, MASK& │ │ │ │ │ +tan2) const; │ │ │ │ │ 194 │ │ │ │ │ -195 if (valence != 6) { │ │ │ │ │ -196 // From HbrLoopSubdivision::Subdivide(mesh, vertex): │ │ │ │ │ -197 // - could use some lookup tables here for common irregular valence (5, 7, │ │ │ │ │ -8) │ │ │ │ │ -198 // or all of these cosine calls will be adding up... │ │ │ │ │ +195private: │ │ │ │ │ +196 _O_p_t_i_o_n_s _options; │ │ │ │ │ +197 │ │ │ │ │ +198protected: │ │ │ │ │ 199 │ │ │ │ │ -200 double dValence = (double) valence; │ │ │ │ │ -201 double invValence = 1.0f / dValence; │ │ │ │ │ -202 double cosTheta = std::cos(M_PI * 2.0f * invValence); │ │ │ │ │ -203 │ │ │ │ │ -204 double beta = 0.25f * cosTheta + 0.375f; │ │ │ │ │ -205 │ │ │ │ │ -206 eWeight = (Weight) ((0.625f - (beta * beta)) * invValence); │ │ │ │ │ -207 vWeight = (Weight) (1.0f - (eWeight * dValence)); │ │ │ │ │ -208 } │ │ │ │ │ -209 │ │ │ │ │ -210 mask.VertexWeight(0) = vWeight; │ │ │ │ │ -211 for (int i = 0; i < valence; ++i) { │ │ │ │ │ -212 mask.EdgeWeight(i) = eWeight; │ │ │ │ │ -213 } │ │ │ │ │ -214} │ │ │ │ │ -215 │ │ │ │ │ -216 │ │ │ │ │ -217// │ │ │ │ │ -218// Limit masks for position: │ │ │ │ │ -219// │ │ │ │ │ -220template <> │ │ │ │ │ -221template │ │ │ │ │ -222inline void │ │ │ │ │ -_2_2_3_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_M_a_s_k(VERTEX const& /* vertex */, MASK& │ │ │ │ │ -posMask) const { │ │ │ │ │ -224 │ │ │ │ │ -225 posMask.SetNumVertexWeights(1); │ │ │ │ │ -226 posMask.SetNumEdgeWeights(0); │ │ │ │ │ -227 posMask.SetNumFaceWeights(0); │ │ │ │ │ -228 posMask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -229 │ │ │ │ │ -230 posMask.VertexWeight(0) = 1.0f; │ │ │ │ │ -231} │ │ │ │ │ -232 │ │ │ │ │ -233template <> │ │ │ │ │ -234template │ │ │ │ │ -235inline void │ │ │ │ │ -_2_3_6_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& │ │ │ │ │ -posMask, │ │ │ │ │ -237 int const creaseEnds[2]) const { │ │ │ │ │ +200 // │ │ │ │ │ +201 // Internal implementation support: │ │ │ │ │ +202 // │ │ │ │ │ +203 // We need a local "mask" class to be declared locally within the vertex- │ │ │ │ │ +vertex mask query │ │ │ │ │ +204 // to hold one of the two possible masks required and to combine the local │ │ │ │ │ +mask with the mask │ │ │ │ │ +205 // the caller provides. It has been parameterized by so that a │ │ │ │ │ +version compatible │ │ │ │ │ +206 // with the caller's mask class is created. │ │ │ │ │ +207 // │ │ │ │ │ +208 template │ │ │ │ │ +_2_0_9 class _L_o_c_a_l_M_a_s_k { │ │ │ │ │ +210 │ │ │ │ │ +211 public: │ │ │ │ │ +_2_1_2 typedef WEIGHT _W_e_i_g_h_t; │ │ │ │ │ +213 │ │ │ │ │ +214 public: │ │ │ │ │ +_2_1_5 _L_o_c_a_l_M_a_s_k(_W_e_i_g_h_t* v, _W_e_i_g_h_t* e, _W_e_i_g_h_t* f) : _vWeights(v), _eWeights(e), │ │ │ │ │ +_fWeights(f) { } │ │ │ │ │ +_2_1_6 _~_L_o_c_a_l_M_a_s_k() { } │ │ │ │ │ +217 │ │ │ │ │ +218 public: │ │ │ │ │ +219 │ │ │ │ │ +220 // │ │ │ │ │ +221 // Methods required for general mask assignments and queries: │ │ │ │ │ +222 // │ │ │ │ │ +_2_2_3 int _G_e_t_N_u_m_V_e_r_t_e_x_W_e_i_g_h_t_s() const { return _vCount; } │ │ │ │ │ +_2_2_4 int _G_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s() const { return _eCount; } │ │ │ │ │ +_2_2_5 int _G_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s() const { return _fCount; } │ │ │ │ │ +226 │ │ │ │ │ +_2_2_7 void _S_e_t_N_u_m_V_e_r_t_e_x_W_e_i_g_h_t_s(int count) { _vCount = count; } │ │ │ │ │ +_2_2_8 void _S_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s( int count) { _eCount = count; } │ │ │ │ │ +_2_2_9 void _S_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s( int count) { _fCount = count; } │ │ │ │ │ +230 │ │ │ │ │ +_2_3_1 _W_e_i_g_h_t const& _V_e_r_t_e_x_W_e_i_g_h_t(int index) const { return _vWeights[index]; } │ │ │ │ │ +_2_3_2 _W_e_i_g_h_t const& _E_d_g_e_W_e_i_g_h_t( int index) const { return _eWeights[index]; } │ │ │ │ │ +_2_3_3 _W_e_i_g_h_t const& _F_a_c_e_W_e_i_g_h_t( int index) const { return _fWeights[index]; } │ │ │ │ │ +234 │ │ │ │ │ +_2_3_5 _W_e_i_g_h_t& _V_e_r_t_e_x_W_e_i_g_h_t(int index) { return _vWeights[index]; } │ │ │ │ │ +_2_3_6 _W_e_i_g_h_t& _E_d_g_e_W_e_i_g_h_t( int index) { return _eWeights[index]; } │ │ │ │ │ +_2_3_7 _W_e_i_g_h_t& _F_a_c_e_W_e_i_g_h_t( int index) { return _fWeights[index]; } │ │ │ │ │ 238 │ │ │ │ │ -239 typedef typename MASK::Weight Weight; │ │ │ │ │ -240 │ │ │ │ │ -241 int valence = vertex.GetNumEdges(); │ │ │ │ │ -242 │ │ │ │ │ -243 posMask.SetNumVertexWeights(1); │ │ │ │ │ -244 posMask.SetNumEdgeWeights(valence); │ │ │ │ │ -245 posMask.SetNumFaceWeights(0); │ │ │ │ │ -246 posMask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -247 │ │ │ │ │ -248 // │ │ │ │ │ -249 // The refinement mask for a crease vertex is (1/8, 3/4, 1/8) and for a │ │ │ │ │ -crease │ │ │ │ │ -250 // edge is (1/2, 1/2) -- producing a uniform B-spline curve along the │ │ │ │ │ -crease │ │ │ │ │ -251 // (boundary) whether the vertex or its crease is regular or not. The limit │ │ │ │ │ -252 // mask is therefore (1/6, 2/3, 1/6) for ALL cases. │ │ │ │ │ -253 // │ │ │ │ │ -254 // An alternative limit mask (1/5, 3/5, 1/5) is often published for use │ │ │ │ │ -either │ │ │ │ │ -255 // for irregular crease vertices or for all crease/boundary vertices, but │ │ │ │ │ -this │ │ │ │ │ -256 // is based on an alternate refinement mask for the edge -- (3/8, 5/8) │ │ │ │ │ -versus │ │ │ │ │ -257 // the usual (1/2, 1/2) -- and will not produce the B-spline curve desired. │ │ │ │ │ +_2_3_9 bool _A_r_e_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s() const { return _fWeightsForCenters; } │ │ │ │ │ +_2_4_0 void _S_e_t_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s(bool on) { _fWeightsForCenters = on; } │ │ │ │ │ +241 │ │ │ │ │ +242 public: │ │ │ │ │ +243 │ │ │ │ │ +244 // │ │ │ │ │ +245 // Additional methods -- mainly the blending method for vertex-vertex │ │ │ │ │ +masks: │ │ │ │ │ +246 // │ │ │ │ │ +247 template │ │ │ │ │ +248 inline void │ │ │ │ │ +_2_4_9 _C_o_m_b_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k_s(_W_e_i_g_h_t thisCoeff, _W_e_i_g_h_t dstCoeff, USER_MASK& dst) │ │ │ │ │ +const { │ │ │ │ │ +250 │ │ │ │ │ +251 // │ │ │ │ │ +252 // This implementation is convoluted by the potential sparsity of each │ │ │ │ │ +mask. Since │ │ │ │ │ +253 // it is specific to a vertex-vertex mask, we are guaranteed to have │ │ │ │ │ +exactly one │ │ │ │ │ +254 // vertex-weight for both masks, but the edge- and face-weights are │ │ │ │ │ +optional. The │ │ │ │ │ +255 // child mask (the "source") should have a superset of the weights of the │ │ │ │ │ +parent │ │ │ │ │ +256 // (the "destination") given its reduced sharpness, so we fortunately don't │ │ │ │ │ +need to │ │ │ │ │ +257 // test all permutations. │ │ │ │ │ 258 // │ │ │ │ │ -259 Weight vWeight = (Weight) (4.0 / 6.0); │ │ │ │ │ -260 Weight eWeight = (Weight) (1.0 / 6.0); │ │ │ │ │ -261 │ │ │ │ │ -262 posMask.VertexWeight(0) = vWeight; │ │ │ │ │ -263 for (int i = 0; i < valence; ++i) { │ │ │ │ │ -264 posMask.EdgeWeight(i) = 0.0f; │ │ │ │ │ -265 } │ │ │ │ │ -266 posMask.EdgeWeight(creaseEnds[0]) = eWeight; │ │ │ │ │ -267 posMask.EdgeWeight(creaseEnds[1]) = eWeight; │ │ │ │ │ -268} │ │ │ │ │ -269 │ │ │ │ │ -270template <> │ │ │ │ │ -271template │ │ │ │ │ -272inline void │ │ │ │ │ -_2_7_3_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& │ │ │ │ │ -posMask) const { │ │ │ │ │ +259 dst.VertexWeight(0) = dstCoeff * dst.VertexWeight(0) + thisCoeff * this- │ │ │ │ │ +>_V_e_r_t_e_x_W_e_i_g_h_t(0); │ │ │ │ │ +260 │ │ │ │ │ +261 int edgeWeightCount = this->_G_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s(); │ │ │ │ │ +262 if (edgeWeightCount) { │ │ │ │ │ +263 if (dst.GetNumEdgeWeights() == 0) { │ │ │ │ │ +264 dst.SetNumEdgeWeights(edgeWeightCount); │ │ │ │ │ +265 for (int i = 0; i < edgeWeightCount; ++i) { │ │ │ │ │ +266 dst.EdgeWeight(i) = thisCoeff * this->_E_d_g_e_W_e_i_g_h_t(i); │ │ │ │ │ +267 } │ │ │ │ │ +268 } else { │ │ │ │ │ +269 for (int i = 0; i < edgeWeightCount; ++i) { │ │ │ │ │ +270 dst.EdgeWeight(i) = dstCoeff * dst.EdgeWeight(i) + thisCoeff * this- │ │ │ │ │ +>_E_d_g_e_W_e_i_g_h_t(i); │ │ │ │ │ +271 } │ │ │ │ │ +272 } │ │ │ │ │ +273 } │ │ │ │ │ 274 │ │ │ │ │ -275 typedef typename MASK::Weight Weight; │ │ │ │ │ -276 │ │ │ │ │ -277 int valence = vertex.GetNumFaces(); │ │ │ │ │ -278 │ │ │ │ │ -279 posMask.SetNumVertexWeights(1); │ │ │ │ │ -280 posMask.SetNumEdgeWeights(valence); │ │ │ │ │ -281 posMask.SetNumFaceWeights(0); │ │ │ │ │ -282 posMask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -283 │ │ │ │ │ -284 // Specialize for the regular case: 1/12 per edge-vert, 1/2 for the vert │ │ │ │ │ -itself: │ │ │ │ │ -285 if (valence == 6) { │ │ │ │ │ -286 Weight eWeight = (Weight) (1.0 / 12.0); │ │ │ │ │ -287 Weight vWeight = 0.5f; │ │ │ │ │ -288 │ │ │ │ │ -289 posMask.VertexWeight(0) = vWeight; │ │ │ │ │ +275 int faceWeightCount = this->_G_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s(); │ │ │ │ │ +276 if (faceWeightCount) { │ │ │ │ │ +277 // │ │ │ │ │ +278 // If combining face weights, be sure their interpretation (i.e. face- │ │ │ │ │ +centers │ │ │ │ │ +279 // or opposite vertices) is properly set in the destination mask: │ │ │ │ │ +280 // │ │ │ │ │ +281 if (dst.GetNumFaceWeights() == 0) { │ │ │ │ │ +282 dst.SetNumFaceWeights(faceWeightCount); │ │ │ │ │ +283 dst.SetFaceWeightsForFaceCenters(this->_A_r_e_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s()); │ │ │ │ │ +284 │ │ │ │ │ +285 for (int i = 0; i < faceWeightCount; ++i) { │ │ │ │ │ +286 dst.FaceWeight(i) = thisCoeff * this->_F_a_c_e_W_e_i_g_h_t(i); │ │ │ │ │ +287 } │ │ │ │ │ +288 } else { │ │ │ │ │ +289 assert(this->_A_r_e_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s() == │ │ │ │ │ +dst.AreFaceWeightsForFaceCenters()); │ │ │ │ │ 290 │ │ │ │ │ -291 posMask.EdgeWeight(0) = eWeight; │ │ │ │ │ -292 posMask.EdgeWeight(1) = eWeight; │ │ │ │ │ -293 posMask.EdgeWeight(2) = eWeight; │ │ │ │ │ -294 posMask.EdgeWeight(3) = eWeight; │ │ │ │ │ -295 posMask.EdgeWeight(4) = eWeight; │ │ │ │ │ -296 posMask.EdgeWeight(5) = eWeight; │ │ │ │ │ +291 for (int i = 0; i < faceWeightCount; ++i) { │ │ │ │ │ +292 dst.FaceWeight(i) = dstCoeff * dst.FaceWeight(i) + thisCoeff * this- │ │ │ │ │ +>_F_a_c_e_W_e_i_g_h_t(i); │ │ │ │ │ +293 } │ │ │ │ │ +294 } │ │ │ │ │ +295 } │ │ │ │ │ +296 } │ │ │ │ │ 297 │ │ │ │ │ -298 } else { │ │ │ │ │ -299 double dValence = (double) valence; │ │ │ │ │ -300 double invValence = 1.0f / dValence; │ │ │ │ │ -301 double cosTheta = std::cos(M_PI * 2.0f * invValence); │ │ │ │ │ -302 │ │ │ │ │ -303 double beta = 0.25f * cosTheta + 0.375f; │ │ │ │ │ -304 double gamma = (0.625f - (beta * beta)) * invValence; │ │ │ │ │ -305 │ │ │ │ │ -306 Weight eWeight = (Weight) (1.0f / (dValence + 3.0f / (8.0f * gamma))); │ │ │ │ │ -307 Weight vWeight = (Weight) (1.0f - (eWeight * dValence)); │ │ │ │ │ +298 private: │ │ │ │ │ +299 _W_e_i_g_h_t* _vWeights; │ │ │ │ │ +300 _W_e_i_g_h_t* _eWeights; │ │ │ │ │ +301 _W_e_i_g_h_t* _fWeights; │ │ │ │ │ +302 int _vCount; │ │ │ │ │ +303 int _eCount; │ │ │ │ │ +304 int _fCount; │ │ │ │ │ +305 bool _fWeightsForCenters; │ │ │ │ │ +306 }; │ │ │ │ │ +307}; │ │ │ │ │ 308 │ │ │ │ │ -309 posMask.VertexWeight(0) = vWeight; │ │ │ │ │ -310 for (int i = 0; i < valence; ++i) { │ │ │ │ │ -311 posMask.EdgeWeight(i) = eWeight; │ │ │ │ │ -312 } │ │ │ │ │ -313 } │ │ │ │ │ -314} │ │ │ │ │ -315 │ │ │ │ │ -316/* │ │ │ │ │ -317// Limit masks for tangents: │ │ │ │ │ -318// │ │ │ │ │ -319// A note on tangent magnitudes: │ │ │ │ │ -320// │ │ │ │ │ -321// Several formulae exist for limit tangents at a vertex to accommodate the │ │ │ │ │ -322// different topological configurations around the vertex. While these │ │ │ │ │ -produce │ │ │ │ │ -323// the desired direction, there is inconsistency in the resulting │ │ │ │ │ -magnitudes. │ │ │ │ │ -324// Ideally a regular mesh of uniformly shaped triangles with similar edge │ │ │ │ │ -lengths │ │ │ │ │ -325// should produce tangents of similar magnitudes throughout -- including │ │ │ │ │ -corners │ │ │ │ │ -326// and boundaries. So some of the common formulae for these are adjusted │ │ │ │ │ -with │ │ │ │ │ -327// scale factors. │ │ │ │ │ -328// │ │ │ │ │ -329// For uses where magnitude does not matter, this scaling should be │ │ │ │ │ -irrelevant. │ │ │ │ │ -330// But just as with patches, where the magnitudes of partial derivatives are │ │ │ │ │ -331// consistent between similar patches, the magnitudes of limit tangents │ │ │ │ │ -should │ │ │ │ │ -332// also be similar. │ │ │ │ │ -333// │ │ │ │ │ -334// The reference tangents, in terms of magnitudes, are those produced by the │ │ │ │ │ -335// limit tangent mask for smooth interior vertices, for which well │ │ │ │ │ -established │ │ │ │ │ -336// sin/cos formulae apply -- these remain unscaled. Formulae for the other │ │ │ │ │ -337// crease/boundary, corner tangents and irregular cases are scaled to be │ │ │ │ │ -more │ │ │ │ │ -338// consistent with these. │ │ │ │ │ -339// │ │ │ │ │ -340// The crease/boundary tangents for the regular case can be viewed as │ │ │ │ │ -derived │ │ │ │ │ -341// from the smooth interior masks with two "phantom" points extrapolated │ │ │ │ │ -across │ │ │ │ │ -342// the regular boundary: │ │ │ │ │ -343// │ │ │ │ │ -344// v3 v2 │ │ │ │ │ -345// X - - - - - X │ │ │ │ │ -346// / \ / \ │ │ │ │ │ -347// / \ / \ │ │ │ │ │ -348// v4 X - - - - - X - - - - - X v1 │ │ │ │ │ -349// . . 0 . . │ │ │ │ │ -350// . . . . │ │ │ │ │ -351// . . . . │ │ │ │ │ -352// (v5) (v6) │ │ │ │ │ -353// │ │ │ │ │ -354// where v5 = v0 + (v4 - v3) and v6 = v0 + v1 - v2. │ │ │ │ │ -355// │ │ │ │ │ -356// When the standard limit tangent mask is applied, the cosines of │ │ │ │ │ -increments │ │ │ │ │ -357// of pi/3 give us coefficients that are multiples of 1/2, leading to the │ │ │ │ │ -first │ │ │ │ │ -358// tangent T1 = 3/2 * (v1 - v4), rather than the widely used T1 = v1 - v4. │ │ │ │ │ -So │ │ │ │ │ -359// this scale factor of 3/2 is applied to ensure tangents along the │ │ │ │ │ -boundaries │ │ │ │ │ -360// are of similar magnitude as tangents in the immediate interior (which may │ │ │ │ │ +309 │ │ │ │ │ +310// │ │ │ │ │ +311// Crease and corner masks are common to most schemes -- the rest need to be │ │ │ │ │ +provided │ │ │ │ │ +312// for each Scheme specialization. │ │ │ │ │ +313// │ │ │ │ │ +314template │ │ │ │ │ +315template │ │ │ │ │ +316inline void │ │ │ │ │ +_3_1_7_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e(EDGE const&, MASK& mask) const { │ │ │ │ │ +318 │ │ │ │ │ +319 mask.SetNumVertexWeights(2); │ │ │ │ │ +320 mask.SetNumEdgeWeights(0); │ │ │ │ │ +321 mask.SetNumFaceWeights(0); │ │ │ │ │ +322 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +323 │ │ │ │ │ +324 mask.VertexWeight(0) = 0.5f; │ │ │ │ │ +325 mask.VertexWeight(1) = 0.5f; │ │ │ │ │ +326} │ │ │ │ │ +327 │ │ │ │ │ +328template │ │ │ │ │ +329template │ │ │ │ │ +330inline void │ │ │ │ │ +_3_3_1_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const&, MASK& mask) const { │ │ │ │ │ +332 │ │ │ │ │ +333 mask.SetNumVertexWeights(1); │ │ │ │ │ +334 mask.SetNumEdgeWeights(0); │ │ │ │ │ +335 mask.SetNumFaceWeights(0); │ │ │ │ │ +336 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +337 │ │ │ │ │ +338 mask.VertexWeight(0) = 1.0f; │ │ │ │ │ +339} │ │ │ │ │ +340 │ │ │ │ │ +341 │ │ │ │ │ +342// │ │ │ │ │ +343// The computation of a face-vertex mask is trivial and consistent for all │ │ │ │ │ +schemes: │ │ │ │ │ +344// │ │ │ │ │ +345template │ │ │ │ │ +346template │ │ │ │ │ +347void │ │ │ │ │ +_3_4_8_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_F_a_c_e_V_e_r_t_e_x_M_a_s_k(FACE const& face, MASK& mask) const { │ │ │ │ │ +349 │ │ │ │ │ +350 int vertCount = face.GetNumVertices(); │ │ │ │ │ +351 │ │ │ │ │ +352 mask.SetNumVertexWeights(vertCount); │ │ │ │ │ +353 mask.SetNumEdgeWeights(0); │ │ │ │ │ +354 mask.SetNumFaceWeights(0); │ │ │ │ │ +355 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +356 │ │ │ │ │ +357 typename MASK::Weight vWeight = 1.0f / (typename MASK::Weight) vertCount; │ │ │ │ │ +358 for (int i = 0; i < vertCount; ++i) { │ │ │ │ │ +359 mask.VertexWeight(i) = vWeight; │ │ │ │ │ +360 } │ │ │ │ │ +361} │ │ │ │ │ +362 │ │ │ │ │ +363 │ │ │ │ │ +364// │ │ │ │ │ +365// The computation of an edge-vertex mask requires inspection of sharpness │ │ │ │ │ +values to │ │ │ │ │ +366// determine if smooth or a crease, and also to detect and apply a │ │ │ │ │ +transition from a │ │ │ │ │ +367// crease to smooth. Using the protected methods to assign the specific │ │ │ │ │ +masks (only │ │ │ │ │ +368// two -- smooth or crease) this implementation should serve all non-linear │ │ │ │ │ +schemes │ │ │ │ │ +369// (currently Catmark and Loop) and only needs to be specialized for │ │ │ │ │ +Bilinear to │ │ │ │ │ +370// trivialize it to the crease case. │ │ │ │ │ +371// │ │ │ │ │ +372// The implementation here is slightly complicated by combining two │ │ │ │ │ +scenarios into a │ │ │ │ │ +373// single implementation -- either the caller knows the parent and child │ │ │ │ │ +rules and │ │ │ │ │ +374// provides them, or they don't and the Rules have to be determined from │ │ │ │ │ +sharpness │ │ │ │ │ +375// values. Both cases include quick return once the parent is determined to │ │ │ │ │ be │ │ │ │ │ -361// parallel). │ │ │ │ │ -362// │ │ │ │ │ -363// Tangents at corners are essentially a form of boundary tangent, and so │ │ │ │ │ -its │ │ │ │ │ -364// simple difference formula is scaled to be consistent with adjoining │ │ │ │ │ -boundary │ │ │ │ │ -365// tangents -- not just with the 3/2 factor from above, but with an │ │ │ │ │ -additional │ │ │ │ │ -366// 2.0 to compensate for the fact that the difference of only side of the │ │ │ │ │ -vertex │ │ │ │ │ -367// is considered here. The resulting scale factor of 3.0 for the regular │ │ │ │ │ -corner │ │ │ │ │ -368// is what similarly arises by extrapolating an interior region around the │ │ │ │ │ -369// vertex and using the interior mask for the first tangent. │ │ │ │ │ -370// │ │ │ │ │ -371// The cross-tangent formula for the regular crease/boundary is similarly │ │ │ │ │ -found │ │ │ │ │ -372// from the above construction of the boundary, but the commonly used │ │ │ │ │ -weights of │ │ │ │ │ -373// +/- 1 and 2 result from omitting the common factor of sqrt(3)/2 (arising │ │ │ │ │ -from │ │ │ │ │ -374// the sines of increments of pi/3). With that scale factor close to one, it │ │ │ │ │ -has │ │ │ │ │ -375// less impact than the irregular cases, which are analogous to corner │ │ │ │ │ -tangents │ │ │ │ │ -376// in that differences on only one side of the vertex are considered. While │ │ │ │ │ -a │ │ │ │ │ -377// scaling of 3.0 is similarly understandable for the valence 2 and 3 cases, │ │ │ │ │ -it is │ │ │ │ │ -378// less obvious in the irregular formula for valence > 4, but similarly │ │ │ │ │ -effective. │ │ │ │ │ +376// smooth or the child a crease, leaving the transitional case remaining. │ │ │ │ │ +377// │ │ │ │ │ +378// The overall process is as follows: │ │ │ │ │ 379// │ │ │ │ │ -380// The end result of these adjustments should be a set of limit tangents │ │ │ │ │ -that are │ │ │ │ │ -381// of similar magnitude over a regular mesh including boundaries and │ │ │ │ │ -corners. │ │ │ │ │ -382*/ │ │ │ │ │ -383template <> │ │ │ │ │ -384template │ │ │ │ │ -385inline void │ │ │ │ │ -_3_8_6_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, │ │ │ │ │ -387 MASK& tan1Mask, MASK& tan2Mask) const { │ │ │ │ │ -388 │ │ │ │ │ -389 int valence = vertex.GetNumEdges(); │ │ │ │ │ -390 │ │ │ │ │ -391 tan1Mask.SetNumVertexWeights(1); │ │ │ │ │ -392 tan1Mask.SetNumEdgeWeights(valence); │ │ │ │ │ -393 tan1Mask.SetNumFaceWeights(0); │ │ │ │ │ -394 tan1Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -395 │ │ │ │ │ -396 tan2Mask.SetNumVertexWeights(1); │ │ │ │ │ -397 tan2Mask.SetNumEdgeWeights(valence); │ │ │ │ │ -398 tan2Mask.SetNumFaceWeights(0); │ │ │ │ │ -399 tan2Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -400 │ │ │ │ │ -401 // See note above regarding scale factor of 3.0: │ │ │ │ │ -402 tan1Mask.VertexWeight(0) = -3.0f; │ │ │ │ │ -403 tan1Mask.EdgeWeight(0) = 3.0f; │ │ │ │ │ -404 tan1Mask.EdgeWeight(1) = 0.0f; │ │ │ │ │ -405 │ │ │ │ │ -406 tan2Mask.VertexWeight(0) = -3.0f; │ │ │ │ │ -407 tan2Mask.EdgeWeight(0) = 0.0f; │ │ │ │ │ -408 tan2Mask.EdgeWeight(1) = 3.0f; │ │ │ │ │ -409 │ │ │ │ │ -410 // Should be at least 2 edges -- be sure to clear weights for any more: │ │ │ │ │ -411 for (int i = 2; i < valence; ++i) { │ │ │ │ │ -412 tan1Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ -413 tan2Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ -414 } │ │ │ │ │ -415} │ │ │ │ │ -416 │ │ │ │ │ -417template <> │ │ │ │ │ -418template │ │ │ │ │ -419inline void │ │ │ │ │ -_4_2_0_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, │ │ │ │ │ -421 MASK& tan1Mask, MASK& tan2Mask, int const creaseEnds[2]) const { │ │ │ │ │ -422 │ │ │ │ │ -423 typedef typename MASK::Weight Weight; │ │ │ │ │ -424 │ │ │ │ │ -425 // │ │ │ │ │ -426 // First, the tangent along the crease: │ │ │ │ │ -427 // The first crease edge is considered the "leading" edge of the span │ │ │ │ │ -428 // of surface for which we are evaluating tangents and the second edge the │ │ │ │ │ -429 // "trailing edge". By convention, the tangent along the crease is oriented │ │ │ │ │ -430 // in the direction of the leading edge. │ │ │ │ │ -431 // │ │ │ │ │ -432 int valence = vertex.GetNumEdges(); │ │ │ │ │ -433 │ │ │ │ │ -434 tan1Mask.SetNumVertexWeights(1); │ │ │ │ │ -435 tan1Mask.SetNumEdgeWeights(valence); │ │ │ │ │ -436 tan1Mask.SetNumFaceWeights(0); │ │ │ │ │ -437 tan1Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -438 │ │ │ │ │ -439 tan1Mask.VertexWeight(0) = 0.0f; │ │ │ │ │ -440 for (int i = 0; i < valence; ++i) { │ │ │ │ │ -441 tan1Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ -442 } │ │ │ │ │ -443 │ │ │ │ │ -444 // See the note above regarding scale factor of 1.5: │ │ │ │ │ -445 tan1Mask.EdgeWeight(creaseEnds[0]) = 1.5f; │ │ │ │ │ -446 tan1Mask.EdgeWeight(creaseEnds[1]) = -1.5f; │ │ │ │ │ +380// - quickly detect the most common specified or detected Smooth case and │ │ │ │ │ +return │ │ │ │ │ +381// - quickly detect a full Crease by child Rule assignment and return │ │ │ │ │ +382// - determine from sharpness if unspecified child is a crease -- return if │ │ │ │ │ +so │ │ │ │ │ +383// - compute smooth mask for child and combine with crease from parent │ │ │ │ │ +384// │ │ │ │ │ +385// Usage of the parent Rule here allows some misuse in that only three of │ │ │ │ │ +five possible │ │ │ │ │ +386// assignments are legitimate for the parent and four for the child (Dart │ │ │ │ │ +being only │ │ │ │ │ +387// valid for the child and Corner for neither). Results are undefined in │ │ │ │ │ +these cases. │ │ │ │ │ +388// │ │ │ │ │ +389template │ │ │ │ │ +390template │ │ │ │ │ +391void │ │ │ │ │ +_3_9_2_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_E_d_g_e_V_e_r_t_e_x_M_a_s_k(EDGE const& edge, │ │ │ │ │ +393 MASK& mask, │ │ │ │ │ +394 _C_r_e_a_s_e_:_:_R_u_l_e parentRule, │ │ │ │ │ +395 _C_r_e_a_s_e_:_:_R_u_l_e childRule) const { │ │ │ │ │ +396 │ │ │ │ │ +397 // │ │ │ │ │ +398 // If the parent was specified or determined to be Smooth, we can quickly │ │ │ │ │ +return │ │ │ │ │ +399 // with a Smooth mask. Otherwise the parent is a crease -- if the child was │ │ │ │ │ +400 // also specified to be a crease, we can quickly return with a Crease mask. │ │ │ │ │ +401 // │ │ │ │ │ +402 if ((parentRule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || │ │ │ │ │ +403 ((parentRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) && (edge.GetSharpness() <= 0.0f))) { │ │ │ │ │ +404 assignSmoothMaskForEdge(edge, mask); │ │ │ │ │ +405 return; │ │ │ │ │ +406 } │ │ │ │ │ +407 if (childRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ +408 assignCreaseMaskForEdge(edge, mask); │ │ │ │ │ +409 return; │ │ │ │ │ +410 } │ │ │ │ │ +411 │ │ │ │ │ +412 // │ │ │ │ │ +413 // We have a Crease on the parent and the child was either specified as │ │ │ │ │ +Smooth │ │ │ │ │ +414 // or was not specified at all -- deal with the unspecified case first │ │ │ │ │ +(again │ │ │ │ │ +415 // returning a Crease mask if the child is also determined to be a Crease) │ │ │ │ │ +and │ │ │ │ │ +416 // continue if we have a transition to Smooth. │ │ │ │ │ +417 // │ │ │ │ │ +418 // Note when qualifying the child that if the parent sharpness > 1.0, │ │ │ │ │ +regardless │ │ │ │ │ +419 // of the creasing method, whether the child sharpness values decay to zero │ │ │ │ │ +is │ │ │ │ │ +420 // irrelevant -- the fractional weight for such a case (the value of the │ │ │ │ │ +parent │ │ │ │ │ +421 // sharpness) is > 1.0, and when clamped to 1 effectively yields a full │ │ │ │ │ +crease. │ │ │ │ │ +422 // │ │ │ │ │ +423 if (childRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) { │ │ │ │ │ +424 _C_r_e_a_s_e crease(_options); │ │ │ │ │ +425 │ │ │ │ │ +426 bool childIsCrease = false; │ │ │ │ │ +427 if (parentRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ +428 // Child unknown as default value but parent Rule specified as Crease │ │ │ │ │ +429 childIsCrease = true; │ │ │ │ │ +430 } else if (edge.GetSharpness() >= 1.0f) { │ │ │ │ │ +431 // Sharpness >= 1.0 always a crease -- see note above │ │ │ │ │ +432 childIsCrease = true; │ │ │ │ │ +433 } else if (crease._I_s_U_n_i_f_o_r_m()) { │ │ │ │ │ +434 // Sharpness < 1.0 is guaranteed to decay to 0.0 for Uniform child edges │ │ │ │ │ +435 childIsCrease = false; │ │ │ │ │ +436 } else { │ │ │ │ │ +437 // Sharpness <= 1.0 does not necessarily decay to 0.0 for both child │ │ │ │ │ +edges... │ │ │ │ │ +438 float cEdgeSharpness[2]; │ │ │ │ │ +439 edge.GetChildSharpnesses(crease, cEdgeSharpness); │ │ │ │ │ +440 childIsCrease = (cEdgeSharpness[0] > 0.0f) && (cEdgeSharpness[1] > 0.0f); │ │ │ │ │ +441 } │ │ │ │ │ +442 if (childIsCrease) { │ │ │ │ │ +443 assignCreaseMaskForEdge(edge, mask); │ │ │ │ │ +444 return; │ │ │ │ │ +445 } │ │ │ │ │ +446 } │ │ │ │ │ 447 │ │ │ │ │ 448 // │ │ │ │ │ -449 // Second, the tangent across the interior faces: │ │ │ │ │ -450 // Note this is ambiguous for an interior vertex. We currently return │ │ │ │ │ -451 // the tangent for the surface in the counter-clockwise span between the │ │ │ │ │ -452 // leading and trailing edges that form the crease. Given the expected │ │ │ │ │ -453 // computation of a surface normal as Tan1 X Tan2, this tangent should be │ │ │ │ │ -454 // oriented "inward" from the crease/boundary -- across the surface rather │ │ │ │ │ -455 // than outward and away from it. │ │ │ │ │ +449 // We are now left with the Crease-to-Smooth case -- compute the Smooth │ │ │ │ │ +mask │ │ │ │ │ +450 // for the child and augment it with the transitional Crease of the parent. │ │ │ │ │ +451 // │ │ │ │ │ +452 // A general combination of separately assigned masks here (as done in the │ │ │ │ │ +vertex- │ │ │ │ │ +453 // vertex case) is overkill -- trivially combine the 0.5f vertex │ │ │ │ │ +coefficient for │ │ │ │ │ +454 // the Crease of the parent with the vertex weights and attenuate the face │ │ │ │ │ +weights │ │ │ │ │ +455 // accordingly. │ │ │ │ │ 456 // │ │ │ │ │ -457 // There is inconsistency in the orientation of this tangent in commonly │ │ │ │ │ -458 // published results: the general formula provided for arbitrary valence │ │ │ │ │ -459 // has the tangent pointing across the crease and "outward" from the │ │ │ │ │ -surface, │ │ │ │ │ -460 // while the special cases for regular valence and lower have the tangent │ │ │ │ │ -461 // pointing across the surface and "inward" from the crease. So if we are │ │ │ │ │ -462 // to consistently orient the first tangent along the crease, regardless of │ │ │ │ │ -463 // the interior topology, we have to correct this. With the first tangent │ │ │ │ │ -464 // following the direction of the leading crease edge, we want the second │ │ │ │ │ -465 // tangent pointing inward/across the surface -- so we flip the result of │ │ │ │ │ -466 // the general formula. │ │ │ │ │ -467 // │ │ │ │ │ -468 tan2Mask.SetNumVertexWeights(1); │ │ │ │ │ -469 tan2Mask.SetNumEdgeWeights(valence); │ │ │ │ │ -470 tan2Mask.SetNumFaceWeights(0); │ │ │ │ │ -471 tan2Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +457 assignSmoothMaskForEdge(edge, mask); │ │ │ │ │ +458 │ │ │ │ │ +459 typedef typename MASK::Weight Weight; │ │ │ │ │ +460 │ │ │ │ │ +461 Weight pWeight = edge.GetSharpness(); │ │ │ │ │ +462 Weight cWeight = 1.0f - pWeight; │ │ │ │ │ +463 │ │ │ │ │ +464 mask.VertexWeight(0) = pWeight * 0.5f + cWeight * mask.VertexWeight(0); │ │ │ │ │ +465 mask.VertexWeight(1) = pWeight * 0.5f + cWeight * mask.VertexWeight(1); │ │ │ │ │ +466 │ │ │ │ │ +467 int faceCount = mask.GetNumFaceWeights(); │ │ │ │ │ +468 for (int i = 0; i < faceCount; ++i) { │ │ │ │ │ +469 mask.FaceWeight(i) *= cWeight; │ │ │ │ │ +470 } │ │ │ │ │ +471} │ │ │ │ │ 472 │ │ │ │ │ -473 for (int i = 0; i < creaseEnds[0]; ++i) { │ │ │ │ │ -474 tan2Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ -475 } │ │ │ │ │ -476 int interiorEdgeCount = creaseEnds[1] - creaseEnds[0] - 1; │ │ │ │ │ -477 if (interiorEdgeCount == 2) { │ │ │ │ │ -478 // See note above regarding scale factor of (sin(60 degs) == sqrt(3)/2: │ │ │ │ │ -479 │ │ │ │ │ -480 static Weight const Root3 = (Weight) 1.73205080756887729352; │ │ │ │ │ -481 static Weight const Root3by2 = (Weight) (Root3 * 0.5); │ │ │ │ │ -482 │ │ │ │ │ -483 tan2Mask.VertexWeight(0) = -Root3; │ │ │ │ │ -484 │ │ │ │ │ -485 tan2Mask.EdgeWeight(creaseEnds[0]) = -Root3by2; │ │ │ │ │ -486 tan2Mask.EdgeWeight(creaseEnds[1]) = -Root3by2; │ │ │ │ │ -487 │ │ │ │ │ -488 tan2Mask.EdgeWeight(creaseEnds[0] + 1) = Root3; │ │ │ │ │ -489 tan2Mask.EdgeWeight(creaseEnds[0] + 2) = Root3; │ │ │ │ │ -490 } else if (interiorEdgeCount > 2) { │ │ │ │ │ -491 // See notes above regarding scale factor of -3.0 (-1 for orientation, │ │ │ │ │ -492 // 2.0 for considering the region as a half-disk, and 1.5 in keeping │ │ │ │ │ -493 // with the crease tangent): │ │ │ │ │ -494 │ │ │ │ │ -495 double theta = M_PI / (interiorEdgeCount + 1); │ │ │ │ │ -496 │ │ │ │ │ -497 tan2Mask.VertexWeight(0) = 0.0f; │ │ │ │ │ -498 │ │ │ │ │ -499 Weight cWeight = (Weight) (-3.0f * std::sin(theta)); │ │ │ │ │ -500 tan2Mask.EdgeWeight(creaseEnds[0]) = cWeight; │ │ │ │ │ -501 tan2Mask.EdgeWeight(creaseEnds[1]) = cWeight; │ │ │ │ │ -502 │ │ │ │ │ -503 double eCoeff = -3.0f * 2.0f * (std::cos(theta) - 1.0f); │ │ │ │ │ -504 for (int i = 1; i <= interiorEdgeCount; ++i) { │ │ │ │ │ -505 tan2Mask.EdgeWeight(creaseEnds[0] + i) = (Weight) (eCoeff * std::sin(i * │ │ │ │ │ -theta)); │ │ │ │ │ -506 } │ │ │ │ │ -507 } else if (interiorEdgeCount == 1) { │ │ │ │ │ -508 // See notes above regarding scale factor of 3.0: │ │ │ │ │ -509 │ │ │ │ │ -510 tan2Mask.VertexWeight(0) = -3.0f; │ │ │ │ │ -511 │ │ │ │ │ -512 tan2Mask.EdgeWeight(creaseEnds[0]) = 0.0f; │ │ │ │ │ -513 tan2Mask.EdgeWeight(creaseEnds[1]) = 0.0f; │ │ │ │ │ -514 │ │ │ │ │ -515 tan2Mask.EdgeWeight(creaseEnds[0] + 1) = 3.0f; │ │ │ │ │ -516 } else { │ │ │ │ │ -517 // See notes above regarding scale factor of 3.0: │ │ │ │ │ -518 │ │ │ │ │ -519 tan2Mask.VertexWeight(0) = -6.0f; │ │ │ │ │ -520 │ │ │ │ │ -521 tan2Mask.EdgeWeight(creaseEnds[0]) = 3.0f; │ │ │ │ │ -522 tan2Mask.EdgeWeight(creaseEnds[1]) = 3.0f; │ │ │ │ │ -523 } │ │ │ │ │ -524 for (int i = creaseEnds[1] + 1; i < valence; ++i) { │ │ │ │ │ -525 tan2Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ -526 } │ │ │ │ │ -527} │ │ │ │ │ -528 │ │ │ │ │ -529template <> │ │ │ │ │ -530template │ │ │ │ │ -531inline void │ │ │ │ │ -_5_3_2_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, │ │ │ │ │ -533 MASK& tan1Mask, MASK& tan2Mask) const { │ │ │ │ │ -534 │ │ │ │ │ -535 typedef typename MASK::Weight Weight; │ │ │ │ │ -536 │ │ │ │ │ -537 int valence = vertex.GetNumFaces(); │ │ │ │ │ -538 │ │ │ │ │ -539 tan1Mask.SetNumVertexWeights(1); │ │ │ │ │ -540 tan1Mask.SetNumEdgeWeights(valence); │ │ │ │ │ -541 tan1Mask.SetNumFaceWeights(0); │ │ │ │ │ -542 tan1Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -543 │ │ │ │ │ -544 tan2Mask.SetNumVertexWeights(1); │ │ │ │ │ -545 tan2Mask.SetNumEdgeWeights(valence); │ │ │ │ │ -546 tan2Mask.SetNumFaceWeights(0); │ │ │ │ │ -547 tan2Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -548 │ │ │ │ │ -549 tan1Mask.VertexWeight(0) = 0.0f; │ │ │ │ │ -550 tan2Mask.VertexWeight(0) = 0.0f; │ │ │ │ │ -551 │ │ │ │ │ -552 if (valence == 6) { │ │ │ │ │ -553 static Weight const Root3by2 = (Weight)(0.5 * 1.73205080756887729352); │ │ │ │ │ -554 │ │ │ │ │ -555 tan1Mask.EdgeWeight(0) = 1.0f; │ │ │ │ │ -556 tan1Mask.EdgeWeight(1) = 0.5f; │ │ │ │ │ -557 tan1Mask.EdgeWeight(2) = -0.5f; │ │ │ │ │ -558 tan1Mask.EdgeWeight(3) = -1.0f; │ │ │ │ │ -559 tan1Mask.EdgeWeight(4) = -0.5f; │ │ │ │ │ -560 tan1Mask.EdgeWeight(5) = 0.5f; │ │ │ │ │ -561 │ │ │ │ │ -562 tan2Mask.EdgeWeight(0) = 0.0f; │ │ │ │ │ -563 tan2Mask.EdgeWeight(1) = Root3by2; │ │ │ │ │ -564 tan2Mask.EdgeWeight(2) = Root3by2; │ │ │ │ │ -565 tan2Mask.EdgeWeight(3) = 0.0f; │ │ │ │ │ -566 tan2Mask.EdgeWeight(4) = -Root3by2; │ │ │ │ │ -567 tan2Mask.EdgeWeight(5) = -Root3by2; │ │ │ │ │ -568 } else { │ │ │ │ │ -569 double alpha = 2.0f * M_PI / valence; │ │ │ │ │ -570 for (int i = 0; i < valence; ++i) { │ │ │ │ │ -571 double alphaI = alpha * i; │ │ │ │ │ -572 tan1Mask.EdgeWeight(i) = (Weight) std::cos(alphaI); │ │ │ │ │ -573 tan2Mask.EdgeWeight(i) = (Weight) std::sin(alphaI); │ │ │ │ │ -574 } │ │ │ │ │ -575 } │ │ │ │ │ -576} │ │ │ │ │ -577 │ │ │ │ │ -578} // end namespace Sdc │ │ │ │ │ -579} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -580using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -581} // end namespace OpenSubdiv │ │ │ │ │ +473// │ │ │ │ │ +474// The computation of a vertex-vertex mask requires inspection of creasing │ │ │ │ │ +sharpness values │ │ │ │ │ +475// to determine what subdivision Rules apply to the parent and its child │ │ │ │ │ +vertex, and also to │ │ │ │ │ +476// detect and apply a transition between two differing Rules. Using the │ │ │ │ │ +protected methods to │ │ │ │ │ +477// assign specific masks, this implementation should serve all non-linear │ │ │ │ │ +schemes (currently │ │ │ │ │ +478// Catmark and Loop) and only needs to be specialized for Bilinear to remove │ │ │ │ │ +all unnecessary │ │ │ │ │ +479// complexity relating to creasing, Rules, etc. │ │ │ │ │ +480// │ │ │ │ │ +481// The implementation here is slightly complicated by combining two │ │ │ │ │ +scenarios into one -- │ │ │ │ │ +482// either the caller knows the parent and child rules and provides them, or │ │ │ │ │ +they don't and │ │ │ │ │ +483// the Rules have to be determined from sharpness values. Even when the │ │ │ │ │ +Rules are known and │ │ │ │ │ +484// provided though, there are cases where the parent and child sharpness │ │ │ │ │ +values need to be │ │ │ │ │ +485// identified, so accounting for the unknown Rules too is not much of an │ │ │ │ │ +added complication. │ │ │ │ │ +486// │ │ │ │ │ +487// The benefit of supporting specified Rules is that they can often be │ │ │ │ │ +trivially │ │ │ │ │ +488// determined from context (e.g. a vertex derived from a face at a previous │ │ │ │ │ +level will always │ │ │ │ │ +489// be smooth) rather than more generally, and at greater cost, inspecting │ │ │ │ │ +neighboring and │ │ │ │ │ +490// they are often the same for parent and child. │ │ │ │ │ +491// │ │ │ │ │ +492// The overall process is as follows: │ │ │ │ │ +493// │ │ │ │ │ +494// - quickly detect the most common Smooth case when specified and return │ │ │ │ │ +495// - determine if sharpness for parent is required and gather if so │ │ │ │ │ +496// - if unspecified, determine the parent rule │ │ │ │ │ +497// - assign mask for the parent rule -- returning if Smooth/Dart │ │ │ │ │ +498// - return if child rule matches parent │ │ │ │ │ +499// - gather sharpness for child to determine or combine child rule │ │ │ │ │ +500// - if unspecified, determine the child rule, returning if it matches │ │ │ │ │ +parent │ │ │ │ │ +501// - assign local mask for child rule │ │ │ │ │ +502// - combine local child mask with the parent mask │ │ │ │ │ +503// │ │ │ │ │ +504// Remember -- if the parent rule is specified but the child is not, this │ │ │ │ │ +implies only one │ │ │ │ │ +505// of the two optional rules was specified and is meant to indicate there is │ │ │ │ │ +no transition, │ │ │ │ │ +506// so the child rule should be assigned to be the same (wish the compiler │ │ │ │ │ +would allow this │ │ │ │ │ +507// in default value assignment). │ │ │ │ │ +508// │ │ │ │ │ +509template │ │ │ │ │ +510template │ │ │ │ │ +511void │ │ │ │ │ +_5_1_2_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k(VERTEX const& vertex, │ │ │ │ │ +513 MASK& mask, │ │ │ │ │ +514 _C_r_e_a_s_e_:_:_R_u_l_e pRule, │ │ │ │ │ +515 _C_r_e_a_s_e_:_:_R_u_l_e cRule) const { │ │ │ │ │ +516 │ │ │ │ │ +517 // Quick assignment and return for the most common case: │ │ │ │ │ +518 if ((pRule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ +519 assignSmoothMaskForVertex(vertex, mask); │ │ │ │ │ +520 return; │ │ │ │ │ +521 } │ │ │ │ │ +522 // If unspecified, assign the child rule to match the parent rule if │ │ │ │ │ +specified: │ │ │ │ │ +523 if ((cRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) && (pRule != _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N)) { │ │ │ │ │ +524 cRule = pRule; │ │ │ │ │ +525 } │ │ │ │ │ +526 int valence = vertex.GetNumEdges(); │ │ │ │ │ +527 │ │ │ │ │ +528 // │ │ │ │ │ +529 // Determine if we need the parent edge sharpness values -- identify/gather │ │ │ │ │ +if so │ │ │ │ │ +530 // and use it to compute the parent rule if unspecified: │ │ │ │ │ +531 // │ │ │ │ │ +532 float * pEdgeSharpnessBuffer = (float *)alloca(valence*sizeof(float)), │ │ │ │ │ +533 * pEdgeSharpness = 0, │ │ │ │ │ +534 pVertexSharpness = 0.0f; │ │ │ │ │ +535 │ │ │ │ │ +536 bool requireParentSharpness = (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) || │ │ │ │ │ +537 (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) || │ │ │ │ │ +538 (pRule != cRule); │ │ │ │ │ +539 if (requireParentSharpness) { │ │ │ │ │ +540 pVertexSharpness = vertex.GetSharpness(); │ │ │ │ │ +541 pEdgeSharpness = vertex.GetSharpnessPerEdge(pEdgeSharpnessBuffer); │ │ │ │ │ +542 │ │ │ │ │ +543 if (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) { │ │ │ │ │ +544 pRule = _C_r_e_a_s_e(_options)._D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e(pVertexSharpness, │ │ │ │ │ +valence, pEdgeSharpness); │ │ │ │ │ +545 } │ │ │ │ │ +546 } │ │ │ │ │ +547 if ((pRule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ +548 assignSmoothMaskForVertex(vertex, mask); │ │ │ │ │ +549 return; // As done on entry, we can return immediately if parent is Smooth/ │ │ │ │ │ +Dart │ │ │ │ │ +550 } else if (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ +551 int creaseEnds[2]; │ │ │ │ │ +552 _C_r_e_a_s_e(_options)._G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(pEdgeSharpness, valence, │ │ │ │ │ +creaseEnds); │ │ │ │ │ +553 │ │ │ │ │ +554 assignCreaseMaskForVertex(vertex, mask, creaseEnds); │ │ │ │ │ +555 } else { │ │ │ │ │ +556 assignCornerMaskForVertex(vertex, mask); │ │ │ │ │ +557 } │ │ │ │ │ +558 if (cRule == pRule) return; │ │ │ │ │ +559 │ │ │ │ │ +560 // │ │ │ │ │ +561 // Identify/gather child sharpness to combine masks for the two differing │ │ │ │ │ +Rules: │ │ │ │ │ +562 // │ │ │ │ │ +563 _C_r_e_a_s_e crease(_options); │ │ │ │ │ +564 │ │ │ │ │ +565 float * cEdgeSharpnessBuffer = (float *)alloca(valence*sizeof(float)), │ │ │ │ │ +566 * cEdgeSharpness = vertex.GetChildSharpnessPerEdge(crease, │ │ │ │ │ +cEdgeSharpnessBuffer), │ │ │ │ │ +567 cVertexSharpness = vertex.GetChildSharpness(crease); │ │ │ │ │ +568 │ │ │ │ │ +569 if (cRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) { │ │ │ │ │ +570 cRule = crease._D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e(cVertexSharpness, valence, │ │ │ │ │ +cEdgeSharpness); │ │ │ │ │ +571 if (cRule == pRule) return; │ │ │ │ │ +572 } │ │ │ │ │ +573 │ │ │ │ │ +574 // │ │ │ │ │ +575 // Initialize a local child mask, compute the fractional weight from parent │ │ │ │ │ +and child │ │ │ │ │ +576 // sharpness values and combine the two masks: │ │ │ │ │ +577 // │ │ │ │ │ +578 typedef typename MASK::Weight Weight; │ │ │ │ │ +579 │ │ │ │ │ +580 Weight * cMaskWeights = (Weight *)alloca((1 + 2 * valence)*sizeof(Weight)); │ │ │ │ │ +581 _L_o_c_a_l_M_a_s_k_<_W_e_i_g_h_t_> cMask(cMaskWeights, cMaskWeights + 1, cMaskWeights + 1 + │ │ │ │ │ +valence); │ │ │ │ │ 582 │ │ │ │ │ -583#endif /* OPENSUBDIV3_SDC_LOOP_SCHEME_H */ │ │ │ │ │ +583 if ((cRule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (cRule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ +584 assignSmoothMaskForVertex(vertex, cMask); │ │ │ │ │ +585 } else if (cRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ +586 int creaseEnds[2]; │ │ │ │ │ +587 _C_r_e_a_s_e(_options)._G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(cEdgeSharpness, valence, │ │ │ │ │ +creaseEnds); │ │ │ │ │ +588 │ │ │ │ │ +589 assignCreaseMaskForVertex(vertex, cMask, creaseEnds); │ │ │ │ │ +590 } else { │ │ │ │ │ +591 assignCornerMaskForVertex(vertex, cMask); │ │ │ │ │ +592 } │ │ │ │ │ +593 │ │ │ │ │ +594 Weight pWeight = crease._C_o_m_p_u_t_e_F_r_a_c_t_i_o_n_a_l_W_e_i_g_h_t_A_t_V_e_r_t_e_x(pVertexSharpness, │ │ │ │ │ +cVertexSharpness, │ │ │ │ │ +595 valence, pEdgeSharpness, cEdgeSharpness); │ │ │ │ │ +596 Weight cWeight = 1.0f - pWeight; │ │ │ │ │ +597 │ │ │ │ │ +598 cMask._C_o_m_b_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k_s(cWeight, pWeight, mask); │ │ │ │ │ +599} │ │ │ │ │ +600 │ │ │ │ │ +601// │ │ │ │ │ +602// The computation of limit masks for vertices: │ │ │ │ │ +603// │ │ │ │ │ +604template │ │ │ │ │ +605template │ │ │ │ │ +606void │ │ │ │ │ +_6_0_7_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, │ │ │ │ │ +608 MASK& mask, │ │ │ │ │ +609 _C_r_e_a_s_e_:_:_R_u_l_e rule) const { │ │ │ │ │ +610 │ │ │ │ │ +611 if ((rule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (rule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ +612 assignSmoothLimitMask(vertex, mask); │ │ │ │ │ +613 } else if (rule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ +614 float * edgeSharpness = (float *)alloca(vertex.GetNumEdges() * sizeof │ │ │ │ │ +(float)); │ │ │ │ │ +615 vertex.GetSharpnessPerEdge(edgeSharpness); │ │ │ │ │ +616 │ │ │ │ │ +617 int creaseEnds[2]; │ │ │ │ │ +618 _C_r_e_a_s_e(_options)._G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(edgeSharpness, vertex.GetNumEdges │ │ │ │ │ +(), creaseEnds); │ │ │ │ │ +619 │ │ │ │ │ +620 assignCreaseLimitMask(vertex, mask, creaseEnds); │ │ │ │ │ +621 } else { │ │ │ │ │ +622 assignCornerLimitMask(vertex, mask); │ │ │ │ │ +623 } │ │ │ │ │ +624} │ │ │ │ │ +625 │ │ │ │ │ +626template │ │ │ │ │ +627template │ │ │ │ │ +628void │ │ │ │ │ +_6_2_9_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, │ │ │ │ │ +630 MASK& posMask, │ │ │ │ │ +631 MASK& tan1Mask, │ │ │ │ │ +632 MASK& tan2Mask, │ │ │ │ │ +633 _C_r_e_a_s_e_:_:_R_u_l_e rule) const { │ │ │ │ │ +634 │ │ │ │ │ +635 if ((rule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (rule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ +636 assignSmoothLimitMask(vertex, posMask); │ │ │ │ │ +637 assignSmoothLimitTangentMasks(vertex, tan1Mask, tan2Mask); │ │ │ │ │ +638 } else if (rule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ +639 float * edgeSharpness = (float *)alloca(vertex.GetNumEdges() * sizeof │ │ │ │ │ +(float)); │ │ │ │ │ +640 vertex.GetSharpnessPerEdge(edgeSharpness); │ │ │ │ │ +641 │ │ │ │ │ +642 int creaseEnds[2]; │ │ │ │ │ +643 _C_r_e_a_s_e(_options)._G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(edgeSharpness, vertex.GetNumEdges │ │ │ │ │ +(), creaseEnds); │ │ │ │ │ +644 │ │ │ │ │ +645 assignCreaseLimitMask(vertex, posMask, creaseEnds); │ │ │ │ │ +646 assignCreaseLimitTangentMasks(vertex, tan1Mask, tan2Mask, creaseEnds); │ │ │ │ │ +647 } else { │ │ │ │ │ +648 assignCornerLimitMask(vertex, posMask); │ │ │ │ │ +649 assignCornerLimitTangentMasks(vertex, tan1Mask, tan2Mask); │ │ │ │ │ +650 } │ │ │ │ │ +651} │ │ │ │ │ +652 │ │ │ │ │ +653 │ │ │ │ │ +654} // end namespace sdc │ │ │ │ │ +655 │ │ │ │ │ +656} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +657using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +658} // end namespace OpenSubdiv │ │ │ │ │ +659 │ │ │ │ │ +660#endif /* OPENSUBDIV3_SDC_SCHEME_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_p_l_i_t │ │ │ │ │ Split │ │ │ │ │ Enumerated type for all face splitting schemes. │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_P_L_I_T___T_O___T_R_I_S │ │ │ │ │ -@ SPLIT_TO_TRIS │ │ │ │ │ -Used by Loop. │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e │ │ │ │ │ +Types, constants and utilities related to semi-sharp creasing – whose │ │ │ │ │ +implementation is independent o... │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ +Rule │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T │ │ │ │ │ +@ RULE_DART │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H │ │ │ │ │ +@ RULE_SMOOTH │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E │ │ │ │ │ +@ RULE_CREASE │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N │ │ │ │ │ +@ RULE_UNKNOWN │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e │ │ │ │ │ +void GetSharpEdgePairOfCrease(float const *incidentEdgeSharpness, int │ │ │ │ │ +incidentEdgeCount, int sharpEdgePair[2]) const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_2_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e │ │ │ │ │ +Rule DetermineVertexVertexRule(float vertexSharpness, int incidentEdgeCount, │ │ │ │ │ +float const *incidentEdgeSharpness) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_U_n_i_f_o_r_m │ │ │ │ │ +bool IsUniform() const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_C_o_m_p_u_t_e_F_r_a_c_t_i_o_n_a_l_W_e_i_g_h_t_A_t_V_e_r_t_e_x │ │ │ │ │ +float ComputeFractionalWeightAtVertex(float vertexSharpness, float │ │ │ │ │ +childVertexSharpness, int incidentEdgeCount, float const │ │ │ │ │ +*incidentEdgeSharpness, float const *childEdgesSharpness) const │ │ │ │ │ +Transitional weighting: When the rules applicable to a parent vertex and its │ │ │ │ │ +child differ,... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s │ │ │ │ │ +All supported options applying to subdivision scheme. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e │ │ │ │ │ +Scheme is a class template which provides all implementation for the │ │ │ │ │ +subdivision schemes supported by... │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_6_6 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_E_d_g_e │ │ │ │ │ void assignSmoothMaskForEdge(EDGE const &edge, MASK &mask) const │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_T_o_p_o_l_o_g_i_c_a_l_S_p_l_i_t_T_y_p_e │ │ │ │ │ static Split GetTopologicalSplitType() │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ void assignCreaseMaskForVertex(VERTEX const &edge, MASK &mask, int const │ │ │ │ │ creaseEnds[2]) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k │ │ │ │ │ +void ComputeVertexVertexMask(VERTEX const &vertexNeighborhood, MASK │ │ │ │ │ +&vertexVertexMask, Crease::Rule parentRule=Crease::RULE_UNKNOWN, Crease::Rule │ │ │ │ │ +childRule=Crease::RULE_UNKNOWN) const │ │ │ │ │ +Vertex-vertex masks If known, a single Rule or pair of Rules can be specified │ │ │ │ │ +(indicating a crease tr... │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_5_1_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k │ │ │ │ │ +void ComputeVertexLimitMask(VERTEX const &vertexNeighborhood, MASK │ │ │ │ │ +&positionMask, Crease::Rule vertexRule) const │ │ │ │ │ +Limit masks for vertices – position and tangents These presume that a vertex │ │ │ │ │ +is suitably isolated for... │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_6_0_7 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ void assignCreaseLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ &tan2, int const creaseEnds[2]) const │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_R_e_g_u_l_a_r_F_a_c_e_S_i_z_e │ │ │ │ │ static int GetRegularFaceSize() │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e │ │ │ │ │ void assignCreaseMaskForEdge(EDGE const &edge, MASK &mask) const │ │ │ │ │ DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_1_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_C_o_m_p_u_t_e_E_d_g_e_V_e_r_t_e_x_M_a_s_k │ │ │ │ │ +void ComputeEdgeVertexMask(EDGE const &edgeNeighborhood, MASK &edgeVertexMask, │ │ │ │ │ +Crease::Rule parentRule=Crease::RULE_UNKNOWN, Crease::Rule childRule=Crease:: │ │ │ │ │ +RULE_UNKNOWN) const │ │ │ │ │ +Edge-vertex masks If known, the Rule for the edge and/or the derived vertex can │ │ │ │ │ +be specified to accel... │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_9_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_S_c_h_e_m_e │ │ │ │ │ +Scheme() │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_7_0 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_M_a_s_k │ │ │ │ │ void assignSmoothLimitMask(VERTEX const &vertex, MASK &pos) const │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_L_o_c_a_l_N_e_i_g_h_b_o_r_h_o_o_d_S_i_z_e │ │ │ │ │ static int GetLocalNeighborhoodSize() │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ void assignCornerMaskForVertex(VERTEX const &edge, MASK &mask) const │ │ │ │ │ DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_3_1 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_M_a_s_k │ │ │ │ │ void assignCreaseLimitMask(VERTEX const &vertex, MASK &pos, int const │ │ │ │ │ creaseEnds[2]) const │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ void assignSmoothMaskForVertex(VERTEX const &edge, MASK &mask) const │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_R_e_g_u_l_a_r_V_e_r_t_e_x_V_a_l_e_n_c_e │ │ │ │ │ static int GetRegularVertexValence() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_O_p_t_i_o_n_s │ │ │ │ │ +Options GetOptions() const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_7_4 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ void assignSmoothLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ &tan2) const │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_M_a_s_k │ │ │ │ │ void assignCornerLimitMask(VERTEX const &vertex, MASK &pos) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_S_c_h_e_m_e │ │ │ │ │ +Scheme(Options const &options) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_C_o_m_p_u_t_e_F_a_c_e_V_e_r_t_e_x_M_a_s_k │ │ │ │ │ +void ComputeFaceVertexMask(FACE const &faceNeighborhood, MASK &faceVertexMask) │ │ │ │ │ +const │ │ │ │ │ +Face-vertex masks - trivial for all current schemes. │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_4_8 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ void assignCornerLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ &tan2) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_S_e_t_O_p_t_i_o_n_s │ │ │ │ │ +void SetOptions(const Options &newOptions) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_7_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_0_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_W_e_i_g_h_t │ │ │ │ │ +WEIGHT Weight │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_1_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_: │ │ │ │ │ +_A_r_e_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s │ │ │ │ │ +bool AreFaceWeightsForFaceCenters() const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_S_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s │ │ │ │ │ +void SetNumEdgeWeights(int count) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_E_d_g_e_W_e_i_g_h_t │ │ │ │ │ +Weight const & EdgeWeight(int index) const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_E_d_g_e_W_e_i_g_h_t │ │ │ │ │ +Weight & EdgeWeight(int index) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_: │ │ │ │ │ +_C_o_m_b_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k_s │ │ │ │ │ +void CombineVertexVertexMasks(Weight thisCoeff, Weight dstCoeff, USER_MASK │ │ │ │ │ +&dst) const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_4_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_G_e_t_N_u_m_V_e_r_t_e_x_W_e_i_g_h_t_s │ │ │ │ │ +int GetNumVertexWeights() const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_S_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s │ │ │ │ │ +void SetNumFaceWeights(int count) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_F_a_c_e_W_e_i_g_h_t │ │ │ │ │ +Weight const & FaceWeight(int index) const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_G_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s │ │ │ │ │ +int GetNumEdgeWeights() const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_V_e_r_t_e_x_W_e_i_g_h_t │ │ │ │ │ +Weight & VertexWeight(int index) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_G_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s │ │ │ │ │ +int GetNumFaceWeights() const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_: │ │ │ │ │ +_S_e_t_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s │ │ │ │ │ +void SetFaceWeightsForFaceCenters(bool on) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_S_e_t_N_u_m_V_e_r_t_e_x_W_e_i_g_h_t_s │ │ │ │ │ +void SetNumVertexWeights(int count) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_L_o_c_a_l_M_a_s_k │ │ │ │ │ +LocalMask(Weight *v, Weight *e, Weight *f) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_1_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_V_e_r_t_e_x_W_e_i_g_h_t │ │ │ │ │ +Weight const & VertexWeight(int index) const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_F_a_c_e_W_e_i_g_h_t │ │ │ │ │ +Weight & FaceWeight(int index) │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_~_L_o_c_a_l_M_a_s_k │ │ │ │ │ +~LocalMask() │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_1_6 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _s_d_c │ │ │ │ │ - * _l_o_o_p_S_c_h_e_m_e_._h │ │ │ │ │ + * _s_c_h_e_m_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00773.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/sdc/scheme.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/sdc/options.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,34 +90,25 @@ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
scheme.h File Reference
│ │ │ │ +
options.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/types.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ -#include "../sdc/crease.h"
│ │ │ │ -#include <cassert>
│ │ │ │ -#include <cstdlib>
│ │ │ │ -#include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  Scheme< SCHEME_TYPE >
 Scheme is a class template which provides all implementation for the subdivision schemes supported by OpenSubdiv through specializations of the methods of each. An instance of Scheme<SCHEME_TYPE> includes a set of Options that will dictate the variable aspects of its behavior.
│ │ │ │ - More...
 
class  Scheme< SCHEME_TYPE >::LocalMask< WEIGHT >
class  Options
 All supported options applying to subdivision scheme. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -126,13 +117,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,35 +1,23 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -scheme.h File Reference │ │ │ │ │ +options.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_s_d_c_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ -#include "_._._/_s_d_c_/_c_r_e_a_s_e_._h" │ │ │ │ │ -#include │ │ │ │ │ -#include │ │ │ │ │ -#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _S_c_h_e_m_e_<_ _S_C_H_E_M_E___T_Y_P_E_ _> │ │ │ │ │ - _S_c_h_e_m_e is a class template which provides all implementation for the │ │ │ │ │ - subdivision schemes supported by _O_p_e_n_S_u_b_d_i_v through specializations of │ │ │ │ │ -  the methods of each. An instance of Scheme includes a set │ │ │ │ │ - of _O_p_t_i_o_n_s that will dictate the variable aspects of its behavior. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -class   _S_c_h_e_m_e_<_ _S_C_H_E_M_E___T_Y_P_E_ _>_:_:_L_o_c_a_l_M_a_s_k_<_ _W_E_I_G_H_T_ _> │ │ │ │ │ +class   _O_p_t_i_o_n_s │ │ │ │ │ +  All supported options applying to subdivision scheme. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _s_d_c │ │ │ │ │ - * _s_c_h_e_m_e_._h │ │ │ │ │ + * _o_p_t_i_o_n_s_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00773.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,3 @@ │ │ │ │ │ var a00773 = [ │ │ │ │ │ - ["Scheme< SCHEME_TYPE >", "a01341.html", "a01341"], │ │ │ │ │ - ["LocalMask< WEIGHT >", "a01345.html", "a01345"] │ │ │ │ │ + ["Options", "a01337.html", "a01337"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00773_source.html │ │ │ │ @@ -22,8471 +22,2397 @@ │ │ │ │ 00000150: 656e 743d 2244 6f78 7967 656e 2031 2e39 ent="Doxygen 1.9 │ │ │ │ 00000160: 2e38 222f 3e0a 3c6d 6574 6120 6e61 6d65 .8"/>..OpenSubdiv: o │ │ │ │ -000001c0: 7065 6e73 7562 6469 762f 7364 632f 7363 pensubdiv/sdc/sc │ │ │ │ -000001d0: 6865 6d65 2e68 2053 6f75 7263 6520 4669 heme.h Source Fi │ │ │ │ -000001e0: 6c65 3c2f 7469 746c 653e 0a3c 6c69 6e6b le...... │ │ │ │ -00000310: 3c73 6372 6970 7420 7479 7065 3d22 7465 .........
.
. │ │ │ │ -00000530: 3c74 6162 6c65 2063 656c 6c73 7061 6369 . │ │ │ │ -00000560: 0a20 3c74 7220 6964 3d22 7072 6f6a 6563 . . . . .
│ │ │ │ -000005c0: 3c2f 7464 3e0a 2020 3c74 6420 6964 3d22 . │ │ │ │ -000005e0: 2020 3c64 6976 2069 643d 2270 726f 6a65
OpenSubd │ │ │ │ -00000600: 6976 0a20 2020 3c2f 6469 763e 0a20 203c iv.
. < │ │ │ │ -00000610: 2f74 643e 0a20 3c2f 7472 3e0a 203c 2f74 /td>.
.< │ │ │ │ -00000630: 2f64 6976 3e0a 3c21 2d2d 2065 6e64 2068 /div>..< │ │ │ │ -00000650: 212d 2d20 4765 6e65 7261 7465 6420 6279 !-- Generated by │ │ │ │ -00000660: 2044 6f78 7967 656e 2031 2e39 2e38 202d Doxygen 1.9.8 - │ │ │ │ -00000670: 2d3e 0a3c 7363 7269 7074 2074 7970 653d ->.. │ │ │ │ -00000750: 3c73 6372 6970 7420 7479 7065 3d22 7465 ...
...
.. │ │ │ │ -00000d00: 3c21 2d2d 2069 6672 616d 6520 7368 6f77 .< │ │ │ │ -00000d40: 6469 7620 6964 3d22 4d53 6561 7263 6852 div id="MSearchR │ │ │ │ -00000d50: 6573 756c 7473 5769 6e64 6f77 223e 0a3c esultsWindow">.< │ │ │ │ -00000d60: 6469 7620 6964 3d22 4d53 6561 7263 6852 div id="MSearchR │ │ │ │ -00000d70: 6573 756c 7473 223e 0a3c 6469 7620 636c esults">.
. │ │ │ │ -00000da0: 0a3c 6469 7620 6964 3d22 5352 5265 7375 .
.
L │ │ │ │ -00000de0: 6f61 6469 6e67 2e2e 2e3c 2f64 6976 3e0a oading...
. │ │ │ │ -00000df0: 3c64 6976 2063 6c61 7373 3d22 5352 5374 .
No │ │ │ │ -00000e50: 4d61 7463 6865 733c 2f64 6976 3e0a 3c2f Matches
..
..
..
. │ │ │ │ -00000e90: 2020 3c64 6976 2063 6c61 7373 3d22 6865
sc │ │ │ │ -00000ec0: 6865 6d65 2e68 3c2f 6469 763e 3c2f 6469 heme.h
.
.
.Go to the do │ │ │ │ -00000f20: 6375 6d65 6e74 6174 696f 6e20 6f66 2074 cumentation of t │ │ │ │ -00000f30: 6869 7320 6669 6c65 2e3c 2f61 3e3c 6469 his file.
1 │ │ │ │ -00000fa0: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 //< │ │ │ │ -00000fc0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -00000fe0: 6120 6964 3d22 6c30 3030 3032 2220 6e61 a id="l00002" na │ │ │ │ -00000ff0: 6d65 3d22 6c30 3030 3032 223e 3c2f 613e me="l00002"> │ │ │ │ -00001000: 3c73 7061 6e20 636c 6173 733d 226c 696e 2// Copy │ │ │ │ -00001040: 7269 6768 7420 3230 3134 2044 7265 616d right 2014 Dream │ │ │ │ -00001050: 576f 726b 7320 416e 696d 6174 696f 6e20 Works Animation │ │ │ │ -00001060: 4c4c 432e 3c2f 7370 616e 3e3c 2f64 6976 LLC.
.
3< │ │ │ │ -000010c0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>//
.
< │ │ │ │ -00001120: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00001130: 6e6f 223e 2020 2020 343c 2f73 7061 6e3e no"> 4 │ │ │ │ -00001140: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // Licen │ │ │ │ -00001160: 7365 6420 756e 6465 7220 7468 6520 4170 sed under the Ap │ │ │ │ -00001170: 6163 6865 204c 6963 656e 7365 2c20 5665 ache License, Ve │ │ │ │ -00001180: 7273 696f 6e20 322e 3020 2874 6865 2026 rsion 2.0 (the & │ │ │ │ -00001190: 7175 6f74 3b41 7061 6368 6520 4c69 6365 quot;Apache Lice │ │ │ │ -000011a0: 6e73 6526 7175 6f74 3b29 3c2f 7370 616e nse")
.
│ │ │ │ -00001200: 2020 2020 353c 2f73 7061 6e3e 3c73 7061 5// with the │ │ │ │ -00001230: 666f 6c6c 6f77 696e 6720 6d6f 6469 6669 following modifi │ │ │ │ -00001240: 6361 7469 6f6e 3b20 796f 7520 6d61 7920 cation; you may │ │ │ │ -00001250: 6e6f 7420 7573 6520 7468 6973 2066 696c not use this fil │ │ │ │ -00001260: 6520 6578 6365 7074 2069 6e3c 2f73 7061 e except in
.
6// complian │ │ │ │ -000012f0: 6365 2077 6974 6820 7468 6520 4170 6163 ce with the Apac │ │ │ │ -00001300: 6865 204c 6963 656e 7365 2061 6e64 2074 he License and t │ │ │ │ -00001310: 6865 2066 6f6c 6c6f 7769 6e67 206d 6f64 he following mod │ │ │ │ -00001320: 6966 6963 6174 696f 6e20 746f 2069 743a ification to it: │ │ │ │ -00001330: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00001350: 3c61 2069 643d 226c 3030 3030 3722 206e 7// Sec │ │ │ │ -000013b0: 7469 6f6e 2036 2e20 5472 6164 656d 6172 tion 6. Trademar │ │ │ │ -000013c0: 6b73 2e20 6973 2064 656c 6574 6564 2061 ks. is deleted a │ │ │ │ -000013d0: 6e64 2072 6570 6c61 6365 6420 7769 7468 nd replaced with │ │ │ │ -000013e0: 3a3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c :
.< │ │ │ │ -000013f0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00001400: 3e3c 6120 6964 3d22 6c30 3030 3038 2220 > 8//
.
9// 6. Trade │ │ │ │ -000014e0: 6d61 726b 732e 2054 6869 7320 4c69 6365 marks. This Lice │ │ │ │ -000014f0: 6e73 6520 646f 6573 206e 6f74 2067 7261 nse does not gra │ │ │ │ -00001500: 6e74 2070 6572 6d69 7373 696f 6e20 746f nt permission to │ │ │ │ -00001510: 2075 7365 2074 6865 2074 7261 6465 3c2f use the trade
.
< │ │ │ │ -00001560: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00001570: 6e6f 223e 2020 2031 303c 2f73 7061 6e3e no"> 10 │ │ │ │ -00001580: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // na │ │ │ │ -000015a0: 6d65 732c 2074 7261 6465 6d61 726b 732c mes, trademarks, │ │ │ │ -000015b0: 2073 6572 7669 6365 206d 6172 6b73 2c20 service marks, │ │ │ │ -000015c0: 6f72 2070 726f 6475 6374 206e 616d 6573 or product names │ │ │ │ -000015d0: 206f 6620 7468 6520 4c69 6365 6e73 6f72 of the Licensor │ │ │ │ -000015e0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00001600: 3c61 2069 643d 226c 3030 3031 3122 206e 11// │ │ │ │ -00001660: 616e 6420 6974 7320 6166 6669 6c69 6174 and its affiliat │ │ │ │ -00001670: 6573 2c20 6578 6365 7074 2061 7320 7265 es, except as re │ │ │ │ -00001680: 7175 6972 6564 2074 6f20 636f 6d70 6c79 quired to comply │ │ │ │ -00001690: 2077 6974 6820 5365 6374 696f 6e20 3428 with Section 4( │ │ │ │ -000016a0: 6329 206f 663c 2f73 7061 6e3e 3c2f 6469 c) of.
12 │ │ │ │ -00001700: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ -00001720: 2020 2020 2074 6865 204c 6963 656e 7365 the License │ │ │ │ -00001730: 2061 6e64 2074 6f20 7265 7072 6f64 7563 and to reproduc │ │ │ │ -00001740: 6520 7468 6520 636f 6e74 656e 7420 6f66 e the content of │ │ │ │ -00001750: 2074 6865 204e 4f54 4943 4520 6669 6c65 the NOTICE file │ │ │ │ -00001760: 2e3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c .
.< │ │ │ │ -00001770: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00001780: 3e3c 6120 6964 3d22 6c30 3030 3133 2220 > 13//
.
14// You may │ │ │ │ -00001860: 6f62 7461 696e 2061 2063 6f70 7920 6f66 obtain a copy of │ │ │ │ -00001870: 2074 6865 2041 7061 6368 6520 4c69 6365 the Apache Lice │ │ │ │ -00001880: 6e73 6520 6174 3c2f 7370 616e 3e3c 2f64 nse at.
1 │ │ │ │ -000018e0: 353c 2f73 7061 6e3e 3c73 7061 6e20 636c 5// │ │ │ │ -00001900: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00001920: 3c61 2069 643d 226c 3030 3031 3622 206e 16
// │ │ │ │ -00001980: 2068 7474 703a 2f2f 7777 772e 6170 6163 http://www.apac │ │ │ │ -00001990: 6865 2e6f 7267 2f6c 6963 656e 7365 732f he.org/licenses/ │ │ │ │ -000019a0: 4c49 4345 4e53 452d 322e 303c 2f73 7061 LICENSE-2.0
.
17//.
18 │ │ │ │ -00001a80: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ -00001aa0: 2020 556e 6c65 7373 2072 6571 7569 7265 Unless require │ │ │ │ -00001ab0: 6420 6279 2061 7070 6c69 6361 626c 6520 d by applicable │ │ │ │ -00001ac0: 6c61 7720 6f72 2061 6772 6565 6420 746f law or agreed to │ │ │ │ -00001ad0: 2069 6e20 7772 6974 696e 672c 2073 6f66 in writing, sof │ │ │ │ -00001ae0: 7477 6172 653c 2f73 7061 6e3e 3c2f 6469 tware.
19 │ │ │ │ -00001b40: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ -00001b60: 2020 6469 7374 7269 6275 7465 6420 756e distributed un │ │ │ │ -00001b70: 6465 7220 7468 6520 4170 6163 6865 204c der the Apache L │ │ │ │ -00001b80: 6963 656e 7365 2077 6974 6820 7468 6520 icense with the │ │ │ │ -00001b90: 6162 6f76 6520 6d6f 6469 6669 6361 7469 above modificati │ │ │ │ -00001ba0: 6f6e 2069 733c 2f73 7061 6e3e 3c2f 6469 on is.
20 │ │ │ │ -00001c00: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ -00001c20: 2020 6469 7374 7269 6275 7465 6420 6f6e distributed on │ │ │ │ -00001c30: 2061 6e20 2671 756f 743b 4153 2049 5326 an "AS IS& │ │ │ │ -00001c40: 7175 6f74 3b20 4241 5349 532c 2057 4954 quot; BASIS, WIT │ │ │ │ -00001c50: 484f 5554 2057 4152 5241 4e54 4945 5320 HOUT WARRANTIES │ │ │ │ -00001c60: 4f52 2043 4f4e 4449 5449 4f4e 5320 4f46 OR CONDITIONS OF │ │ │ │ -00001c70: 2041 4e59 3c2f 7370 616e 3e3c 2f64 6976 ANY
.
21< │ │ │ │ -00001cd0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -00001cf0: 204b 494e 442c 2065 6974 6865 7220 6578 KIND, either ex │ │ │ │ -00001d00: 7072 6573 7320 6f72 2069 6d70 6c69 6564 press or implied │ │ │ │ -00001d10: 2e20 5365 6520 7468 6520 4170 6163 6865 . See the Apache │ │ │ │ -00001d20: 204c 6963 656e 7365 2066 6f72 2074 6865 License for the │ │ │ │ -00001d30: 2073 7065 6369 6669 633c 2f73 7061 6e3e specific │ │ │ │ -00001d40: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00001d90: 2020 3232 3c2f 7370 616e 3e3c 7370 616e 22// language g │ │ │ │ -00001dc0: 6f76 6572 6e69 6e67 2070 6572 6d69 7373 overning permiss │ │ │ │ -00001dd0: 696f 6e73 2061 6e64 206c 696d 6974 6174 ions and limitat │ │ │ │ -00001de0: 696f 6e73 2075 6e64 6572 2074 6865 2041 ions under the A │ │ │ │ -00001df0: 7061 6368 6520 4c69 6365 6e73 652e 3c2f pache License.
.
< │ │ │ │ -00001e40: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00001e50: 6e6f 223e 2020 2032 333c 2f73 7061 6e3e no"> 23 │ │ │ │ -00001e60: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ -00001e80: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00001ed0: 2032 343c 2f73 7061 6e3e 3c73 7061 6e20 24#ifndef OPE │ │ │ │ -00001f00: 4e53 5542 4449 5633 5f53 4443 5f53 4348 NSUBDIV3_SDC_SCH │ │ │ │ -00001f10: 454d 455f 483c 2f73 7061 6e3e 3c2f 6469 EME_H.
25 │ │ │ │ -00001f70: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 #define OPENSU │ │ │ │ -00001fa0: 4244 4956 335f 5344 435f 5343 4845 4d45 BDIV3_SDC_SCHEME │ │ │ │ -00001fb0: 5f48 3c2f 7370 616e 3e3c 2f64 6976 3e0a _H
. │ │ │ │ -00001fc0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ -00002050: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00002060: 6e6f 223e 2020 2032 373c 2f73 7061 6e3e no"> 27 │ │ │ │ -00002070: 3c73 7061 6e20 636c 6173 733d 2270 7265 #incl │ │ │ │ -00002090: 7564 6520 2671 756f 743b 2e2e 2f76 6572 ude "../ver │ │ │ │ -000020a0: 7369 6f6e 2e68 2671 756f 743b 3c2f 7370 sion.h"
.
28 < │ │ │ │ -00002110: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00002160: 2032 393c 2f73 7061 6e3e 3c73 7061 6e20 29#include &q │ │ │ │ -00002190: 756f 743b 2e2e 2f73 6463 2f74 7970 6573 uot;../sdc/types │ │ │ │ -000021a0: 2e68 2671 756f 743b 3c2f 7370 616e 3e3c .h"< │ │ │ │ -000021b0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00002200: 2033 303c 2f73 7061 6e3e 3c73 7061 6e20 30#include &q │ │ │ │ -00002230: 756f 743b 2e2e 2f73 6463 2f6f 7074 696f uot;../sdc/optio │ │ │ │ -00002240: 6e73 2e68 2671 756f 743b 3c2f 7370 616e ns.h"
.
│ │ │ │ -000022a0: 2020 2033 313c 2f73 7061 6e3e 3c73 7061 31#include │ │ │ │ -000022d0: 2671 756f 743b 2e2e 2f73 6463 2f63 7265 "../sdc/cre │ │ │ │ -000022e0: 6173 652e 6826 7175 6f74 3b3c 2f73 7061 ase.h"
.
32 ..... │ │ │ │ +00000310: 0a3c 7363 7269 7074 2074 7970 653d 2274 ..< │ │ │ │ +00000350: 7363 7269 7074 2074 7970 653d 2274 6578 script type="tex │ │ │ │ +00000360: 742f 6a61 7661 7363 7269 7074 2220 7372 t/javascript" sr │ │ │ │ +00000370: 633d 226e 6176 7472 6565 2e6a 7322 3e3c c="navtree.js">< │ │ │ │ +00000380: 2f73 6372 6970 743e 0a3c 6c69 6e6b 2068 /script>...< │ │ │ │ +00000410: 7363 7269 7074 2074 7970 653d 2274 6578 script type="tex │ │ │ │ +00000420: 742f 6a61 7661 7363 7269 7074 2220 7372 t/javascript" sr │ │ │ │ +00000430: 633d 2273 6561 7263 682f 7365 6172 6368 c="search/search │ │ │ │ +00000440: 2e6a 7322 3e3c 2f73 6372 6970 743e 0a3c .js">.< │ │ │ │ +00000450: 6c69 6e6b 2068 7265 663d 2264 6f78 7967 link href="doxyg │ │ │ │ +00000460: 656e 2e63 7373 2220 7265 6c3d 2273 7479 en.css" rel="sty │ │ │ │ +00000470: 6c65 7368 6565 7422 2074 7970 653d 2274 lesheet" type="t │ │ │ │ +00000480: 6578 742f 6373 7322 202f 3e0a 3c6c 696e ext/css" />....
.
│ │ │ │ +00000530: 0a3c 7461 626c 6520 6365 6c6c 7370 6163 .. . . . . . .
< │ │ │ │ +00000590: 696d 6720 616c 743d 224c 6f67 6f22 2073 img alt="Logo" s │ │ │ │ +000005a0: 7263 3d22 6f70 656e 7375 6264 6976 5f6c rc="opensubdiv_l │ │ │ │ +000005b0: 6f67 6f5f 6865 6164 6572 2e70 6e67 222f ogo_header.png"/ │ │ │ │ +000005c0: 3e3c 2f74 643e 0a20 203c 7464 2069 643d >. │ │ │ │ +000005e0: 2020 203c 6469 7620 6964 3d22 7072 6f6a
OpenSub │ │ │ │ +00000600: 6469 760a 2020 203c 2f64 6976 3e0a 2020 div.
. │ │ │ │ +00000610: 3c2f 7464 3e0a 203c 2f74 723e 0a20 3c2f
. │ │ │ │ +00000630: 3c2f 6469 763e 0a3c 212d 2d20 656e 6420
.. │ │ │ │ +00000650: 3c21 2d2d 2047 656e 6572 6174 6564 2062 . │ │ │ │ +00000750: 0a3c 7363 7269 7074 2074 7970 653d 2274 ....
...
. │ │ │ │ +00000d00: 0a3c 212d 2d20 6966 7261 6d65 2073 686f .. │ │ │ │ +00000d40: 3c64 6976 2069 643d 224d 5365 6172 6368
. │ │ │ │ +00000d60: 3c64 6976 2069 643d 224d 5365 6172 6368
.
.< │ │ │ │ +00000d90: 6469 7620 6964 3d22 5352 496e 6465 7822 div id="SRIndex" │ │ │ │ +00000da0: 3e0a 3c64 6976 2069 643d 2253 5252 6573 >.
. │ │ │ │ +00000de0: 4c6f 6164 696e 672e 2e2e 3c2f 6469 763e Loading...
│ │ │ │ +00000df0: 0a3c 6469 7620 636c 6173 733d 2253 5253 .
Searching. │ │ │ │ +00000e20: 2e2e 3c2f 6469 763e 0a3c 6469 7620 636c ..
.
No │ │ │ │ +00000e50: 204d 6174 6368 6573 3c2f 6469 763e 0a3c Matches
.< │ │ │ │ +00000e60: 2f64 6976 3e0a 3c2f 6469 763e 0a3c 2f64 /div>.
..
..
│ │ │ │ +00000e90: 0a20 203c 6469 7620 636c 6173 733d 2268 .
o │ │ │ │ +00000ec0: 7074 696f 6e73 2e68 3c2f 6469 763e 3c2f ptions.h
.
.
. │ │ │ │ +00000f00: 3c61 2068 7265 663d 2261 3030 3737 332e Go to the │ │ │ │ +00000f20: 646f 6375 6d65 6e74 6174 696f 6e20 6f66 documentation of │ │ │ │ +00000f30: 2074 6869 7320 6669 6c65 2e3c 2f61 3e3c this file.< │ │ │ │ +00000f40: 6469 7620 636c 6173 733d 2266 7261 676d div class="fragm │ │ │ │ +00000f50: 656e 7422 3e3c 6469 7620 636c 6173 733d ent">
│ │ │ │ +00000fa0: 2031 3c2f 7370 616e 3e3c 7370 616e 2063 1/ │ │ │ │ +00000fc0: 2f3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c /
.< │ │ │ │ +00000fd0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00000fe0: 3e3c 6120 6964 3d22 6c30 3030 3032 2220 > 2// Co │ │ │ │ +00001040: 7079 7269 6768 7420 3230 3134 2044 7265 pyright 2014 Dre │ │ │ │ +00001050: 616d 576f 726b 7320 416e 696d 6174 696f amWorks Animatio │ │ │ │ +00001060: 6e20 4c4c 432e 3c2f 7370 616e 3e3c 2f64 n LLC..
│ │ │ │ +000010c0: 333c 2f73 7061 6e3e 3c73 7061 6e20 636c 3// │ │ │ │ +000010e0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00001100: 3c61 2069 643d 226c 3030 3030 3422 206e 4// Lic │ │ │ │ +00001160: 656e 7365 6420 756e 6465 7220 7468 6520 ensed under the │ │ │ │ +00001170: 4170 6163 6865 204c 6963 656e 7365 2c20 Apache License, │ │ │ │ +00001180: 5665 7273 696f 6e20 322e 3020 2874 6865 Version 2.0 (the │ │ │ │ +00001190: 2026 7175 6f74 3b41 7061 6368 6520 4c69 "Apache Li │ │ │ │ +000011a0: 6365 6e73 6526 7175 6f74 3b29 3c2f 7370 cense")
.
5// with th │ │ │ │ +00001230: 6520 666f 6c6c 6f77 696e 6720 6d6f 6469 e following modi │ │ │ │ +00001240: 6669 6361 7469 6f6e 3b20 796f 7520 6d61 fication; you ma │ │ │ │ +00001250: 7920 6e6f 7420 7573 6520 7468 6973 2066 y not use this f │ │ │ │ +00001260: 696c 6520 6578 6365 7074 2069 6e3c 2f73 ile except in
.
6< │ │ │ │ +000012d0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +000012e0: 656e 7422 3e2f 2f20 2020 636f 6d70 6c69 ent">// compli │ │ │ │ +000012f0: 616e 6365 2077 6974 6820 7468 6520 4170 ance with the Ap │ │ │ │ +00001300: 6163 6865 204c 6963 656e 7365 2061 6e64 ache License and │ │ │ │ +00001310: 2074 6865 2066 6f6c 6c6f 7769 6e67 206d the following m │ │ │ │ +00001320: 6f64 6966 6963 6174 696f 6e20 746f 2069 odification to i │ │ │ │ +00001330: 743a 3c2f 7370 616e 3e3c 2f64 6976 3e0a t:
. │ │ │ │ +00001340: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 │ │ │ │ +000013f0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
.
9< │ │ │ │ +000014c0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +000014d0: 656e 7422 3e2f 2f20 2020 362e 2054 7261 ent">// 6. Tra │ │ │ │ +000014e0: 6465 6d61 726b 732e 2054 6869 7320 4c69 demarks. This Li │ │ │ │ +000014f0: 6365 6e73 6520 646f 6573 206e 6f74 2067 cense does not g │ │ │ │ +00001500: 7261 6e74 2070 6572 6d69 7373 696f 6e20 rant permission │ │ │ │ +00001510: 746f 2075 7365 2074 6865 2074 7261 6465 to use the trade │ │ │ │ +00001520: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00001540: 3c61 2069 643d 226c 3030 3031 3022 206e 10// │ │ │ │ +000015a0: 6e61 6d65 732c 2074 7261 6465 6d61 726b names, trademark │ │ │ │ +000015b0: 732c 2073 6572 7669 6365 206d 6172 6b73 s, service marks │ │ │ │ +000015c0: 2c20 6f72 2070 726f 6475 6374 206e 616d , or product nam │ │ │ │ +000015d0: 6573 206f 6620 7468 6520 4c69 6365 6e73 es of the Licens │ │ │ │ +000015e0: 6f72 3c2f 7370 616e 3e3c 2f64 6976 3e0a or
. │ │ │ │ +000015f0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ +00001620: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 11// │ │ │ │ +00001660: 2020 616e 6420 6974 7320 6166 6669 6c69 and its affili │ │ │ │ +00001670: 6174 6573 2c20 6578 6365 7074 2061 7320 ates, except as │ │ │ │ +00001680: 7265 7175 6972 6564 2074 6f20 636f 6d70 required to comp │ │ │ │ +00001690: 6c79 2077 6974 6820 5365 6374 696f 6e20 ly with Section │ │ │ │ +000016a0: 3428 6329 206f 663c 2f73 7061 6e3e 3c2f 4(c) of.
│ │ │ │ +00001700: 3132 3c2f 7370 616e 3e3c 7370 616e 2063 12/ │ │ │ │ +00001720: 2f20 2020 2020 2074 6865 204c 6963 656e / the Licen │ │ │ │ +00001730: 7365 2061 6e64 2074 6f20 7265 7072 6f64 se and to reprod │ │ │ │ +00001740: 7563 6520 7468 6520 636f 6e74 656e 7420 uce the content │ │ │ │ +00001750: 6f66 2074 6865 204e 4f54 4943 4520 6669 of the NOTICE fi │ │ │ │ +00001760: 6c65 2e3c 2f73 7061 6e3e 3c2f 6469 763e le.
│ │ │ │ +00001770: 0a3c 6469 7620 636c 6173 733d 226c 696e ..
14< │ │ │ │ +00001840: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00001850: 656e 7422 3e2f 2f20 2020 596f 7520 6d61 ent">// You ma │ │ │ │ +00001860: 7920 6f62 7461 696e 2061 2063 6f70 7920 y obtain a copy │ │ │ │ +00001870: 6f66 2074 6865 2041 7061 6368 6520 4c69 of the Apache Li │ │ │ │ +00001880: 6365 6e73 6520 6174 3c2f 7370 616e 3e3c cense at< │ │ │ │ +00001890: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +000018e0: 2031 353c 2f73 7061 6e3e 3c73 7061 6e20 15 │ │ │ │ +00001900: 2f2f 3c2f 7370 616e 3e3c 2f64 6976 3e0a //
. │ │ │ │ +00001910: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
17< │ │ │ │ +00001a10: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +00001a20: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
│ │ │ │ +00001a80: 3138 3c2f 7370 616e 3e3c 7370 616e 2063 18/ │ │ │ │ +00001aa0: 2f20 2020 556e 6c65 7373 2072 6571 7569 / Unless requi │ │ │ │ +00001ab0: 7265 6420 6279 2061 7070 6c69 6361 626c red by applicabl │ │ │ │ +00001ac0: 6520 6c61 7720 6f72 2061 6772 6565 6420 e law or agreed │ │ │ │ +00001ad0: 746f 2069 6e20 7772 6974 696e 672c 2073 to in writing, s │ │ │ │ +00001ae0: 6f66 7477 6172 653c 2f73 7061 6e3e 3c2f oftware.
│ │ │ │ +00001b40: 3139 3c2f 7370 616e 3e3c 7370 616e 2063 19/ │ │ │ │ +00001b60: 2f20 2020 6469 7374 7269 6275 7465 6420 / distributed │ │ │ │ +00001b70: 756e 6465 7220 7468 6520 4170 6163 6865 under the Apache │ │ │ │ +00001b80: 204c 6963 656e 7365 2077 6974 6820 7468 License with th │ │ │ │ +00001b90: 6520 6162 6f76 6520 6d6f 6469 6669 6361 e above modifica │ │ │ │ +00001ba0: 7469 6f6e 2069 733c 2f73 7061 6e3e 3c2f tion is.
│ │ │ │ +00001c00: 3230 3c2f 7370 616e 3e3c 7370 616e 2063 20/ │ │ │ │ +00001c20: 2f20 2020 6469 7374 7269 6275 7465 6420 / distributed │ │ │ │ +00001c30: 6f6e 2061 6e20 2671 756f 743b 4153 2049 on an "AS I │ │ │ │ +00001c40: 5326 7175 6f74 3b20 4241 5349 532c 2057 S" BASIS, W │ │ │ │ +00001c50: 4954 484f 5554 2057 4152 5241 4e54 4945 ITHOUT WARRANTIE │ │ │ │ +00001c60: 5320 4f52 2043 4f4e 4449 5449 4f4e 5320 S OR CONDITIONS │ │ │ │ +00001c70: 4f46 2041 4e59 3c2f 7370 616e 3e3c 2f64 OF ANY.
2 │ │ │ │ +00001cd0: 313c 2f73 7061 6e3e 3c73 7061 6e20 636c 1// │ │ │ │ +00001cf0: 2020 204b 494e 442c 2065 6974 6865 7220 KIND, either │ │ │ │ +00001d00: 6578 7072 6573 7320 6f72 2069 6d70 6c69 express or impli │ │ │ │ +00001d10: 6564 2e20 5365 6520 7468 6520 4170 6163 ed. See the Apac │ │ │ │ +00001d20: 6865 204c 6963 656e 7365 2066 6f72 2074 he License for t │ │ │ │ +00001d30: 6865 2073 7065 6369 6669 633c 2f73 7061 he specific
.
22// language │ │ │ │ +00001dc0: 2067 6f76 6572 6e69 6e67 2070 6572 6d69 governing permi │ │ │ │ +00001dd0: 7373 696f 6e73 2061 6e64 206c 696d 6974 ssions and limit │ │ │ │ +00001de0: 6174 696f 6e73 2075 6e64 6572 2074 6865 ations under the │ │ │ │ +00001df0: 2041 7061 6368 6520 4c69 6365 6e73 652e Apache License. │ │ │ │ +00001e00: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ +00001e20: 3c61 2069 643d 226c 3030 3032 3322 206e 23//
.
│ │ │ │ +00001ed0: 2020 2032 343c 2f73 7061 6e3e 3c73 7061 24#ifndef O │ │ │ │ +00001f00: 5045 4e53 5542 4449 5633 5f53 4443 5f4f PENSUBDIV3_SDC_O │ │ │ │ +00001f10: 5054 494f 4e53 5f48 3c2f 7370 616e 3e3c PTIONS_H< │ │ │ │ +00001f20: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00001f70: 2032 353c 2f73 7061 6e3e 3c73 7061 6e20 25#define OPE │ │ │ │ +00001fa0: 4e53 5542 4449 5633 5f53 4443 5f4f 5054 NSUBDIV3_SDC_OPT │ │ │ │ +00001fb0: 494f 4e53 5f48 3c2f 7370 616e 3e3c 2f64 IONS_H.
2 │ │ │ │ +00002010: 363c 2f73 7061 6e3e 203c 2f64 6976 3e0a 6
. │ │ │ │ +00002020: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
. │ │ │ │ +000020d0: 3c61 2069 643d 226c 3030 3032 3822 206e 28
..
< │ │ │ │ +00002210: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00002220: 6e6f 223e 2020 2033 303c 2f73 7061 6e3e no"> 30 │ │ │ │ +00002230: 3c73 7061 6e20 636c 6173 733d 226b 6579 namespace │ │ │ │ +00002250: 3c2f 7370 616e 3e4f 5045 4e53 5542 4449 OPENSUBDI │ │ │ │ +00002260: 565f 5645 5253 494f 4e20 7b3c 2f64 6976 V_VERSION {
.
31< │ │ │ │ +000022c0: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ +000022e0: 3c61 2069 643d 226c 3030 3033 3222 206e 32namespac │ │ │ │ +00002340: 6520 3c2f 7370 616e 3e53 6463 207b 3c2f e Sdc {.
│ │ │ │ -000023a0: 3333 3c2f 7370 616e 3e3c 7370 616e 2063 33#include < │ │ │ │ -000023d0: 3b63 6173 7365 7274 2667 743b 3c2f 7370 ;cassert>
.
34#includ │ │ │ │ -00002460: 6520 266c 743b 6373 7464 6c69 6226 6774 e <cstdlib> │ │ │ │ -00002470: 3b3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c ;
.< │ │ │ │ -00002480: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00002490: 3e3c 6120 6964 3d22 6c30 3030 3335 2220 > 35#i │ │ │ │ -000024f0: 6e63 6c75 6465 2026 6c74 3b76 6563 746f nclude <vecto │ │ │ │ -00002500: 7226 6774 3b3c 2f73 7061 6e3e 3c2f 6469 r>.
36 │ │ │ │ -00002560: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ -00002570: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00002580: 3e3c 6120 6964 3d22 6c30 3030 3337 2220 > 37namespa │ │ │ │ -000025e0: 6365 203c 2f73 7061 6e3e 3c61 2063 6c61 ce OpenSu │ │ │ │ -00002620: 6264 6976 3c2f 613e 207b 3c2f 6469 763e bdiv {
│ │ │ │ -00002630: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00002660: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 38names │ │ │ │ -000026a0: 7061 6365 203c 2f73 7061 6e3e 4f50 454e pace OPEN │ │ │ │ -000026b0: 5355 4244 4956 5f56 4552 5349 4f4e 207b SUBDIV_VERSION { │ │ │ │ -000026c0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00002710: 2020 3339 3c2f 7370 616e 3e20 3c2f 6469 39 .
40 │ │ │ │ -00002770: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 nam │ │ │ │ -00002790: 6573 7061 6365 203c 2f73 7061 6e3e 5364 espace Sd │ │ │ │ -000027a0: 6320 7b3c 2f64 6976 3e0a 3c64 6976 2063 c {
.
41 < │ │ │ │ -00002800: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00002850: 2036 353c 2f73 7061 6e3e 3c73 7061 6e20 65 │ │ │ │ -00002870: 7465 6d70 6c61 7465 3c2f 7370 616e 3e20 template │ │ │ │ -00002880: 266c 743b 5363 6865 6d65 5479 7065 2053 <SchemeType S │ │ │ │ -00002890: 4348 454d 455f 5459 5045 2667 743b 3c2f CHEME_TYPE>.
.
< │ │ │ │ -00002920: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00002930: 6e6f 223e 3c61 2063 6c61 7373 3d22 6c69 no"> 66 │ │ │ │ -00002960: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 cla │ │ │ │ -00002980: 7373 203c 2f73 7061 6e3e 3c61 2063 6c61 ss Scheme │ │ │ │ -000029c0: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
67 .
│ │ │ │ -00002a70: 3638 3c2f 7370 616e 3e3c 7370 616e 2063 68p │ │ │ │ -00002a90: 7562 6c69 633c 2f73 7061 6e3e 3a3c 2f64 ublic:.
6 │ │ │ │ -00002af0: 393c 2f73 7061 6e3e 203c 2f64 6976 3e0a 9
. │ │ │ │ -00002b00: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -00002b30: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> │ │ │ │ -00002b90: 3730 3c2f 613e 3c2f 7370 616e 3e20 2020 70 │ │ │ │ -00002ba0: 203c 6120 636c 6173 733d 2263 6f64 6520 Scheme() : │ │ │ │ -00002c00: 205f 6f70 7469 6f6e 7328 2920 7b20 7d3c _options() { }< │ │ │ │ -00002c10: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00002c60: 2037 313c 2f73 7061 6e3e 203c 2f64 6976 71
.
│ │ │ │ -00002d00: 2020 3732 3c2f 613e 3c2f 7370 616e 3e20 72 │ │ │ │ -00002d10: 2020 203c 6120 636c 6173 733d 2263 6f64 Scheme(< │ │ │ │ -00002d70: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00002d80: 5f63 6c61 7373 2220 6872 6566 3d22 6130 _class" href="a0 │ │ │ │ -00002d90: 3133 3337 2e68 746d 6c22 3e4f 7074 696f 1337.html">Optio │ │ │ │ -00002da0: 6e73 3c2f 613e 203c 7370 616e 2063 6c61 ns con │ │ │ │ -00002dc0: 7374 3c2f 7370 616e 3e26 616d 703b 206f st& o │ │ │ │ -00002dd0: 7074 696f 6e73 2920 3a20 5f6f 7074 696f ptions) : _optio │ │ │ │ -00002de0: 6e73 286f 7074 696f 6e73 2920 7b20 7d3c ns(options) { }< │ │ │ │ -00002df0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00002e40: 2037 333c 2f73 7061 6e3e 203c 2f64 6976 73
.
│ │ │ │ -00002ee0: 2020 3734 3c2f 613e 3c2f 7370 616e 3e20 74 │ │ │ │ -00002ef0: 2020 203c 6120 636c 6173 733d 2263 6f64 O │ │ │ │ -00002f20: 7074 696f 6e73 3c2f 613e 203c 6120 636c ptions GetO │ │ │ │ -00002f80: 7074 696f 6e73 3c2f 613e 2829 3c73 7061 ptions() const │ │ │ │ -00002fb0: 7b20 3c73 7061 6e20 636c 6173 733d 226b { retu │ │ │ │ -00002fd0: 726e 3c2f 7370 616e 3e20 5f6f 7074 696f rn _optio │ │ │ │ -00002fe0: 6e73 3b20 7d3c 2f64 6976 3e0a 3c64 6976 ns; }
.
< │ │ │ │ -00003020: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00003030: 6e6f 223e 3c61 2063 6c61 7373 3d22 6c69 no"> 75 void SetOption │ │ │ │ -00003110: 733c 2f61 3e28 3c73 7061 6e20 636c 6173 s(cons │ │ │ │ -00003130: 743c 2f73 7061 6e3e 203c 6120 636c 6173 t Options │ │ │ │ -00003170: 2661 6d70 3b20 6e65 774f 7074 696f 6e73 & newOptions │ │ │ │ -00003180: 2920 7b20 5f6f 7074 696f 6e73 203d 206e ) { _options = n │ │ │ │ -00003190: 6577 4f70 7469 6f6e 733b 207d 3c2f 6469 ewOptions; }.
76 │ │ │ │ -000031f0: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ -00003200: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00003210: 3e3c 6120 6964 3d22 6c30 3030 3830 2220 > 80 tem │ │ │ │ -00003270: 706c 6174 653c 2f73 7061 6e3e 2026 6c74 plate < │ │ │ │ -00003280: 3b3c 7370 616e 2063 6c61 7373 3d22 6b65 ;typename< │ │ │ │ -000032a0: 2f73 7061 6e3e 2046 4143 452c 203c 7370 /span> FACE, typename MASK>
.
81< │ │ │ │ -00003330: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> void │ │ │ │ -00003360: 3c61 2063 6c61 7373 3d22 636f 6465 2068 ComputeFaceVert │ │ │ │ -000033c0: 6578 4d61 736b 3c2f 613e 2846 4143 4520 exMask(FACE │ │ │ │ -000033d0: 3c73 7061 6e20 636c 6173 733d 226b 6579 const& faceNeig │ │ │ │ -00003400: 6862 6f72 686f 6f64 2c20 4d41 534b 2661 hborhood, MASK&a │ │ │ │ -00003410: 6d70 3b20 6661 6365 5665 7274 6578 4d61 mp; faceVertexMa │ │ │ │ -00003420: 736b 2920 3c73 7061 6e20 636c 6173 733d sk) const< │ │ │ │ -00003440: 2f73 7061 6e3e 3b3c 2f64 6976 3e0a 3c64 /span>;
. │ │ │ │ -00003460: 3c61 2069 643d 226c 3030 3038 3222 206e 82
.
98 │ │ │ │ -00003500: 2020 3c73 7061 6e20 636c 6173 733d 226b template │ │ │ │ -00003520: 3c2f 7370 616e 3e20 266c 743b 3c73 7061 <typename EDGE, ty │ │ │ │ -00003570: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ -00003580: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ -000035a0: 6120 6964 3d22 6c30 3030 3939 2220 6e61 a id="l00099" na │ │ │ │ -000035b0: 6d65 3d22 6c30 3030 3939 223e 3c2f 613e me="l00099"> │ │ │ │ -000035c0: 3c73 7061 6e20 636c 6173 733d 226c 696e 99 v │ │ │ │ -00003600: 6f69 643c 2f73 7061 6e3e 203c 6120 636c oid Comp │ │ │ │ -00003660: 7574 6545 6467 6556 6572 7465 784d 6173 uteEdgeVertexMas │ │ │ │ -00003670: 6b3c 2f61 3e28 4544 4745 203c 7370 616e k(EDGE const&am │ │ │ │ -000036a0: 703b 2065 6467 654e 6569 6768 626f 7268 p; edgeNeighborh │ │ │ │ -000036b0: 6f6f 642c 204d 4153 4b26 616d 703b 2065 ood, MASK& e │ │ │ │ -000036c0: 6467 6556 6572 7465 784d 6173 6b2c 3c2f dgeVertexMask,.
1 │ │ │ │ -00003720: 3030 3c2f 7370 616e 3e20 2020 2020 2020 00 │ │ │ │ -00003730: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00003740: 2020 2020 2020 2020 3c61 2063 6c61 7373 Crea │ │ │ │ -000037a0: 7365 3a3a 5275 6c65 3c2f 613e 2070 6172 se::Rule par │ │ │ │ -000037b0: 656e 7452 756c 6520 3d20 3c61 2063 6c61 entRule = Cre │ │ │ │ -00003830: 6173 653a 3a52 554c 455f 554e 4b4e 4f57 ase::RULE_UNKNOW │ │ │ │ -00003840: 4e3c 2f61 3e2c 3c2f 6469 763e 0a3c 6469 N,
.< │ │ │ │ -00003860: 6120 6964 3d22 6c30 3031 3031 2220 6e61 a id="l00101" na │ │ │ │ -00003870: 6d65 3d22 6c30 3031 3031 223e 3c2f 613e me="l00101"> │ │ │ │ -00003880: 3c73 7061 6e20 636c 6173 733d 226c 696e 101 │ │ │ │ -000038b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -000038c0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Crease::Rule │ │ │ │ -00003920: 3c2f 613e 2063 6869 6c64 5275 6c65 203d childRule = │ │ │ │ -00003930: 203c 6120 636c 6173 733d 2263 6f64 6520 Crease::RULE │ │ │ │ -000039b0: 5f55 4e4b 4e4f 574e 3c2f 613e 2920 3c73 _UNKNOWN) const │ │ │ │ -000039e0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00003a30: 2020 3130 323c 2f73 7061 6e3e 203c 2f64 102 .
11 │ │ │ │ -00003a90: 323c 2f73 7061 6e3e 2020 2020 3c73 7061 2 template <type │ │ │ │ -00003ae0: 6e61 6d65 3c2f 7370 616e 3e20 5645 5254 name VERT │ │ │ │ -00003af0: 4558 2c20 3c73 7061 6e20 636c 6173 733d EX, typena │ │ │ │ -00003b10: 6d65 3c2f 7370 616e 3e20 4d41 534b 2667 me MASK&g │ │ │ │ -00003b20: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
..
114 │ │ │ │ -00003cd0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00003ce0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00003cf0: 203c 6120 636c 6173 733d 2263 6f64 6520 Crease::Rul │ │ │ │ -00003d50: 653c 2f61 3e20 7061 7265 6e74 5275 6c65 e parentRule │ │ │ │ -00003d60: 203d 203c 6120 636c 6173 733d 2263 6f64 = Crease::RU │ │ │ │ -00003de0: 4c45 5f55 4e4b 4e4f 574e 3c2f 613e 2c3c LE_UNKNOWN,< │ │ │ │ -00003df0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00003e40: 3131 353c 2f73 7061 6e3e 2020 2020 2020 115 │ │ │ │ -00003e50: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00003e60: 2020 2020 2020 2020 2020 2020 2020 3c61 Crease::Rule childRule = < │ │ │ │ -00003ee0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00003ef0: 5f65 6e75 6d76 616c 7565 2220 6872 6566 _enumvalue" href │ │ │ │ -00003f00: 3d22 6130 3133 3333 2e68 746d 6c23 6131 ="a01333.html#a1 │ │ │ │ -00003f10: 3166 6364 3531 6566 3836 3131 3866 3635 1fcd51ef86118f65 │ │ │ │ -00003f20: 6536 3033 6331 3437 3433 3737 6137 3861 e603c1474377a78a │ │ │ │ -00003f30: 6232 3939 6165 6662 3236 3031 3361 3739 b299aefb26013a79 │ │ │ │ -00003f40: 6435 3231 3931 6137 3838 3766 6561 3533 d52191a7887fea53 │ │ │ │ -00003f50: 223e 4372 6561 7365 3a3a 5255 4c45 5f55 ">Crease::RULE_U │ │ │ │ -00003f60: 4e4b 4e4f 574e 3c2f 613e 2920 3c73 7061 NKNOWN) const;< │ │ │ │ -00003f90: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00003fe0: 3131 363c 2f73 7061 6e3e 203c 2f64 6976 116
.
141< │ │ │ │ -00004040: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -00004060: 7465 6d70 6c61 7465 3c2f 7370 616e 3e20 template │ │ │ │ -00004070: 266c 743b 3c73 7061 6e20 636c 6173 733d <typena │ │ │ │ -00004090: 6d65 3c2f 7370 616e 3e20 5645 5254 4558 me VERTEX │ │ │ │ -000040a0: 2c20 3c73 7061 6e20 636c 6173 733d 226b , typename │ │ │ │ -000040c0: 3c2f 7370 616e 3e20 4d41 534b 2667 743b MASK> │ │ │ │ -000040d0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00004120: 2031 3432 3c2f 7370 616e 3e20 2020 203c 142 < │ │ │ │ -00004130: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00004140: 6f72 6474 7970 6522 3e76 6f69 643c 2f73 ordtype">void ComputeVer │ │ │ │ -000041b0: 7465 784c 696d 6974 4d61 736b 3c2f 613e texLimitMask │ │ │ │ -000041c0: 2856 4552 5445 5820 3c73 7061 6e20 636c (VERTEX co │ │ │ │ -000041e0: 6e73 743c 2f73 7061 6e3e 2661 6d70 3b20 nst& │ │ │ │ -000041f0: 7665 7274 6578 4e65 6967 6862 6f72 686f vertexNeighborho │ │ │ │ -00004200: 6f64 2c20 4d41 534b 2661 6d70 3b20 706f od, MASK& po │ │ │ │ -00004210: 7369 7469 6f6e 4d61 736b 2c3c 2f64 6976 sitionMask,
.
143< │ │ │ │ -00004270: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ -00004280: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00004290: 2020 2020 2020 3c61 2063 6c61 7373 3d22 Crease │ │ │ │ -000042f0: 3a3a 5275 6c65 3c2f 613e 2076 6572 7465 ::Rule verte │ │ │ │ -00004300: 7852 756c 6529 203c 7370 616e 2063 6c61 xRule) con │ │ │ │ -00004320: 7374 3c2f 7370 616e 3e3b 3c2f 6469 763e st;
│ │ │ │ -00004330: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -000043a0: 6120 6964 3d22 6c30 3031 3435 2220 6e61 a id="l00145" na │ │ │ │ -000043b0: 6d65 3d22 6c30 3031 3435 223e 3c2f 613e me="l00145"> │ │ │ │ -000043c0: 3c73 7061 6e20 636c 6173 733d 226c 696e 145 templ │ │ │ │ -00004400: 6174 653c 2f73 7061 6e3e 2026 6c74 3b3c ate << │ │ │ │ -00004410: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00004420: 6f72 6422 3e74 7970 656e 616d 653c 2f73 ord">typename VERTEX, typename MASK>
.
146< │ │ │ │ -000044c0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> void │ │ │ │ -000044f0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 ComputeVertexLi │ │ │ │ -00004550: 6d69 744d 6173 6b3c 2f61 3e28 5645 5254 mitMask(VERT │ │ │ │ -00004560: 4558 203c 7370 616e 2063 6c61 7373 3d22 EX const& verte │ │ │ │ -00004590: 784e 6569 6768 626f 7268 6f6f 642c 204d xNeighborhood, M │ │ │ │ -000045a0: 4153 4b26 616d 703b 2070 6f73 6974 696f ASK& positio │ │ │ │ -000045b0: 6e4d 6173 6b2c 3c2f 6469 763e 0a3c 6469 nMask,
.< │ │ │ │ -000045d0: 6120 6964 3d22 6c30 3031 3437 2220 6e61 a id="l00147" na │ │ │ │ -000045e0: 6d65 3d22 6c30 3031 3437 223e 3c2f 613e me="l00147"> │ │ │ │ -000045f0: 3c73 7061 6e20 636c 6173 733d 226c 696e 147 │ │ │ │ -00004620: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00004630: 204d 4153 4b26 616d 703b 2074 616e 6765 MASK& tange │ │ │ │ -00004640: 6e74 314d 6173 6b2c 204d 4153 4b26 616d nt1Mask, MASK&am │ │ │ │ -00004650: 703b 2074 616e 6765 6e74 324d 6173 6b2c p; tangent2Mask, │ │ │ │ -00004660: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000046b0: 2031 3438 3c2f 7370 616e 3e20 2020 2020 148 │ │ │ │ -000046c0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -000046d0: 2020 2020 2020 2020 2020 203c 6120 636c C │ │ │ │ -00004730: 7265 6173 653a 3a52 756c 653c 2f61 3e20 rease::Rule │ │ │ │ -00004740: 7665 7274 6578 5275 6c65 2920 3c73 7061 vertexRule) const;< │ │ │ │ -00004770: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -000047c0: 3134 393c 2f73 7061 6e3e 203c 2f64 6976 149
.
150< │ │ │ │ -00004820: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -00004840: 2f2f 3c2f 7370 616e 3e3c 2f64 6976 3e0a //
. │ │ │ │ -00004850: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
│ │ │ │ -00004950: 2020 3135 323c 2f73 7061 6e3e 2020 2020 152 │ │ │ │ -00004960: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ -00004980: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>..< │ │ │ │ -00004b20: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00004b30: 3e3c 6120 6964 3d22 6c30 3031 3534 2220 > 15 │ │ │ │ -00004bb0: 343c 2f61 3e3c 2f73 7061 6e3e 2020 2020 4 │ │ │ │ -00004bc0: 3c73 7061 6e20 636c 6173 733d 226b 6579 static in │ │ │ │ -00004c00: 743c 2f73 7061 6e3e 2020 203c 6120 636c t GetR │ │ │ │ -00004c60: 6567 756c 6172 4661 6365 5369 7a65 3c2f egularFaceSize();
.. │ │ │ │ -00004df0: 3c61 2069 643d 226c 3030 3135 3622 206e 156 │ │ │ │ -00004e70: 3c2f 613e 3c2f 7370 616e 3e20 2020 203c < │ │ │ │ -00004e80: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00004e90: 6f72 6422 3e73 7461 7469 633c 2f73 7061 ord">static int │ │ │ │ -00004ec0: 3c2f 7370 616e 3e20 2020 3c61 2063 6c61 GetLo │ │ │ │ -00004f20: 6361 6c4e 6569 6768 626f 7268 6f6f 6453 calNeighborhoodS │ │ │ │ -00004f30: 697a 653c 2f61 3e28 293b 3c2f 6469 763e ize();
│ │ │ │ -00004f40: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -00004fb0: 6120 6964 3d22 6c30 3031 3538 2220 6e61 a id="l00158" na │ │ │ │ -00004fc0: 6d65 3d22 6c30 3031 3538 223e 3c2f 613e me="l00158"> │ │ │ │ -00004fd0: 3c73 7061 6e20 636c 6173 733d 226c 696e 158protected │ │ │ │ -00005010: 3c2f 7370 616e 3e3a 3c2f 6469 763e 0a3c :
.< │ │ │ │ -00005020: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00005030: 3e3c 6120 6964 3d22 6c30 3031 3539 2220 > 159
.
160 │ │ │ │ -000050d0: 2020 203c 7370 616e 2063 6c61 7373 3d22 //
.
161 │ │ │ │ -00005150: 203c 7370 616e 2063 6c61 7373 3d22 636f // Suppo │ │ │ │ -00005170: 7274 696e 6720 696e 7465 726e 616c 206d rting internal m │ │ │ │ -00005180: 6574 686f 6473 202d 2d20 6f70 7469 6f6e ethods -- option │ │ │ │ -00005190: 616c 6c79 2069 6d70 6c65 6d65 6e74 6564 ally implemented │ │ │ │ -000051a0: 2c20 6465 7065 6e64 696e 6720 6f6e 2073 , depending on s │ │ │ │ -000051b0: 7065 6369 616c 697a 6174 696f 6e3a 3c2f pecialization:
.
< │ │ │ │ -00005200: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00005210: 6e6f 223e 2020 3136 323c 2f73 7061 6e3e no"> 162 │ │ │ │ -00005220: 2020 2020 3c73 7061 6e20 636c 6173 733d //
.
163 < │ │ │ │ -000052a0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -000052f0: 3136 343c 2f73 7061 6e3e 2020 2020 3c73 164 // Subdivis │ │ │ │ -00005320: 696f 6e2f 7265 6669 6e65 6d65 6e74 206d ion/refinement m │ │ │ │ -00005330: 6173 6b73 202d 2d20 7477 6f20 666f 7220 asks -- two for │ │ │ │ -00005340: 6564 6765 2d76 6572 7469 6365 7320 616e edge-vertices an │ │ │ │ -00005350: 6420 7468 7265 6520 666f 7220 7665 7274 d three for vert │ │ │ │ -00005360: 6578 2d76 6572 7469 6365 733a 3c2f 7370 ex-vertices:
.
165 │ │ │ │ -000053d0: 2020 3c73 7061 6e20 636c 6173 733d 2263 //
.
│ │ │ │ -00005440: 2020 3136 363c 2f73 7061 6e3e 2020 2020 166 │ │ │ │ -00005450: 3c73 7061 6e20 636c 6173 733d 226b 6579 template < │ │ │ │ -00005490: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ -000054a0: 4544 4745 2c20 3c73 7061 6e20 636c 6173 EDGE, type │ │ │ │ -000054c0: 6e61 6d65 3c2f 7370 616e 3e20 4d41 534b name MASK │ │ │ │ -000054d0: 2667 743b 3c2f 6469 763e 0a3c 6469 7620 >
.
167 │ │ │ │ -00005530: 2020 203c 7370 616e 2063 6c61 7373 3d22 voi │ │ │ │ -00005550: 643c 2f73 7061 6e3e 203c 6120 636c 6173 d assign │ │ │ │ -000055b0: 4372 6561 7365 4d61 736b 466f 7245 6467 CreaseMaskForEdg │ │ │ │ -000055c0: 653c 2f61 3e28 4544 4745 203c 7370 616e e(EDGE const&am │ │ │ │ -000055f0: 703b 2065 6467 652c 204d 4153 4b26 616d p; edge, MASK&am │ │ │ │ -00005600: 703b 206d 6173 6b29 203c 7370 616e 2063 p; mask) c │ │ │ │ -00005620: 6f6e 7374 3c2f 7370 616e 3e3b 3c2f 6469 onst;.
168 │ │ │ │ -00005680: 3c2f 7370 616e 3e20 2020 203c 7370 616e template │ │ │ │ -000056b0: 2026 6c74 3b3c 7370 616e 2063 6c61 7373 <typen │ │ │ │ -000056d0: 616d 653c 2f73 7061 6e3e 2045 4447 452c ame EDGE, │ │ │ │ -000056e0: 203c 7370 616e 2063 6c61 7373 3d22 6b65 typename< │ │ │ │ -00005700: 2f73 7061 6e3e 204d 4153 4b26 6774 3b3c /span> MASK>< │ │ │ │ -00005710: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
169 void as │ │ │ │ -00005830: 7369 676e 536d 6f6f 7468 4d61 736b 466f signSmoothMaskFo │ │ │ │ -00005840: 7245 6467 653c 2f61 3e28 4544 4745 203c rEdge(EDGE < │ │ │ │ -00005850: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00005860: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const& edge, MAS │ │ │ │ -00005880: 4b26 616d 703b 206d 6173 6b29 203c 7370 K& mask) const; │ │ │ │ -000058b0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00005900: 2031 3730 3c2f 7370 616e 3e20 3c2f 6469 170 .
171 │ │ │ │ -00005960: 3c2f 7370 616e 3e20 2020 203c 7370 616e template │ │ │ │ -00005990: 2026 6c74 3b3c 7370 616e 2063 6c61 7373 <typen │ │ │ │ -000059b0: 616d 653c 2f73 7061 6e3e 2056 4552 5445 ame VERTE │ │ │ │ -000059c0: 582c 203c 7370 616e 2063 6c61 7373 3d22 X, typenam │ │ │ │ -000059e0: 653c 2f73 7061 6e3e 204d 4153 4b26 6774 e MASK> │ │ │ │ -000059f0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00005a40: 2020 3137 323c 2f73 7061 6e3e 2020 2020 172 │ │ │ │ -00005a50: 3c73 7061 6e20 636c 6173 733d 226b 6579 void assignCor │ │ │ │ -00005ad0: 6e65 724d 6173 6b46 6f72 5665 7274 6578 nerMaskForVertex │ │ │ │ -00005ae0: 3c2f 613e 2856 4552 5445 5820 3c73 7061 (VERTEX const&a │ │ │ │ -00005b10: 6d70 3b20 6564 6765 2c20 4d41 534b 2661 mp; edge, MASK&a │ │ │ │ -00005b20: 6d70 3b20 6d61 736b 2920 3c73 7061 6e20 mp; mask) │ │ │ │ -00005b40: 636f 6e73 743c 2f73 7061 6e3e 3b3c 2f64 const;.
17 │ │ │ │ -00005ba0: 333c 2f73 7061 6e3e 2020 2020 3c73 7061 3 template <type │ │ │ │ -00005bf0: 6e61 6d65 3c2f 7370 616e 3e20 5645 5254 name VERT │ │ │ │ -00005c00: 4558 2c20 3c73 7061 6e20 636c 6173 733d EX, typena │ │ │ │ -00005c20: 6d65 3c2f 7370 616e 3e20 4d41 534b 2667 me MASK&g │ │ │ │ -00005c30: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
174< │ │ │ │ -00005cd0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> void │ │ │ │ -00005d00: 3c61 2063 6c61 7373 3d22 636f 6465 2068 assignCreaseMas │ │ │ │ -00005d60: 6b46 6f72 5665 7274 6578 3c2f 613e 2856 kForVertex(V │ │ │ │ -00005d70: 4552 5445 5820 3c73 7061 6e20 636c 6173 ERTEX cons │ │ │ │ -00005d90: 743c 2f73 7061 6e3e 2661 6d70 3b20 6564 t& ed │ │ │ │ -00005da0: 6765 2c20 4d41 534b 2661 6d70 3b20 6d61 ge, MASK& ma │ │ │ │ -00005db0: 736b 2c20 3c73 7061 6e20 636c 6173 733d sk, in │ │ │ │ -00005dd0: 743c 2f73 7061 6e3e 203c 7370 616e 2063 t c │ │ │ │ -00005df0: 6f6e 7374 3c2f 7370 616e 3e20 6372 6561 onst crea │ │ │ │ -00005e00: 7365 456e 6473 5b32 5d29 203c 7370 616e seEnds[2]) const;.
1 │ │ │ │ -00005e80: 3735 3c2f 7370 616e 3e20 2020 203c 7370 75 template <typ │ │ │ │ -00005ed0: 656e 616d 653c 2f73 7061 6e3e 2056 4552 ename VER │ │ │ │ -00005ee0: 5445 582c 203c 7370 616e 2063 6c61 7373 TEX, typen │ │ │ │ -00005f00: 616d 653c 2f73 7061 6e3e 204d 4153 4b26 ame MASK& │ │ │ │ -00005f10: 6774 3b3c 2f64 6976 3e0a 3c64 6976 2063 gt;
.
176 │ │ │ │ -00005fb0: 3c2f 7370 616e 3e20 2020 203c 7370 616e void │ │ │ │ -00005fe0: 203c 6120 636c 6173 733d 2263 6f64 6520 assignSmoothMa │ │ │ │ -00006040: 736b 466f 7256 6572 7465 783c 2f61 3e28 skForVertex( │ │ │ │ -00006050: 5645 5254 4558 203c 7370 616e 2063 6c61 VERTEX con │ │ │ │ -00006070: 7374 3c2f 7370 616e 3e26 616d 703b 2065 st& e │ │ │ │ -00006080: 6467 652c 204d 4153 4b26 616d 703b 206d dge, MASK& m │ │ │ │ -00006090: 6173 6b29 203c 7370 616e 2063 6c61 7373 ask) const │ │ │ │ -000060b0: 3c2f 7370 616e 3e3b 3c2f 6469 763e 0a3c ;
.< │ │ │ │ -000060c0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -000060d0: 3e3c 6120 6964 3d22 6c30 3031 3737 2220 > 177
.
178 │ │ │ │ -00006170: 2020 203c 7370 616e 2063 6c61 7373 3d22 //
.
179 │ │ │ │ -000061f0: 203c 7370 616e 2063 6c61 7373 3d22 636f // Limit │ │ │ │ -00006210: 206d 6173 6b73 2066 6f72 2070 6f73 6974 masks for posit │ │ │ │ -00006220: 696f 6e20 616e 6420 7461 6e67 656e 7473 ion and tangents │ │ │ │ -00006230: 2061 7420 7665 7274 6963 6573 202d 2d20 at vertices -- │ │ │ │ -00006240: 7468 7265 6520 6361 7365 7320 666f 7220 three cases for │ │ │ │ -00006250: 6561 6368 3a3c 2f73 7061 6e3e 3c2f 6469 each:.
180 │ │ │ │ -000062b0: 3c2f 7370 616e 3e20 2020 203c 7370 616e //
│ │ │ │ -000062e0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00006310: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 181 t │ │ │ │ -00006350: 656d 706c 6174 653c 2f73 7061 6e3e 2026 emplate & │ │ │ │ -00006360: 6c74 3b3c 7370 616e 2063 6c61 7373 3d22 lt;typenam │ │ │ │ -00006380: 653c 2f73 7061 6e3e 2056 4552 5445 582c e VERTEX, │ │ │ │ -00006390: 203c 7370 616e 2063 6c61 7373 3d22 6b65 typename< │ │ │ │ -000063b0: 2f73 7061 6e3e 204d 4153 4b26 6774 3b3c /span> MASK>< │ │ │ │ -000063c0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
182 void as │ │ │ │ -000064e0: 7369 676e 436f 726e 6572 4c69 6d69 744d signCornerLimitM │ │ │ │ -000064f0: 6173 6b3c 2f61 3e28 5645 5254 4558 203c ask(VERTEX < │ │ │ │ -00006500: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00006510: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const& vertex, M │ │ │ │ -00006530: 4153 4b26 616d 703b 2070 6f73 2920 3c73 ASK& pos) const │ │ │ │ -00006560: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -000065b0: 2020 3138 333c 2f73 7061 6e3e 2020 2020 183 │ │ │ │ -000065c0: 3c73 7061 6e20 636c 6173 733d 226b 6579 template < │ │ │ │ -00006600: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ -00006610: 5645 5254 4558 2c20 3c73 7061 6e20 636c VERTEX, ty │ │ │ │ -00006630: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ -00006640: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ -00006660: 6120 6964 3d22 6c30 3031 3834 2220 6e61 a id="l00184" na │ │ │ │ -00006670: 6d65 3d22 6c30 3031 3834 223e 3c2f 613e me="l00184"> │ │ │ │ -00006680: 3c73 7061 6e20 636c 6173 733d 226c 696e 184< │ │ │ │ -000066e0: 2f61 3e3c 2f73 7061 6e3e 2020 2020 3c73 /a> void assignCreas │ │ │ │ -00006770: 654c 696d 6974 4d61 736b 3c2f 613e 2856 eLimitMask(V │ │ │ │ -00006780: 4552 5445 5820 3c73 7061 6e20 636c 6173 ERTEX cons │ │ │ │ -000067a0: 743c 2f73 7061 6e3e 2661 6d70 3b20 7665 t& ve │ │ │ │ -000067b0: 7274 6578 2c20 4d41 534b 2661 6d70 3b20 rtex, MASK& │ │ │ │ -000067c0: 706f 732c 203c 7370 616e 2063 6c61 7373 pos, i │ │ │ │ -000067e0: 6e74 3c2f 7370 616e 3e20 3c73 7061 6e20 nt │ │ │ │ -00006800: 636f 6e73 743c 2f73 7061 6e3e 2063 7265 const cre │ │ │ │ -00006810: 6173 6545 6e64 735b 325d 2920 3c73 7061 aseEnds[2]) const
;< │ │ │ │ -00006840: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00006890: 3138 353c 2f73 7061 6e3e 2020 2020 3c73 185 template <ty │ │ │ │ -000068e0: 7065 6e61 6d65 3c2f 7370 616e 3e20 5645 pename VE │ │ │ │ -000068f0: 5254 4558 2c20 3c73 7061 6e20 636c 6173 RTEX, type │ │ │ │ -00006910: 6e61 6d65 3c2f 7370 616e 3e20 4d41 534b name MASK │ │ │ │ -00006920: 2667 743b 3c2f 6469 763e 0a3c 6469 7620 >
.
186 void assignSmoothL │ │ │ │ -00006a50: 696d 6974 4d61 736b 3c2f 613e 2856 4552 imitMask(VER │ │ │ │ -00006a60: 5445 5820 3c73 7061 6e20 636c 6173 733d TEX const< │ │ │ │ -00006a80: 2f73 7061 6e3e 2661 6d70 3b20 7665 7274 /span>& vert │ │ │ │ -00006a90: 6578 2c20 4d41 534b 2661 6d70 3b20 706f ex, MASK& po │ │ │ │ -00006aa0: 7329 203c 7370 616e 2063 6c61 7373 3d22 s) const;
.< │ │ │ │ -00006ae0: 6120 6964 3d22 6c30 3031 3837 2220 6e61 a id="l00187" na │ │ │ │ -00006af0: 6d65 3d22 6c30 3031 3837 223e 3c2f 613e me="l00187"> │ │ │ │ -00006b00: 3c73 7061 6e20 636c 6173 733d 226c 696e 187
.
188 │ │ │ │ -00006b80: 203c 7370 616e 2063 6c61 7373 3d22 6b65 template< │ │ │ │ -00006ba0: 2f73 7061 6e3e 2026 6c74 3b3c 7370 616e /span> <typename │ │ │ │ -00006bd0: 2056 4552 5445 582c 203c 7370 616e 2063 VERTEX, t │ │ │ │ -00006bf0: 7970 656e 616d 653c 2f73 7061 6e3e 204d ypename M │ │ │ │ -00006c00: 4153 4b26 6774 3b3c 2f64 6976 3e0a 3c64 ASK>
. │ │ │ │ -00006c20: 3c61 2069 643d 226c 3030 3138 3922 206e 189 │ │ │ │ -00006ca0: 3c2f 613e 3c2f 7370 616e 3e20 2020 203c < │ │ │ │ -00006cb0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00006cc0: 6f72 6474 7970 6522 3e76 6f69 643c 2f73 ordtype">void
assignCorn │ │ │ │ -00006d30: 6572 4c69 6d69 7454 616e 6765 6e74 4d61 erLimitTangentMa │ │ │ │ -00006d40: 736b 733c 2f61 3e28 5645 5254 4558 203c sks(VERTEX < │ │ │ │ -00006d50: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00006d60: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const& vertex, M │ │ │ │ -00006d80: 4153 4b26 616d 703b 2074 616e 312c 204d ASK& tan1, M │ │ │ │ -00006d90: 4153 4b26 616d 703b 2074 616e 3229 203c ASK& tan2) < │ │ │ │ -00006da0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00006db0: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const;
.
190 │ │ │ │ -00006e20: 203c 7370 616e 2063 6c61 7373 3d22 6b65 template< │ │ │ │ -00006e40: 2f73 7061 6e3e 2026 6c74 3b3c 7370 616e /span> <typename │ │ │ │ -00006e70: 2056 4552 5445 582c 203c 7370 616e 2063 VERTEX, t │ │ │ │ -00006e90: 7970 656e 616d 653c 2f73 7061 6e3e 204d ypename M │ │ │ │ -00006ea0: 4153 4b26 6774 3b3c 2f64 6976 3e0a 3c64 ASK>
. │ │ │ │ -00006ec0: 3c61 2069 643d 226c 3030 3139 3122 206e 191 │ │ │ │ -00006f40: 3c2f 613e 3c2f 7370 616e 3e20 2020 203c < │ │ │ │ -00006f50: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00006f60: 6f72 6474 7970 6522 3e76 6f69 643c 2f73 ordtype">void
assignCrea │ │ │ │ -00006fd0: 7365 4c69 6d69 7454 616e 6765 6e74 4d61 seLimitTangentMa │ │ │ │ -00006fe0: 736b 733c 2f61 3e28 5645 5254 4558 203c sks(VERTEX < │ │ │ │ -00006ff0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00007000: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const& vertex, M │ │ │ │ -00007020: 4153 4b26 616d 703b 2074 616e 312c 204d ASK& tan1, M │ │ │ │ -00007030: 4153 4b26 616d 703b 2074 616e 322c 203c ASK& tan2, < │ │ │ │ -00007040: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00007050: 6f72 6474 7970 6522 3e69 6e74 3c2f 7370 ordtype">int const< │ │ │ │ -00007080: 2f73 7061 6e3e 2063 7265 6173 6545 6e64 /span> creaseEnd │ │ │ │ -00007090: 735b 325d 2920 3c73 7061 6e20 636c 6173 s[2]) cons │ │ │ │ -000070b0: 743c 2f73 7061 6e3e 3b3c 2f64 6976 3e0a t;
. │ │ │ │ -000070c0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -000070f0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 192 te │ │ │ │ -00007130: 6d70 6c61 7465 3c2f 7370 616e 3e20 266c mplate &l │ │ │ │ -00007140: 743b 3c73 7061 6e20 636c 6173 733d 226b t;typename │ │ │ │ -00007160: 3c2f 7370 616e 3e20 5645 5254 4558 2c20 VERTEX, │ │ │ │ -00007170: 3c73 7061 6e20 636c 6173 733d 226b 6579 typename MASK>.
193 │ │ │ │ -00007260: 766f 6964 3c2f 7370 616e 3e20 3c61 2063 void ass │ │ │ │ -000072c0: 6967 6e53 6d6f 6f74 684c 696d 6974 5461 ignSmoothLimitTa │ │ │ │ -000072d0: 6e67 656e 744d 6173 6b73 3c2f 613e 2856 ngentMasks(V │ │ │ │ -000072e0: 4552 5445 5820 3c73 7061 6e20 636c 6173 ERTEX cons │ │ │ │ -00007300: 743c 2f73 7061 6e3e 2661 6d70 3b20 7665 t& ve │ │ │ │ -00007310: 7274 6578 2c20 4d41 534b 2661 6d70 3b20 rtex, MASK& │ │ │ │ -00007320: 7461 6e31 2c20 4d41 534b 2661 6d70 3b20 tan1, MASK& │ │ │ │ -00007330: 7461 6e32 2920 3c73 7061 6e20 636c 6173 tan2) cons │ │ │ │ -00007350: 743c 2f73 7061 6e3e 3b3c 2f64 6976 3e0a t;
. │ │ │ │ -00007360: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ -000073f0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00007400: 6e6f 223e 2020 3139 353c 2f73 7061 6e3e no"> 195 │ │ │ │ -00007410: 3c73 7061 6e20 636c 6173 733d 226b 6579 private:
.
< │ │ │ │ -00007470: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00007480: 6e6f 223e 2020 3139 363c 2f73 7061 6e3e no"> 196 │ │ │ │ -00007490: 2020 2020 3c61 2063 6c61 7373 3d22 636f │ │ │ │ -000074c0: 4f70 7469 6f6e 733c 2f61 3e20 5f6f 7074 Options _opt │ │ │ │ -000074d0: 696f 6e73 3b3c 2f64 6976 3e0a 3c64 6976 ions;
.
< │ │ │ │ -00007510: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00007520: 6e6f 223e 2020 3139 373c 2f73 7061 6e3e no"> 197 │ │ │ │ -00007530: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ -00007580: 2020 3139 383c 2f73 7061 6e3e 3c73 7061 198protected:
.
199 < │ │ │ │ -00007610: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00007660: 3230 303c 2f73 7061 6e3e 2020 2020 3c73 200 //.
20 │ │ │ │ -000076e0: 313c 2f73 7061 6e3e 2020 2020 3c73 7061 1 // Internal i │ │ │ │ -00007710: 6d70 6c65 6d65 6e74 6174 696f 6e20 7375 mplementation su │ │ │ │ -00007720: 7070 6f72 743a 3c2f 7370 616e 3e3c 2f64 pport:.
20 │ │ │ │ -00007780: 323c 2f73 7061 6e3e 2020 2020 3c73 7061 2 //
.
203< │ │ │ │ -00007800: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -00007820: 2f2f 2020 5765 206e 6565 6420 6120 6c6f // We need a lo │ │ │ │ -00007830: 6361 6c20 2671 756f 743b 6d61 736b 2671 cal "mask&q │ │ │ │ -00007840: 756f 743b 2063 6c61 7373 2074 6f20 6265 uot; class to be │ │ │ │ -00007850: 2064 6563 6c61 7265 6420 6c6f 6361 6c6c declared locall │ │ │ │ -00007860: 7920 7769 7468 696e 2074 6865 2076 6572 y within the ver │ │ │ │ -00007870: 7465 782d 7665 7274 6578 206d 6173 6b20 tex-vertex mask │ │ │ │ -00007880: 7175 6572 793c 2f73 7061 6e3e 3c2f 6469 query.
204 │ │ │ │ -000078e0: 3c2f 7370 616e 3e20 2020 203c 7370 616e // to hold one │ │ │ │ -00007910: 206f 6620 7468 6520 7477 6f20 706f 7373 of the two poss │ │ │ │ -00007920: 6962 6c65 206d 6173 6b73 2072 6571 7569 ible masks requi │ │ │ │ -00007930: 7265 6420 616e 6420 746f 2063 6f6d 6269 red and to combi │ │ │ │ -00007940: 6e65 2074 6865 206c 6f63 616c 206d 6173 ne the local mas │ │ │ │ -00007950: 6b20 7769 7468 2074 6865 206d 6173 6b3c k with the mask< │ │ │ │ -00007960: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -00007980: 6120 6964 3d22 6c30 3032 3035 2220 6e61 a id="l00205" na │ │ │ │ -00007990: 6d65 3d22 6c30 3032 3035 223e 3c2f 613e me="l00205"> │ │ │ │ -000079a0: 3c73 7061 6e20 636c 6173 733d 226c 696e 205 // t │ │ │ │ -000079e0: 6865 2063 616c 6c65 7220 7072 6f76 6964 he caller provid │ │ │ │ -000079f0: 6573 2e20 2049 7420 6861 7320 6265 656e es. It has been │ │ │ │ -00007a00: 2070 6172 616d 6574 6572 697a 6564 2062 parameterized b │ │ │ │ -00007a10: 7920 266c 743b 5745 4947 4854 2667 743b y <WEIGHT> │ │ │ │ -00007a20: 2073 6f20 7468 6174 2061 2076 6572 7369 so that a versi │ │ │ │ -00007a30: 6f6e 2063 6f6d 7061 7469 626c 653c 2f73 on compatible
.
206 │ │ │ │ -00007aa0: 2020 203c 7370 616e 2063 6c61 7373 3d22 // wit │ │ │ │ -00007ac0: 6820 7468 6520 6361 6c6c 6572 2623 3339 h the caller' │ │ │ │ -00007ad0: 3b73 206d 6173 6b20 636c 6173 7320 6973 ;s mask class is │ │ │ │ -00007ae0: 2063 7265 6174 6564 2e3c 2f73 7061 6e3e created. │ │ │ │ -00007af0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00007b40: 2032 3037 3c2f 7370 616e 3e20 2020 203c 207 < │ │ │ │ -00007b50: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00007b60: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
2 │ │ │ │ -00007bc0: 3038 3c2f 7370 616e 3e20 2020 203c 7370 08 template <typ │ │ │ │ -00007c10: 656e 616d 653c 2f73 7061 6e3e 2057 4549 ename WEI │ │ │ │ -00007c20: 4748 5426 6774 3b3c 2f64 6976 3e0a 3c64 GHT>
..
│ │ │ │ -00007ce0: 2020 3230 393c 2f61 3e3c 2f73 7061 6e3e 209 │ │ │ │ -00007cf0: 2020 2020 3c73 7061 6e20 636c 6173 733d class │ │ │ │ -00007d10: 3c2f 7370 616e 3e3c 6120 636c 6173 733d LocalMask │ │ │ │ -00007d50: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
210 .
2 │ │ │ │ -00007e00: 3131 3c2f 7370 616e 3e20 2020 203c 7370 11 public │ │ │ │ -00007e30: 3a3c 2f64 6976 3e0a 3c64 6976 2063 6c61 :
.
│ │ │ │ -00007e80: 3c61 2063 6c61 7373 3d22 6c69 6e65 2220 212 typedef WEIGHT Weight< │ │ │ │ -00007f60: 2f61 3e3b 3c2f 6469 763e 0a3c 6469 7620 /a>;
.
213 │ │ │ │ -00007fc0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00008010: 2032 3134 3c2f 7370 616e 3e20 2020 203c 214 < │ │ │ │ -00008020: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00008030: 6f72 6422 3e70 7562 6c69 633c 2f73 7061 ord">public:
.
215 │ │ │ │ -000080e0: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ -000080f0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00008100: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ -00008110: 2261 3031 3334 352e 6874 6d6c 2361 6334 "a01345.html#ac4 │ │ │ │ -00008120: 6234 6335 3566 6232 3464 6139 3566 3135 b4c55fb24da95f15 │ │ │ │ -00008130: 3466 3461 3966 3531 3764 6230 3739 223e 4f4a9f517db079"> │ │ │ │ -00008140: 4c6f 6361 6c4d 6173 6b3c 2f61 3e28 3c61 LocalMask(We │ │ │ │ -000081a0: 6967 6874 3c2f 613e 2a20 762c 203c 6120 ight* v, Wei │ │ │ │ -00008200: 6768 743c 2f61 3e2a 2065 2c20 3c61 2063 ght* e, Weig │ │ │ │ -00008260: 6874 3c2f 613e 2a20 6629 203a 205f 7657 ht* f) : _vW │ │ │ │ -00008270: 6569 6768 7473 2876 292c 205f 6557 6569 eights(v), _eWei │ │ │ │ -00008280: 6768 7473 2865 292c 205f 6657 6569 6768 ghts(e), _fWeigh │ │ │ │ -00008290: 7473 2866 2920 7b20 7d3c 2f64 6976 3e0a ts(f) { }
. │ │ │ │ -000082a0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 │ │ │ │ -000083b0: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -00008420: 6120 6964 3d22 6c30 3032 3138 2220 6e61 a id="l00218" na │ │ │ │ -00008430: 6d65 3d22 6c30 3032 3138 223e 3c2f 613e me="l00218"> │ │ │ │ -00008440: 3c73 7061 6e20 636c 6173 733d 226c 696e 218 publi │ │ │ │ -00008480: 633c 2f73 7061 6e3e 3a3c 2f64 6976 3e0a c:
. │ │ │ │ -00008490: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
< │ │ │ │ -00008520: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00008530: 6e6f 223e 2020 3232 303c 2f73 7061 6e3e no"> 220 │ │ │ │ -00008540: 2020 2020 2020 2020 3c73 7061 6e20 636c // │ │ │ │ -00008560: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00008580: 3c61 2069 643d 226c 3030 3232 3122 206e 221 │ │ │ │ -000085e0: 2f2f 2020 4d65 7468 6f64 7320 7265 7175 // Methods requ │ │ │ │ -000085f0: 6972 6564 2066 6f72 2067 656e 6572 616c ired for general │ │ │ │ -00008600: 206d 6173 6b20 6173 7369 676e 6d65 6e74 mask assignment │ │ │ │ -00008610: 7320 616e 6420 7175 6572 6965 733a 3c2f s and queries:
.
< │ │ │ │ -00008660: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00008670: 6e6f 223e 2020 3232 323c 2f73 7061 6e3e no"> 222 │ │ │ │ -00008680: 2020 2020 2020 2020 3c73 7061 6e20 636c // │ │ │ │ -000086a0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -000086c0: 3c61 2069 643d 226c 3030 3232 3322 206e 223 │ │ │ │ -00008740: 3c2f 613e 3c2f 7370 616e 3e20 2020 2020 │ │ │ │ -00008750: 2020 203c 7370 616e 2063 6c61 7373 3d22 int │ │ │ │ -00008770: 3c2f 7370 616e 3e20 3c61 2063 6c61 7373 GetNumV │ │ │ │ -000087d0: 6572 7465 7857 6569 6768 7473 3c2f 613e ertexWeights │ │ │ │ -000087e0: 2829 3c73 7061 6e20 636c 6173 733d 226b () const < │ │ │ │ -00008800: 2f73 7061 6e3e 7b20 3c73 7061 6e20 636c /span>{ return │ │ │ │ -00008830: 5f76 436f 756e 743b 207d 3c2f 6469 763e _vCount; }
│ │ │ │ -00008840: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00008870: 3c2f 613e 3c73 7061 6e20 636c 6173 733d │ │ │ │ -000088d0: 3232 343c 2f61 3e3c 2f73 7061 6e3e 2020 224 │ │ │ │ -000088e0: 2020 2020 2020 3c73 7061 6e20 636c 6173 │ │ │ │ -00008900: 696e 743c 2f73 7061 6e3e 203c 6120 636c int GetN │ │ │ │ -00008960: 756d 4564 6765 5765 6967 6874 733c 2f61 umEdgeWeights() cons │ │ │ │ -00008990: 7420 3c2f 7370 616e 3e7b 203c 7370 616e t { return _eCount; }.
225 int G │ │ │ │ -00008af0: 6574 4e75 6d46 6163 6557 6569 6768 7473 etNumFaceWeights │ │ │ │ -00008b00: 3c2f 613e 2829 3c73 7061 6e20 636c 6173 () c │ │ │ │ -00008b20: 6f6e 7374 203c 2f73 7061 6e3e 7b20 3c73 onst { return _fCount; } │ │ │ │ -00008b60: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00008bb0: 2032 3236 3c2f 7370 616e 3e20 3c2f 6469 226 .
│ │ │ │ -00008c50: 2020 3232 373c 2f61 3e3c 2f73 7061 6e3e 227 │ │ │ │ -00008c60: 2020 2020 2020 2020 3c73 7061 6e20 636c void S │ │ │ │ -00008ce0: 6574 4e75 6d56 6572 7465 7857 6569 6768 etNumVertexWeigh │ │ │ │ -00008cf0: 7473 3c2f 613e 283c 7370 616e 2063 6c61 ts(int coun │ │ │ │ -00008d20: 7429 207b 205f 7643 6f75 6e74 203d 2063 t) { _vCount = c │ │ │ │ -00008d30: 6f75 6e74 3b20 7d3c 2f64 6976 3e0a 3c64 ount; }
. │ │ │ │ -00008d50: 3c61 2069 643d 226c 3030 3232 3822 206e 228 │ │ │ │ -00008dd0: 3c2f 613e 3c2f 7370 616e 3e20 2020 2020 │ │ │ │ -00008de0: 2020 203c 7370 616e 2063 6c61 7373 3d22 voi │ │ │ │ -00008e00: 643c 2f73 7061 6e3e 203c 6120 636c 6173 d SetNum │ │ │ │ -00008e60: 4564 6765 5765 6967 6874 733c 2f61 3e28 EdgeWeights( │ │ │ │ -00008e70: 2020 3c73 7061 6e20 636c 6173 733d 226b int< │ │ │ │ -00008e90: 2f73 7061 6e3e 2063 6f75 6e74 2920 7b20 /span> count) { │ │ │ │ -00008ea0: 5f65 436f 756e 7420 3d20 636f 756e 743b _eCount = count; │ │ │ │ -00008eb0: 207d 3c2f 6469 763e 0a3c 6469 7620 636c }
.
229< │ │ │ │ -00008f50: 2f73 7061 6e3e 2020 2020 2020 2020 3c73 /span> void SetNumFaceW │ │ │ │ -00008fe0: 6569 6768 7473 3c2f 613e 2820 203c 7370 eights( int count) { _fCou │ │ │ │ -00009020: 6e74 203d 2063 6f75 6e74 3b20 7d3c 2f64 nt = count; }.
23 │ │ │ │ -00009080: 303c 2f73 7061 6e3e 203c 2f64 6976 3e0a 0
. │ │ │ │ -00009090: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -000090c0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 2 │ │ │ │ -00009120: 3331 3c2f 613e 3c2f 7370 616e 3e20 2020 31 │ │ │ │ -00009130: 2020 2020 203c 6120 636c 6173 733d 2263 Weight │ │ │ │ -00009190: 3c73 7061 6e20 636c 6173 733d 226b 6579 const& VertexW │ │ │ │ -00009210: 6569 6768 743c 2f61 3e28 3c73 7061 6e20 eight(int i │ │ │ │ -00009240: 6e64 6578 293c 7370 616e 2063 6c61 7373 ndex) cons │ │ │ │ -00009260: 7420 3c2f 7370 616e 3e7b 203c 7370 616e t { return _vWeights[ind │ │ │ │ -000092a0: 6578 5d3b 207d 3c2f 6469 763e 0a3c 6469 ex]; }
.< │ │ │ │ -000092c0: 6120 6964 3d22 6c30 3032 3332 2220 6e61 a id="l00232" na │ │ │ │ -000092d0: 6d65 3d22 6c30 3032 3332 223e 3c2f 613e me="l00232"> │ │ │ │ -000092e0: 3c73 7061 6e20 636c 6173 733d 226c 696e 232< │ │ │ │ -00009340: 2f61 3e3c 2f73 7061 6e3e 2020 2020 2020 /a> │ │ │ │ -00009350: 2020 3c61 2063 6c61 7373 3d22 636f 6465 Weight const& │ │ │ │ -000093d0: 616d 703b 203c 6120 636c 6173 733d 2263 amp; EdgeWeight │ │ │ │ -00009430: 3c2f 613e 2820 203c 7370 616e 2063 6c61 ( int inde │ │ │ │ -00009460: 7829 3c73 7061 6e20 636c 6173 733d 226b x) const < │ │ │ │ -00009480: 2f73 7061 6e3e 7b20 3c73 7061 6e20 636c /span>{ return │ │ │ │ -000094b0: 5f65 5765 6967 6874 735b 696e 6465 785d _eWeights[index] │ │ │ │ -000094c0: 3b20 7d3c 2f64 6976 3e0a 3c64 6976 2063 ; }
.
233 │ │ │ │ -00009560: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ -00009570: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00009580: 5f74 7970 6564 6566 2220 6872 6566 3d22 _typedef" href=" │ │ │ │ -00009590: 6130 3133 3435 2e68 746d 6c23 6131 3733 a01345.html#a173 │ │ │ │ -000095a0: 6539 3865 3064 3162 3364 3135 6635 6333 e98e0d1b3d15f5c3 │ │ │ │ -000095b0: 6164 3433 3664 3066 6564 3430 3122 3e57 ad436d0fed401">W │ │ │ │ -000095c0: 6569 6768 743c 2f61 3e20 3c73 7061 6e20 eight │ │ │ │ -000095e0: 636f 6e73 743c 2f73 7061 6e3e 2661 6d70 const& │ │ │ │ -000095f0: 3b20 3c61 2063 6c61 7373 3d22 636f 6465 ; FaceWeight( in │ │ │ │ -00009670: 743c 2f73 7061 6e3e 2069 6e64 6578 293c t index)< │ │ │ │ -00009680: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00009690: 6f72 6422 3e20 636f 6e73 7420 3c2f 7370 ord"> const { r │ │ │ │ -000096c0: 6574 7572 6e3c 2f73 7061 6e3e 205f 6657 eturn _fW │ │ │ │ -000096d0: 6569 6768 7473 5b69 6e64 6578 5d3b 207d eights[index]; } │ │ │ │ -000096e0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00009730: 2032 3334 3c2f 7370 616e 3e20 3c2f 6469 234 .
│ │ │ │ -000097d0: 2020 3233 353c 2f61 3e3c 2f73 7061 6e3e 235 │ │ │ │ -000097e0: 2020 2020 2020 2020 3c61 2063 6c61 7373 Weight& VertexW │ │ │ │ -000098a0: 6569 6768 743c 2f61 3e28 3c73 7061 6e20 eight(int i │ │ │ │ -000098d0: 6e64 6578 2920 7b20 3c73 7061 6e20 636c ndex) { return │ │ │ │ -00009900: 5f76 5765 6967 6874 735b 696e 6465 785d _vWeights[index] │ │ │ │ -00009910: 3b20 7d3c 2f64 6976 3e0a 3c64 6976 2063 ; }
.
236 │ │ │ │ -000099b0: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ -000099c0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -000099d0: 5f74 7970 6564 6566 2220 6872 6566 3d22 _typedef" href=" │ │ │ │ -000099e0: 6130 3133 3435 2e68 746d 6c23 6131 3733 a01345.html#a173 │ │ │ │ -000099f0: 6539 3865 3064 3162 3364 3135 6635 6333 e98e0d1b3d15f5c3 │ │ │ │ -00009a00: 6164 3433 3664 3066 6564 3430 3122 3e57 ad436d0fed401">W │ │ │ │ -00009a10: 6569 6768 743c 2f61 3e26 616d 703b 203c eight& < │ │ │ │ -00009a20: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00009a30: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ -00009a40: 2261 3031 3334 352e 6874 6d6c 2361 3533 "a01345.html#a53 │ │ │ │ -00009a50: 3364 6261 3332 6139 3436 3835 3463 3366 3dba32a946854c3f │ │ │ │ -00009a60: 3235 6532 3762 3532 3165 6637 6466 223e 25e27b521ef7df"> │ │ │ │ -00009a70: 4564 6765 5765 6967 6874 3c2f 613e 2820 EdgeWeight( │ │ │ │ -00009a80: 203c 7370 616e 2063 6c61 7373 3d22 6b65 int index) { < │ │ │ │ -00009ab0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00009ac0: 6f72 6466 6c6f 7722 3e72 6574 7572 6e3c ordflow">return< │ │ │ │ -00009ad0: 2f73 7061 6e3e 205f 6557 6569 6768 7473 /span> _eWeights │ │ │ │ -00009ae0: 5b69 6e64 6578 5d3b 207d 3c2f 6469 763e [index]; }
│ │ │ │ -00009af0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00009b20: 3c2f 613e 3c73 7061 6e20 636c 6173 733d │ │ │ │ -00009b80: 3233 373c 2f61 3e3c 2f73 7061 6e3e 2020 237 │ │ │ │ -00009b90: 2020 2020 2020 3c61 2063 6c61 7373 3d22 Weight │ │ │ │ -00009bf0: 2661 6d70 3b20 3c61 2063 6c61 7373 3d22 & FaceWeigh │ │ │ │ -00009c50: 743c 2f61 3e28 2020 3c73 7061 6e20 636c t( int ind │ │ │ │ -00009c80: 6578 2920 7b20 3c73 7061 6e20 636c 6173 ex) { │ │ │ │ -00009ca0: 7265 7475 726e 3c2f 7370 616e 3e20 5f66 return _f │ │ │ │ -00009cb0: 5765 6967 6874 735b 696e 6465 785d 3b20 Weights[index]; │ │ │ │ -00009cc0: 7d3c 2f64 6976 3e0a 3c64 6976 2063 6c61 }
.
│ │ │ │ -00009d10: 2020 3233 383c 2f73 7061 6e3e 203c 2f64 238 .
239 bool < │ │ │ │ -00009df0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00009e00: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ -00009e10: 2261 3031 3334 352e 6874 6d6c 2361 3335 "a01345.html#a35 │ │ │ │ -00009e20: 3139 6535 6530 3536 3331 3032 3666 6164 19e5e05631026fad │ │ │ │ -00009e30: 3934 6337 3631 3666 3565 3065 3637 223e 94c7616f5e0e67"> │ │ │ │ -00009e40: 4172 6546 6163 6557 6569 6768 7473 466f AreFaceWeightsFo │ │ │ │ -00009e50: 7246 6163 6543 656e 7465 7273 3c2f 613e rFaceCenters │ │ │ │ -00009e60: 2829 3c73 7061 6e20 636c 6173 733d 226b () const │ │ │ │ -00009e80: 3c2f 7370 616e 3e7b 203c 7370 616e 2063 { return │ │ │ │ -00009eb0: 205f 6657 6569 6768 7473 466f 7243 656e _fWeightsForCen │ │ │ │ -00009ec0: 7465 7273 3b20 7d3c 2f64 6976 3e0a 3c64 ters; }
. │ │ │ │ -00009ee0: 3c61 2069 643d 226c 3030 3234 3022 206e 240 │ │ │ │ -00009f60: 3c2f 613e 3c2f 7370 616e 3e20 2020 2020 │ │ │ │ -00009f70: 2020 203c 7370 616e 2063 6c61 7373 3d22 voi │ │ │ │ -00009f90: 643c 2f73 7061 6e3e 203c 6120 636c 6173 d SetFac │ │ │ │ -00009ff0: 6557 6569 6768 7473 466f 7246 6163 6543 eWeightsForFaceC │ │ │ │ -0000a000: 656e 7465 7273 3c2f 613e 283c 7370 616e enters(bool │ │ │ │ -0000a030: 206f 6e29 207b 205f 6657 6569 6768 7473 on) { _fWeights │ │ │ │ -0000a040: 466f 7243 656e 7465 7273 203d 206f 6e3b ForCenters = on; │ │ │ │ -0000a050: 207d 3c2f 6469 763e 0a3c 6469 7620 636c }
.
241 .
2 │ │ │ │ -0000a100: 3432 3c2f 7370 616e 3e20 2020 203c 7370 42 public │ │ │ │ -0000a130: 3a3c 2f64 6976 3e0a 3c64 6976 2063 6c61 :
.
│ │ │ │ -0000a180: 2020 3234 333c 2f73 7061 6e3e 203c 2f64 243 .
24 │ │ │ │ -0000a1e0: 343c 2f73 7061 6e3e 2020 2020 2020 2020 4 │ │ │ │ -0000a1f0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ -0000a210: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000a260: 3234 353c 2f73 7061 6e3e 2020 2020 2020 245 │ │ │ │ -0000a270: 2020 3c73 7061 6e20 636c 6173 733d 2263 // Addi │ │ │ │ -0000a290: 7469 6f6e 616c 206d 6574 686f 6473 202d tional methods - │ │ │ │ -0000a2a0: 2d20 6d61 696e 6c79 2074 6865 2062 6c65 - mainly the ble │ │ │ │ -0000a2b0: 6e64 696e 6720 6d65 7468 6f64 2066 6f72 nding method for │ │ │ │ -0000a2c0: 2076 6572 7465 782d 7665 7274 6578 206d vertex-vertex m │ │ │ │ -0000a2d0: 6173 6b73 3a3c 2f73 7061 6e3e 3c2f 6469 asks:.
246 │ │ │ │ -0000a330: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ -0000a340: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -0000a350: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
2 │ │ │ │ -0000a3b0: 3437 3c2f 7370 616e 3e20 2020 2020 2020 47 │ │ │ │ -0000a3c0: 203c 7370 616e 2063 6c61 7373 3d22 6b65 template< │ │ │ │ -0000a3e0: 2f73 7061 6e3e 2026 6c74 3b3c 7370 616e /span> <typename │ │ │ │ -0000a410: 2055 5345 525f 4d41 534b 2667 743b 3c2f USER_MASK>.
2 │ │ │ │ -0000a470: 3438 3c2f 7370 616e 3e20 2020 2020 2020 48 │ │ │ │ -0000a480: 203c 7370 616e 2063 6c61 7373 3d22 6b65 inline v │ │ │ │ -0000a4c0: 6f69 643c 2f73 7061 6e3e 3c2f 6469 763e oid
│ │ │ │ -0000a4d0: 0a3c 6469 7620 636c 6173 733d 2266 6f6c .
.
< │ │ │ │ -0000a560: 6120 636c 6173 733d 226c 696e 6522 2068 a class="line" h │ │ │ │ -0000a570: 7265 663d 2261 3031 3334 352e 6874 6d6c ref="a01345.html │ │ │ │ -0000a580: 2361 3565 6438 3030 6539 6437 3032 6635 #a5ed800e9d702f5 │ │ │ │ -0000a590: 3761 6539 3738 6665 3630 6261 3261 3337 7ae978fe60ba2a37 │ │ │ │ -0000a5a0: 6463 223e 2020 3234 393c 2f61 3e3c 2f73 dc"> 249 Com │ │ │ │ -0000a610: 6269 6e65 5665 7274 6578 5665 7274 6578 bineVertexVertex │ │ │ │ -0000a620: 4d61 736b 733c 2f61 3e28 3c61 2063 6c61 Masks(Weight │ │ │ │ -0000a680: 3c2f 613e 2074 6869 7343 6f65 6666 2c20 thisCoeff, │ │ │ │ -0000a690: 3c61 2063 6c61 7373 3d22 636f 6465 2068 │ │ │ │ -0000a6e0: 5765 6967 6874 3c2f 613e 2064 7374 436f Weight dstCo │ │ │ │ -0000a6f0: 6566 662c 2055 5345 525f 4d41 534b 2661 eff, USER_MASK&a │ │ │ │ -0000a700: 6d70 3b20 6473 7429 3c73 7061 6e20 636c mp; dst) c │ │ │ │ -0000a720: 6f6e 7374 203c 2f73 7061 6e3e 7b3c 2f64 onst {.
25 │ │ │ │ -0000a780: 303c 2f73 7061 6e3e 203c 2f64 6976 3e0a 0
. │ │ │ │ -0000a790: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -0000a7c0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 251 │ │ │ │ -0000a7f0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ -0000a810: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000a860: 3235 323c 2f73 7061 6e3e 2020 2020 2020 252 │ │ │ │ -0000a870: 2020 2020 2020 3c73 7061 6e20 636c 6173 // │ │ │ │ -0000a890: 5468 6973 2069 6d70 6c65 6d65 6e74 6174 This implementat │ │ │ │ -0000a8a0: 696f 6e20 6973 2063 6f6e 766f 6c75 7465 ion is convolute │ │ │ │ -0000a8b0: 6420 6279 2074 6865 2070 6f74 656e 7469 d by the potenti │ │ │ │ -0000a8c0: 616c 2073 7061 7273 6974 7920 6f66 2065 al sparsity of e │ │ │ │ -0000a8d0: 6163 6820 6d61 736b 2e20 2053 696e 6365 ach mask. Since │ │ │ │ -0000a8e0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000a900: 3c61 2069 643d 226c 3030 3235 3322 206e 253 // it is sp │ │ │ │ -0000a970: 6563 6966 6963 2074 6f20 6120 7665 7274 ecific to a vert │ │ │ │ -0000a980: 6578 2d76 6572 7465 7820 6d61 736b 2c20 ex-vertex mask, │ │ │ │ -0000a990: 7765 2061 7265 2067 7561 7261 6e74 6565 we are guarantee │ │ │ │ -0000a9a0: 6420 746f 2068 6176 6520 6578 6163 746c d to have exactl │ │ │ │ -0000a9b0: 7920 6f6e 653c 2f73 7061 6e3e 3c2f 6469 y one.
254 │ │ │ │ -0000aa10: 3c2f 7370 616e 3e20 2020 2020 2020 2020 │ │ │ │ -0000aa20: 2020 203c 7370 616e 2063 6c61 7373 3d22 // ver │ │ │ │ -0000aa40: 7465 782d 7765 6967 6874 2066 6f72 2062 tex-weight for b │ │ │ │ -0000aa50: 6f74 6820 6d61 736b 732c 2062 7574 2074 oth masks, but t │ │ │ │ -0000aa60: 6865 2065 6467 652d 2061 6e64 2066 6163 he edge- and fac │ │ │ │ -0000aa70: 652d 7765 6967 6874 7320 6172 6520 6f70 e-weights are op │ │ │ │ -0000aa80: 7469 6f6e 616c 2e20 2054 6865 3c2f 7370 tional. The
.
255 │ │ │ │ -0000aaf0: 2020 2020 2020 2020 2020 3c73 7061 6e20 │ │ │ │ -0000ab10: 2f2f 2020 6368 696c 6420 6d61 736b 2028 // child mask ( │ │ │ │ -0000ab20: 7468 6520 2671 756f 743b 736f 7572 6365 the "source │ │ │ │ -0000ab30: 2671 756f 743b 2920 7368 6f75 6c64 2068 ") should h │ │ │ │ -0000ab40: 6176 6520 6120 7375 7065 7273 6574 206f ave a superset o │ │ │ │ -0000ab50: 6620 7468 6520 7765 6967 6874 7320 6f66 f the weights of │ │ │ │ -0000ab60: 2074 6865 2070 6172 656e 743c 2f73 7061 the parent
.
256 │ │ │ │ -0000abd0: 2020 2020 2020 2020 203c 7370 616e 2063 / │ │ │ │ -0000abf0: 2f20 2028 7468 6520 2671 756f 743b 6465 / (the "de │ │ │ │ -0000ac00: 7374 696e 6174 696f 6e26 7175 6f74 3b29 stination") │ │ │ │ -0000ac10: 2067 6976 656e 2069 7473 2072 6564 7563 given its reduc │ │ │ │ -0000ac20: 6564 2073 6861 7270 6e65 7373 2c20 736f ed sharpness, so │ │ │ │ -0000ac30: 2077 6520 666f 7274 756e 6174 656c 7920 we fortunately │ │ │ │ -0000ac40: 646f 6e26 2333 393b 7420 6e65 6564 2074 don't need t │ │ │ │ -0000ac50: 6f3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c o
.< │ │ │ │ -0000ac60: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000ac70: 3e3c 6120 6964 3d22 6c30 3032 3537 2220 > 257 < │ │ │ │ -0000acc0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -0000acd0: 656e 7422 3e2f 2f20 2074 6573 7420 616c ent">// test al │ │ │ │ -0000ace0: 6c20 7065 726d 7574 6174 696f 6e73 2e3c l permutations.< │ │ │ │ -0000acf0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -0000ad10: 6120 6964 3d22 6c30 3032 3538 2220 6e61 a id="l00258" na │ │ │ │ -0000ad20: 6d65 3d22 6c30 3032 3538 223e 3c2f 613e me="l00258"> │ │ │ │ -0000ad30: 3c73 7061 6e20 636c 6173 733d 226c 696e 258 //.
259 │ │ │ │ -0000add0: 3c2f 7370 616e 3e20 2020 2020 2020 2020 │ │ │ │ -0000ade0: 2020 2064 7374 2e56 6572 7465 7857 6569 dst.VertexWei │ │ │ │ -0000adf0: 6768 7428 3029 203d 2064 7374 436f 6566 ght(0) = dstCoef │ │ │ │ -0000ae00: 6620 2a20 6473 742e 5665 7274 6578 5765 f * dst.VertexWe │ │ │ │ -0000ae10: 6967 6874 2830 2920 2b20 7468 6973 436f ight(0) + thisCo │ │ │ │ -0000ae20: 6566 6620 2a20 7468 6973 2d26 6774 3b3c eff * this->< │ │ │ │ -0000ae30: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -0000ae40: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ -0000ae50: 2261 3031 3334 352e 6874 6d6c 2361 6563 "a01345.html#aec │ │ │ │ -0000ae60: 3563 3261 6266 6466 6264 6534 6464 3933 5c2abfdfbde4dd93 │ │ │ │ -0000ae70: 3463 3036 3136 3235 3939 3437 3931 223e 4c061625994791"> │ │ │ │ -0000ae80: 5665 7274 6578 5765 6967 6874 3c2f 613e VertexWeight │ │ │ │ -0000ae90: 2830 293b 3c2f 6469 763e 0a3c 6469 7620 (0);
.
260 │ │ │ │ -0000aef0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000af40: 2032 3631 3c2f 7370 616e 3e20 2020 2020 261 │ │ │ │ -0000af50: 2020 2020 2020 203c 7370 616e 2063 6c61 int edge │ │ │ │ -0000af80: 5765 6967 6874 436f 756e 7420 3d20 7468 WeightCount = th │ │ │ │ -0000af90: 6973 2d26 6774 3b3c 6120 636c 6173 733d is->GetNumEd │ │ │ │ -0000aff0: 6765 5765 6967 6874 733c 2f61 3e28 293b geWeights(); │ │ │ │ -0000b000: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000b050: 2032 3632 3c2f 7370 616e 3e20 2020 2020 262 │ │ │ │ -0000b060: 2020 2020 2020 203c 7370 616e 2063 6c61 if (edge │ │ │ │ -0000b090: 5765 6967 6874 436f 756e 7429 207b 3c2f WeightCount) {.
2 │ │ │ │ -0000b0f0: 3633 3c2f 7370 616e 3e20 2020 2020 2020 63 │ │ │ │ -0000b100: 2020 2020 2020 2020 203c 7370 616e 2063 if (ds │ │ │ │ -0000b130: 742e 4765 744e 756d 4564 6765 5765 6967 t.GetNumEdgeWeig │ │ │ │ -0000b140: 6874 7328 2920 3d3d 2030 2920 7b3c 2f64 hts() == 0) {.
26 │ │ │ │ -0000b1a0: 343c 2f73 7061 6e3e 2020 2020 2020 2020 4 │ │ │ │ -0000b1b0: 2020 2020 2020 2020 2020 2020 6473 742e dst. │ │ │ │ -0000b1c0: 5365 744e 756d 4564 6765 5765 6967 6874 SetNumEdgeWeight │ │ │ │ -0000b1d0: 7328 6564 6765 5765 6967 6874 436f 756e s(edgeWeightCoun │ │ │ │ -0000b1e0: 7429 3b3c 2f64 6976 3e0a 3c64 6976 2063 t);
.
265 │ │ │ │ -0000b240: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000b250: 2020 3c73 7061 6e20 636c 6173 733d 226b for< │ │ │ │ -0000b270: 2f73 7061 6e3e 2028 3c73 7061 6e20 636c /span> (int i = │ │ │ │ -0000b2a0: 2030 3b20 6920 266c 743b 2065 6467 6557 0; i < edgeW │ │ │ │ -0000b2b0: 6569 6768 7443 6f75 6e74 3b20 2b2b 6929 eightCount; ++i) │ │ │ │ -0000b2c0: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
266 │ │ │ │ -0000b320: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000b330: 2020 2020 2064 7374 2e45 6467 6557 6569 dst.EdgeWei │ │ │ │ -0000b340: 6768 7428 6929 203d 2074 6869 7343 6f65 ght(i) = thisCoe │ │ │ │ -0000b350: 6666 202a 2074 6869 732d 2667 743b 3c61 ff * this->E │ │ │ │ -0000b3b0: 6467 6557 6569 6768 743c 2f61 3e28 6929 dgeWeight(i) │ │ │ │ -0000b3c0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -0000b410: 2020 3236 373c 2f73 7061 6e3e 2020 2020 267 │ │ │ │ -0000b420: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000b430: 7d3c 2f64 6976 3e0a 3c64 6976 2063 6c61 }
.
│ │ │ │ -0000b480: 2020 3236 383c 2f73 7061 6e3e 2020 2020 268 │ │ │ │ -0000b490: 2020 2020 2020 2020 2020 2020 7d20 3c73 } else {
.
< │ │ │ │ -0000b500: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000b510: 6e6f 223e 2020 3236 393c 2f73 7061 6e3e no"> 269 │ │ │ │ -0000b520: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000b530: 2020 2020 3c73 7061 6e20 636c 6173 733d fo │ │ │ │ -0000b550: 723c 2f73 7061 6e3e 2028 3c73 7061 6e20 r (int i │ │ │ │ -0000b580: 203d 2030 3b20 6920 266c 743b 2065 6467 = 0; i < edg │ │ │ │ -0000b590: 6557 6569 6768 7443 6f75 6e74 3b20 2b2b eWeightCount; ++ │ │ │ │ -0000b5a0: 6929 207b 3c2f 6469 763e 0a3c 6469 7620 i) {
.
270 │ │ │ │ -0000b600: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000b610: 2020 2020 2020 2064 7374 2e45 6467 6557 dst.EdgeW │ │ │ │ -0000b620: 6569 6768 7428 6929 203d 2064 7374 436f eight(i) = dstCo │ │ │ │ -0000b630: 6566 6620 2a20 6473 742e 4564 6765 5765 eff * dst.EdgeWe │ │ │ │ -0000b640: 6967 6874 2869 2920 2b20 7468 6973 436f ight(i) + thisCo │ │ │ │ -0000b650: 6566 6620 2a20 7468 6973 2d26 6774 3b3c eff * this->< │ │ │ │ -0000b660: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -0000b670: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ -0000b680: 2261 3031 3334 352e 6874 6d6c 2361 3464 "a01345.html#a4d │ │ │ │ -0000b690: 6239 3332 6138 6133 3366 6430 3632 3263 b932a8a33fd0622c │ │ │ │ -0000b6a0: 3764 3031 3136 3765 6231 3462 3532 223e 7d01167eb14b52"> │ │ │ │ -0000b6b0: 4564 6765 5765 6967 6874 3c2f 613e 2869 EdgeWeight(i │ │ │ │ -0000b6c0: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
271 │ │ │ │ -0000b720: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000b730: 207d 3c2f 6469 763e 0a3c 6469 7620 636c }
.
272 │ │ │ │ -0000b790: 2020 2020 2020 2020 2020 2020 207d 3c2f }.
2 │ │ │ │ -0000b7f0: 3733 3c2f 7370 616e 3e20 2020 2020 2020 73 │ │ │ │ -0000b800: 2020 2020 207d 3c2f 6469 763e 0a3c 6469 }
.< │ │ │ │ -0000b820: 6120 6964 3d22 6c30 3032 3734 2220 6e61 a id="l00274" na │ │ │ │ -0000b830: 6d65 3d22 6c30 3032 3734 223e 3c2f 613e me="l00274"> │ │ │ │ -0000b840: 3c73 7061 6e20 636c 6173 733d 226c 696e 274
.
275 │ │ │ │ -0000b8c0: 2020 2020 2020 2020 203c 7370 616e 2063 int fa │ │ │ │ -0000b8f0: 6365 5765 6967 6874 436f 756e 7420 3d20 ceWeightCount = │ │ │ │ -0000b900: 7468 6973 2d26 6774 3b3c 6120 636c 6173 this->GetNum │ │ │ │ -0000b960: 4661 6365 5765 6967 6874 733c 2f61 3e28 FaceWeights( │ │ │ │ -0000b970: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
276 │ │ │ │ -0000b9d0: 2020 2020 2020 2020 203c 7370 616e 2063 if (fa │ │ │ │ -0000ba00: 6365 5765 6967 6874 436f 756e 7429 207b ceWeightCount) { │ │ │ │ -0000ba10: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000ba60: 2032 3737 3c2f 7370 616e 3e20 2020 2020 277 │ │ │ │ -0000ba70: 2020 2020 2020 2020 2020 203c 7370 616e //
│ │ │ │ -0000baa0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -0000bad0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 278 │ │ │ │ -0000bb00: 2020 2020 203c 7370 616e 2063 6c61 7373 // I │ │ │ │ -0000bb20: 6620 636f 6d62 696e 696e 6720 6661 6365 f combining face │ │ │ │ -0000bb30: 2077 6569 6768 7473 2c20 6265 2073 7572 weights, be sur │ │ │ │ -0000bb40: 6520 7468 6569 7220 696e 7465 7270 7265 e their interpre │ │ │ │ -0000bb50: 7461 7469 6f6e 2028 692e 652e 2066 6163 tation (i.e. fac │ │ │ │ -0000bb60: 652d 6365 6e74 6572 733c 2f73 7061 6e3e e-centers │ │ │ │ -0000bb70: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000bbc0: 2032 3739 3c2f 7370 616e 3e20 2020 2020 279 │ │ │ │ -0000bbd0: 2020 2020 2020 2020 2020 203c 7370 616e // or opposite │ │ │ │ -0000bc00: 2076 6572 7469 6365 7329 2069 7320 7072 vertices) is pr │ │ │ │ -0000bc10: 6f70 6572 6c79 2073 6574 2069 6e20 7468 operly set in th │ │ │ │ -0000bc20: 6520 6465 7374 696e 6174 696f 6e20 6d61 e destination ma │ │ │ │ -0000bc30: 736b 3a3c 2f73 7061 6e3e 3c2f 6469 763e sk:
│ │ │ │ -0000bc40: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -0000bc70: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 280 │ │ │ │ -0000bca0: 2020 2020 203c 7370 616e 2063 6c61 7373 //
.
281 │ │ │ │ -0000bd20: 2020 2020 2020 2020 2020 2020 2020 203c < │ │ │ │ -0000bd30: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -0000bd40: 6f72 6466 6c6f 7722 3e69 663c 2f73 7061 ordflow">if (dst.GetNumFa │ │ │ │ -0000bd60: 6365 5765 6967 6874 7328 2920 3d3d 2030 ceWeights() == 0 │ │ │ │ -0000bd70: 2920 7b3c 2f64 6976 3e0a 3c64 6976 2063 ) {
.
282 │ │ │ │ -0000bdd0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000bde0: 2020 6473 742e 5365 744e 756d 4661 6365 dst.SetNumFace │ │ │ │ -0000bdf0: 5765 6967 6874 7328 6661 6365 5765 6967 Weights(faceWeig │ │ │ │ -0000be00: 6874 436f 756e 7429 3b3c 2f64 6976 3e0a htCount);
. │ │ │ │ -0000be10: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
. │ │ │ │ -0000bf30: 3c61 2069 643d 226c 3030 3238 3422 206e 284
.
285 │ │ │ │ -0000bfd0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000bfe0: 2020 3c73 7061 6e20 636c 6173 733d 226b for< │ │ │ │ -0000c000: 2f73 7061 6e3e 2028 3c73 7061 6e20 636c /span> (int i = │ │ │ │ -0000c030: 2030 3b20 6920 266c 743b 2066 6163 6557 0; i < faceW │ │ │ │ -0000c040: 6569 6768 7443 6f75 6e74 3b20 2b2b 6929 eightCount; ++i) │ │ │ │ -0000c050: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
286 │ │ │ │ -0000c0b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000c0c0: 2020 2020 2064 7374 2e46 6163 6557 6569 dst.FaceWei │ │ │ │ -0000c0d0: 6768 7428 6929 203d 2074 6869 7343 6f65 ght(i) = thisCoe │ │ │ │ -0000c0e0: 6666 202a 2074 6869 732d 2667 743b 3c61 ff * this->F │ │ │ │ -0000c140: 6163 6557 6569 6768 743c 2f61 3e28 6929 aceWeight(i) │ │ │ │ -0000c150: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -0000c1a0: 2020 3238 373c 2f73 7061 6e3e 2020 2020 287 │ │ │ │ -0000c1b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000c1c0: 7d3c 2f64 6976 3e0a 3c64 6976 2063 6c61 }
.
│ │ │ │ -0000c210: 2020 3238 383c 2f73 7061 6e3e 2020 2020 288 │ │ │ │ -0000c220: 2020 2020 2020 2020 2020 2020 7d20 3c73 } else {
.
< │ │ │ │ -0000c290: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000c2a0: 6e6f 223e 2020 3238 393c 2f73 7061 6e3e no"> 289 │ │ │ │ -0000c2b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0000c2c0: 2020 2020 6173 7365 7274 2874 6869 732d assert(this- │ │ │ │ -0000c2d0: 2667 743b 3c61 2063 6c61 7373 3d22 636f >AreFaceWeig │ │ │ │ -0000c330: 6874 7346 6f72 4661 6365 4365 6e74 6572 htsForFaceCenter │ │ │ │ -0000c340: 733c 2f61 3e28 2920 3d3d 2064 7374 2e41 s() == dst.A │ │ │ │ -0000c350: 7265 4661 6365 5765 6967 6874 7346 6f72 reFaceWeightsFor │ │ │ │ -0000c360: 4661 6365 4365 6e74 6572 7328 2929 3b3c FaceCenters());< │ │ │ │ -0000c370: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000c3c0: 3239 303c 2f73 7061 6e3e 203c 2f64 6976 290
.
291< │ │ │ │ -0000c420: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ -0000c430: 2020 2020 2020 2020 2020 3c73 7061 6e20 for ( │ │ │ │ -0000c460: 3c73 7061 6e20 636c 6173 733d 226b 6579 int i = 0; i &l │ │ │ │ -0000c490: 743b 2066 6163 6557 6569 6768 7443 6f75 t; faceWeightCou │ │ │ │ -0000c4a0: 6e74 3b20 2b2b 6929 207b 3c2f 6469 763e nt; ++i) {
│ │ │ │ -0000c4b0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -0000c4e0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 292 │ │ │ │ -0000c510: 2020 2020 2020 2020 2020 2020 2064 7374 dst │ │ │ │ -0000c520: 2e46 6163 6557 6569 6768 7428 6929 203d .FaceWeight(i) = │ │ │ │ -0000c530: 2064 7374 436f 6566 6620 2a20 6473 742e dstCoeff * dst. │ │ │ │ -0000c540: 4661 6365 5765 6967 6874 2869 2920 2b20 FaceWeight(i) + │ │ │ │ -0000c550: 7468 6973 436f 6566 6620 2a20 7468 6973 thisCoeff * this │ │ │ │ -0000c560: 2d26 6774 3b3c 6120 636c 6173 733d 2263 ->FaceWeight │ │ │ │ -0000c5c0: 3c2f 613e 2869 293b 3c2f 6469 763e 0a3c (i);
.< │ │ │ │ -0000c5d0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000c5e0: 3e3c 6120 6964 3d22 6c30 3032 3933 2220 > 293 │ │ │ │ -0000c630: 2020 2020 2020 207d 3c2f 6469 763e 0a3c }
.< │ │ │ │ -0000c640: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000c650: 3e3c 6120 6964 3d22 6c30 3032 3934 2220 > 294 │ │ │ │ -0000c6a0: 2020 207d 3c2f 6469 763e 0a3c 6469 7620 }
.
295 │ │ │ │ -0000c700: 2020 2020 2020 2020 2020 207d 3c2f 6469 }.
296 │ │ │ │ -0000c760: 3c2f 7370 616e 3e20 2020 2020 2020 207d } │ │ │ │ -0000c770: 3c2f 6469 763e 0a3c 2f64 6976 3e0a 3c64
.
. │ │ │ │ -0000c790: 3c61 2069 643d 226c 3030 3239 3722 206e 297
.
298 │ │ │ │ -0000c830: 2020 3c73 7061 6e20 636c 6173 733d 226b private< │ │ │ │ -0000c850: 2f73 7061 6e3e 3a3c 2f64 6976 3e0a 3c64 /span>:
. │ │ │ │ -0000c870: 3c61 2069 643d 226c 3030 3239 3922 206e 299 Weight │ │ │ │ -0000c910: 3c2f 613e 2a20 5f76 5765 6967 6874 733b * _vWeights; │ │ │ │ -0000c920: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000c970: 2033 3030 3c2f 7370 616e 3e20 2020 2020 300 │ │ │ │ -0000c980: 2020 203c 6120 636c 6173 733d 2263 6f64 Weight* _ │ │ │ │ -0000c9e0: 6557 6569 6768 7473 3b3c 2f64 6976 3e0a eWeights;
. │ │ │ │ -0000c9f0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
302 │ │ │ │ -0000cb10: 2020 2020 203c 7370 616e 2063 6c61 7373 i │ │ │ │ -0000cb30: 6e74 3c2f 7370 616e 3e20 5f76 436f 756e nt _vCoun │ │ │ │ -0000cb40: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
303 │ │ │ │ -0000cba0: 2020 2020 203c 7370 616e 2063 6c61 7373 i │ │ │ │ -0000cbc0: 6e74 3c2f 7370 616e 3e20 5f65 436f 756e nt _eCoun │ │ │ │ -0000cbd0: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
304 │ │ │ │ -0000cc30: 2020 2020 203c 7370 616e 2063 6c61 7373 i │ │ │ │ -0000cc50: 6e74 3c2f 7370 616e 3e20 5f66 436f 756e nt _fCoun │ │ │ │ -0000cc60: 743b 3c2f 6469 763e 0a3c 6469 7620 636c t;
.
305 │ │ │ │ -0000ccc0: 2020 2020 203c 7370 616e 2063 6c61 7373 b │ │ │ │ -0000cce0: 6f6f 6c3c 2f73 7061 6e3e 205f 6657 6569 ool _fWei │ │ │ │ -0000ccf0: 6768 7473 466f 7243 656e 7465 7273 3b3c ghtsForCenters;< │ │ │ │ -0000cd00: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000cd50: 3330 363c 2f73 7061 6e3e 2020 2020 7d3b 306 }; │ │ │ │ -0000cd60: 3c2f 6469 763e 0a3c 2f64 6976 3e0a 3c64
.
. │ │ │ │ -0000cd80: 3c61 2069 643d 226c 3030 3330 3722 206e 307};
.
.
308< │ │ │ │ -0000ce20: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ -0000ce40: 3c61 2069 643d 226c 3030 3330 3922 206e 309
.
310//.
31 │ │ │ │ -0000cf50: 313c 2f73 7061 6e3e 3c73 7061 6e20 636c 1// │ │ │ │ -0000cf70: 2020 4372 6561 7365 2061 6e64 2063 6f72 Crease and cor │ │ │ │ -0000cf80: 6e65 7220 6d61 736b 7320 6172 6520 636f ner masks are co │ │ │ │ -0000cf90: 6d6d 6f6e 2074 6f20 6d6f 7374 2073 6368 mmon to most sch │ │ │ │ -0000cfa0: 656d 6573 202d 2d20 7468 6520 7265 7374 emes -- the rest │ │ │ │ -0000cfb0: 206e 6565 6420 746f 2062 6520 7072 6f76 need to be prov │ │ │ │ -0000cfc0: 6964 6564 3c2f 7370 616e 3e3c 2f64 6976 ided
.
312< │ │ │ │ -0000d020: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -0000d040: 666f 7220 6561 6368 2053 6368 656d 6520 for each Scheme │ │ │ │ -0000d050: 7370 6563 6961 6c69 7a61 7469 6f6e 2e3c specialization.< │ │ │ │ -0000d060: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -0000d080: 6120 6964 3d22 6c30 3033 3133 2220 6e61 a id="l00313" na │ │ │ │ -0000d090: 6d65 3d22 6c30 3033 3133 223e 3c2f 613e me="l00313"> │ │ │ │ -0000d0a0: 3c73 7061 6e20 636c 6173 733d 226c 696e 313// │ │ │ │ -0000d0e0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000d130: 2033 3134 3c2f 7370 616e 3e3c 7370 616e 314template │ │ │ │ -0000d160: 2026 6c74 3b53 6368 656d 6554 7970 6520 <SchemeType │ │ │ │ -0000d170: 5343 4845 4d45 2667 743b 3c2f 6469 763e SCHEME>
│ │ │ │ -0000d180: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -0000d1b0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 315templ │ │ │ │ -0000d1f0: 6174 653c 2f73 7061 6e3e 2026 6c74 3b3c ate << │ │ │ │ -0000d200: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -0000d210: 6f72 6422 3e74 7970 656e 616d 653c 2f73 ord">typename EDGE, typename │ │ │ │ -0000d250: 204d 4153 4b26 6774 3b3c 2f64 6976 3e0a MASK>
. │ │ │ │ -0000d260: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -0000d290: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 316inline │ │ │ │ -0000d2d0: 3c2f 7370 616e 3e20 3c73 7061 6e20 636c void.
.
317 │ │ │ │ -0000d3e0: 3c2f 7370 616e 3e3c 6120 636c 6173 733d Scheme&l │ │ │ │ -0000d440: 743b 5343 4845 4d45 2667 743b 3a3a 6173 t;SCHEME>::as │ │ │ │ -0000d450: 7369 676e 4372 6561 7365 4d61 736b 466f signCreaseMaskFo │ │ │ │ -0000d460: 7245 6467 653c 2f61 3e28 4544 4745 203c rEdge(EDGE < │ │ │ │ -0000d470: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -0000d480: 6f72 6422 3e63 6f6e 7374 3c2f 7370 616e ord">const&, MASK& │ │ │ │ -0000d4a0: 3b20 6d61 736b 293c 7370 616e 2063 6c61 ; mask) co │ │ │ │ -0000d4c0: 6e73 7420 3c2f 7370 616e 3e7b 3c2f 6469 nst {.
318 │ │ │ │ -0000d520: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ -0000d530: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000d540: 3e3c 6120 6964 3d22 6c30 3033 3139 2220 > 319
mask.SetN │ │ │ │ -0000d590: 756d 5665 7274 6578 5765 6967 6874 7328 umVertexWeights( │ │ │ │ -0000d5a0: 3229 3b3c 2f64 6976 3e0a 3c64 6976 2063 2);
.
320 │ │ │ │ -0000d600: 2020 6d61 736b 2e53 6574 4e75 6d45 6467 mask.SetNumEdg │ │ │ │ -0000d610: 6557 6569 6768 7473 2830 293b 3c2f 6469 eWeights(0);.
321 │ │ │ │ -0000d670: 3c2f 7370 616e 3e20 2020 206d 6173 6b2e mask. │ │ │ │ -0000d680: 5365 744e 756d 4661 6365 5765 6967 6874 SetNumFaceWeight │ │ │ │ -0000d690: 7328 3029 3b3c 2f64 6976 3e0a 3c64 6976 s(0);
.
< │ │ │ │ -0000d6d0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000d6e0: 6e6f 223e 2020 3332 323c 2f73 7061 6e3e no"> 322 │ │ │ │ -0000d6f0: 2020 2020 6d61 736b 2e53 6574 4661 6365 mask.SetFace │ │ │ │ -0000d700: 5765 6967 6874 7346 6f72 4661 6365 4365 WeightsForFaceCe │ │ │ │ -0000d710: 6e74 6572 7328 3c73 7061 6e20 636c 6173 nters(fals │ │ │ │ -0000d730: 653c 2f73 7061 6e3e 293b 3c2f 6469 763e e);
│ │ │ │ -0000d740: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -0000d7b0: 6120 6964 3d22 6c30 3033 3234 2220 6e61 a id="l00324" na │ │ │ │ -0000d7c0: 6d65 3d22 6c30 3033 3234 223e 3c2f 613e me="l00324"> │ │ │ │ -0000d7d0: 3c73 7061 6e20 636c 6173 733d 226c 696e 324 mask.Vertex │ │ │ │ -0000d800: 5765 6967 6874 2830 2920 3d20 302e 3566 Weight(0) = 0.5f │ │ │ │ -0000d810: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -0000d860: 2020 3332 353c 2f73 7061 6e3e 2020 2020 325 │ │ │ │ -0000d870: 6d61 736b 2e56 6572 7465 7857 6569 6768 mask.VertexWeigh │ │ │ │ -0000d880: 7428 3129 203d 2030 2e35 663b 3c2f 6469 t(1) = 0.5f;.
326 │ │ │ │ -0000d8e0: 3c2f 7370 616e 3e7d 3c2f 6469 763e 0a3c }
.< │ │ │ │ -0000d8f0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0000d940: 3332 373c 2f73 7061 6e3e 203c 2f64 6976 327
.
328< │ │ │ │ -0000d9a0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>temp │ │ │ │ -0000d9c0: 6c61 7465 3c2f 7370 616e 3e20 266c 743b late < │ │ │ │ -0000d9d0: 5363 6865 6d65 5479 7065 2053 4348 454d SchemeType SCHEM │ │ │ │ -0000d9e0: 4526 6774 3b3c 2f64 6976 3e0a 3c64 6976 E>
.
< │ │ │ │ -0000da20: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000da30: 6e6f 223e 2020 3332 393c 2f73 7061 6e3e no"> 329 │ │ │ │ -0000da40: 3c73 7061 6e20 636c 6173 733d 226b 6579 template < │ │ │ │ -0000da80: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ -0000da90: 5645 5254 4558 2c20 3c73 7061 6e20 636c VERTEX, ty │ │ │ │ -0000dab0: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ -0000dac0: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ -0000dae0: 6120 6964 3d22 6c30 3033 3330 2220 6e61 a id="l00330" na │ │ │ │ -0000daf0: 6d65 3d22 6c30 3033 3330 223e 3c2f 613e me="l00330"> │ │ │ │ -0000db00: 3c73 7061 6e20 636c 6173 733d 226c 696e 330inline
v │ │ │ │ -0000db60: 6f69 643c 2f73 7061 6e3e 3c2f 6469 763e oid
│ │ │ │ -0000db70: 0a3c 6469 7620 636c 6173 733d 2266 6f6c .
.
< │ │ │ │ -0000dc00: 6120 636c 6173 733d 226c 696e 6522 2068 a class="line" h │ │ │ │ -0000dc10: 7265 663d 2261 3031 3334 312e 6874 6d6c ref="a01341.html │ │ │ │ -0000dc20: 2361 3737 3634 3466 3639 6564 6530 3366 #a77644f69ede03f │ │ │ │ -0000dc30: 6136 3232 3232 6436 3061 3939 3937 3032 a62222d60a999702 │ │ │ │ -0000dc40: 3338 223e 2020 3333 313c 2f61 3e3c 2f73 38"> 331Scheme<S │ │ │ │ -0000dcb0: 4348 454d 4526 6774 3b3a 3a61 7373 6967 CHEME>::assig │ │ │ │ -0000dcc0: 6e43 6f72 6e65 724d 6173 6b46 6f72 5665 nCornerMaskForVe │ │ │ │ -0000dcd0: 7274 6578 3c2f 613e 2856 4552 5445 5820 rtex(VERTEX │ │ │ │ -0000dce0: 3c73 7061 6e20 636c 6173 733d 226b 6579 const&, MASK&am │ │ │ │ -0000dd10: 703b 206d 6173 6b29 3c73 7061 6e20 636c p; mask) c │ │ │ │ -0000dd30: 6f6e 7374 203c 2f73 7061 6e3e 7b3c 2f64 onst {.
33 │ │ │ │ -0000dd90: 323c 2f73 7061 6e3e 203c 2f64 6976 3e0a 2
. │ │ │ │ -0000dda0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
334 │ │ │ │ -0000de70: 2020 206d 6173 6b2e 5365 744e 756d 4564 mask.SetNumEd │ │ │ │ -0000de80: 6765 5765 6967 6874 7328 3029 3b3c 2f64 geWeights(0);.
33 │ │ │ │ -0000dee0: 353c 2f73 7061 6e3e 2020 2020 6d61 736b 5 mask │ │ │ │ -0000def0: 2e53 6574 4e75 6d46 6163 6557 6569 6768 .SetNumFaceWeigh │ │ │ │ -0000df00: 7473 2830 293b 3c2f 6469 763e 0a3c 6469 ts(0);
.< │ │ │ │ -0000df20: 6120 6964 3d22 6c30 3033 3336 2220 6e61 a id="l00336" na │ │ │ │ -0000df30: 6d65 3d22 6c30 3033 3336 223e 3c2f 613e me="l00336"> │ │ │ │ -0000df40: 3c73 7061 6e20 636c 6173 733d 226c 696e 336 mask.SetFac │ │ │ │ -0000df70: 6557 6569 6768 7473 466f 7246 6163 6543 eWeightsForFaceC │ │ │ │ -0000df80: 656e 7465 7273 283c 7370 616e 2063 6c61 enters(fal │ │ │ │ -0000dfa0: 7365 3c2f 7370 616e 3e29 3b3c 2f64 6976 se);
.
337< │ │ │ │ -0000e000: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ -0000e020: 3c61 2069 643d 226c 3030 3333 3822 206e 338 mask.Verte │ │ │ │ -0000e070: 7857 6569 6768 7428 3029 203d 2031 2e30 xWeight(0) = 1.0 │ │ │ │ -0000e080: 663b 3c2f 6469 763e 0a3c 6469 7620 636c f;
.
339}.
.
< │ │ │ │ -0000e120: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000e130: 6e6f 223e 2020 3334 303c 2f73 7061 6e3e no"> 340 │ │ │ │ -0000e140: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ -0000e190: 2020 3334 313c 2f73 7061 6e3e 203c 2f64 341 .
34 │ │ │ │ -0000e1f0: 323c 2f73 7061 6e3e 3c73 7061 6e20 636c 2// │ │ │ │ -0000e210: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000e230: 3c61 2069 643d 226c 3030 3334 3322 206e 343// The │ │ │ │ -0000e290: 636f 6d70 7574 6174 696f 6e20 6f66 2061 computation of a │ │ │ │ -0000e2a0: 2066 6163 652d 7665 7274 6578 206d 6173 face-vertex mas │ │ │ │ -0000e2b0: 6b20 6973 2074 7269 7669 616c 2061 6e64 k is trivial and │ │ │ │ -0000e2c0: 2063 6f6e 7369 7374 656e 7420 666f 7220 consistent for │ │ │ │ -0000e2d0: 616c 6c20 7363 6865 6d65 733a 3c2f 7370 all schemes:
.
344//.
34 │ │ │ │ -0000e3b0: 353c 2f73 7061 6e3e 3c73 7061 6e20 636c 5te │ │ │ │ -0000e3d0: 6d70 6c61 7465 3c2f 7370 616e 3e20 266c mplate &l │ │ │ │ -0000e3e0: 743b 5363 6865 6d65 5479 7065 2053 4348 t;SchemeType SCH │ │ │ │ -0000e3f0: 454d 4526 6774 3b3c 2f64 6976 3e0a 3c64 EME>
. │ │ │ │ -0000e410: 3c61 2069 643d 226c 3030 3334 3622 206e 346template │ │ │ │ -0000e470: 3c2f 7370 616e 3e20 266c 743b 3c73 7061 <typename FACE, ty │ │ │ │ -0000e4c0: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ -0000e4d0: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ -0000e4f0: 6120 6964 3d22 6c30 3033 3437 2220 6e61 a id="l00347" na │ │ │ │ -0000e500: 6d65 3d22 6c30 3033 3437 223e 3c2f 613e me="l00347"> │ │ │ │ -0000e510: 3c73 7061 6e20 636c 6173 733d 226c 696e 347void< │ │ │ │ -0000e550: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
..
│ │ │ │ -0000e630: 2020 3334 383c 2f61 3e3c 2f73 7061 6e3e 348 │ │ │ │ -0000e640: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Scheme<SCHEM │ │ │ │ -0000e6a0: 4526 6774 3b3a 3a43 6f6d 7075 7465 4661 E>::ComputeFa │ │ │ │ -0000e6b0: 6365 5665 7274 6578 4d61 736b 3c2f 613e ceVertexMask │ │ │ │ -0000e6c0: 2846 4143 4520 3c73 7061 6e20 636c 6173 (FACE cons │ │ │ │ -0000e6e0: 743c 2f73 7061 6e3e 2661 6d70 3b20 6661 t& fa │ │ │ │ -0000e6f0: 6365 2c20 4d41 534b 2661 6d70 3b20 6d61 ce, MASK& ma │ │ │ │ -0000e700: 736b 293c 7370 616e 2063 6c61 7373 3d22 sk) const │ │ │ │ -0000e720: 3c2f 7370 616e 3e7b 3c2f 6469 763e 0a3c {
.< │ │ │ │ -0000e730: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000e740: 3e3c 6120 6964 3d22 6c30 3033 3439 2220 > 349
.
350 │ │ │ │ -0000e7e0: 2020 203c 7370 616e 2063 6c61 7373 3d22 int │ │ │ │ -0000e800: 3c2f 7370 616e 3e20 7665 7274 436f 756e vertCoun │ │ │ │ -0000e810: 7420 3d20 6661 6365 2e47 6574 4e75 6d56 t = face.GetNumV │ │ │ │ -0000e820: 6572 7469 6365 7328 293b 3c2f 6469 763e ertices();
│ │ │ │ -0000e830: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -0000e8a0: 6120 6964 3d22 6c30 3033 3532 2220 6e61 a id="l00352" na │ │ │ │ -0000e8b0: 6d65 3d22 6c30 3033 3532 223e 3c2f 613e me="l00352"> │ │ │ │ -0000e8c0: 3c73 7061 6e20 636c 6173 733d 226c 696e 352 mask.SetNum │ │ │ │ -0000e8f0: 5665 7274 6578 5765 6967 6874 7328 7665 VertexWeights(ve │ │ │ │ -0000e900: 7274 436f 756e 7429 3b3c 2f64 6976 3e0a rtCount);
. │ │ │ │ -0000e910: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
354 │ │ │ │ -0000e9e0: 206d 6173 6b2e 5365 744e 756d 4661 6365 mask.SetNumFace │ │ │ │ -0000e9f0: 5765 6967 6874 7328 3029 3b3c 2f64 6976 Weights(0);
.
355< │ │ │ │ -0000ea50: 2f73 7061 6e3e 2020 2020 6d61 736b 2e53 /span> mask.S │ │ │ │ -0000ea60: 6574 4661 6365 5765 6967 6874 7346 6f72 etFaceWeightsFor │ │ │ │ -0000ea70: 4661 6365 4365 6e74 6572 7328 3c73 7061 FaceCenters(false); │ │ │ │ -0000eaa0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000eaf0: 2033 3536 3c2f 7370 616e 3e20 3c2f 6469 356 .
357 │ │ │ │ -0000eb50: 3c2f 7370 616e 3e20 2020 203c 7370 616e typename │ │ │ │ -0000eb80: 204d 4153 4b3a 3a57 6569 6768 7420 7657 MASK::Weight vW │ │ │ │ -0000eb90: 6569 6768 7420 3d20 312e 3066 202f 2028 eight = 1.0f / ( │ │ │ │ -0000eba0: 3c73 7061 6e20 636c 6173 733d 226b 6579 typename MASK::Weig │ │ │ │ -0000ebd0: 6874 2920 7665 7274 436f 756e 743b 3c2f ht) vertCount;.
3 │ │ │ │ -0000ec30: 3538 3c2f 7370 616e 3e20 2020 203c 7370 58 for (int │ │ │ │ -0000ec80: 3c2f 7370 616e 3e20 6920 3d20 303b 2069 i = 0; i │ │ │ │ -0000ec90: 2026 6c74 3b20 7665 7274 436f 756e 743b < vertCount; │ │ │ │ -0000eca0: 202b 2b69 2920 7b3c 2f64 6976 3e0a 3c64 ++i) {
. │ │ │ │ -0000ecc0: 3c61 2069 643d 226c 3030 3335 3922 206e 359 mask.V │ │ │ │ -0000ed10: 6572 7465 7857 6569 6768 7428 6929 203d ertexWeight(i) = │ │ │ │ -0000ed20: 2076 5765 6967 6874 3b3c 2f64 6976 3e0a vWeight;
. │ │ │ │ -0000ed30: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
. │ │ │ │ -0000ed90: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
..
362 │ │ │ │ -0000ee40: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ -0000ee50: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000ee60: 3e3c 6120 6964 3d22 6c30 3033 3633 2220 > 363
.
364< │ │ │ │ -0000ef00: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -0000ef10: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
3 │ │ │ │ -0000ef70: 3635 3c2f 7370 616e 3e3c 7370 616e 2063 65/ │ │ │ │ -0000ef90: 2f20 2054 6865 2063 6f6d 7075 7461 7469 / The computati │ │ │ │ -0000efa0: 6f6e 206f 6620 616e 2065 6467 652d 7665 on of an edge-ve │ │ │ │ -0000efb0: 7274 6578 206d 6173 6b20 7265 7175 6972 rtex mask requir │ │ │ │ -0000efc0: 6573 2069 6e73 7065 6374 696f 6e20 6f66 es inspection of │ │ │ │ -0000efd0: 2073 6861 7270 6e65 7373 2076 616c 7565 sharpness value │ │ │ │ -0000efe0: 7320 746f 3c2f 7370 616e 3e3c 2f64 6976 s to
.
366< │ │ │ │ -0000f040: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -0000f060: 6465 7465 726d 696e 6520 6966 2073 6d6f determine if smo │ │ │ │ -0000f070: 6f74 6820 6f72 2061 2063 7265 6173 652c oth or a crease, │ │ │ │ -0000f080: 2061 6e64 2061 6c73 6f20 746f 2064 6574 and also to det │ │ │ │ -0000f090: 6563 7420 616e 6420 6170 706c 7920 6120 ect and apply a │ │ │ │ -0000f0a0: 7472 616e 7369 7469 6f6e 2066 726f 6d20 transition from │ │ │ │ -0000f0b0: 613c 2f73 7061 6e3e 3c2f 6469 763e 0a3c a
.< │ │ │ │ -0000f0c0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000f0d0: 3e3c 6120 6964 3d22 6c30 3033 3637 2220 > 367// cre │ │ │ │ -0000f130: 6173 6520 746f 2073 6d6f 6f74 682e 2020 ase to smooth. │ │ │ │ -0000f140: 5573 696e 6720 7468 6520 7072 6f74 6563 Using the protec │ │ │ │ -0000f150: 7465 6420 6d65 7468 6f64 7320 746f 2061 ted methods to a │ │ │ │ -0000f160: 7373 6967 6e20 7468 6520 7370 6563 6966 ssign the specif │ │ │ │ -0000f170: 6963 206d 6173 6b73 2028 6f6e 6c79 3c2f ic masks (only
.
< │ │ │ │ -0000f1c0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0000f1d0: 6e6f 223e 2020 3336 383c 2f73 7061 6e3e no"> 368 │ │ │ │ -0000f1e0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // two -- │ │ │ │ -0000f200: 2073 6d6f 6f74 6820 6f72 2063 7265 6173 smooth or creas │ │ │ │ -0000f210: 6529 2074 6869 7320 696d 706c 656d 656e e) this implemen │ │ │ │ -0000f220: 7461 7469 6f6e 2073 686f 756c 6420 7365 tation should se │ │ │ │ -0000f230: 7276 6520 616c 6c20 6e6f 6e2d 6c69 6e65 rve all non-line │ │ │ │ -0000f240: 6172 2073 6368 656d 6573 3c2f 7370 616e ar schemes
.
│ │ │ │ -0000f2a0: 2020 3336 393c 2f73 7061 6e3e 3c73 7061 369// (currently │ │ │ │ -0000f2d0: 2043 6174 6d61 726b 2061 6e64 204c 6f6f Catmark and Loo │ │ │ │ -0000f2e0: 7029 2061 6e64 206f 6e6c 7920 6e65 6564 p) and only need │ │ │ │ -0000f2f0: 7320 746f 2062 6520 7370 6563 6961 6c69 s to be speciali │ │ │ │ -0000f300: 7a65 6420 666f 7220 4269 6c69 6e65 6172 zed for Bilinear │ │ │ │ -0000f310: 2074 6f3c 2f73 7061 6e3e 3c2f 6469 763e to
│ │ │ │ -0000f320: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -0000f350: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 370// t │ │ │ │ -0000f390: 7269 7669 616c 697a 6520 6974 2074 6f20 rivialize it to │ │ │ │ -0000f3a0: 7468 6520 6372 6561 7365 2063 6173 652e the crease case. │ │ │ │ -0000f3b0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000f3d0: 3c61 2069 643d 226c 3030 3337 3122 206e 371//
.
│ │ │ │ -0000f480: 2020 3337 323c 2f73 7061 6e3e 3c73 7061 372// The implem │ │ │ │ -0000f4b0: 656e 7461 7469 6f6e 2068 6572 6520 6973 entation here is │ │ │ │ -0000f4c0: 2073 6c69 6768 746c 7920 636f 6d70 6c69 slightly compli │ │ │ │ -0000f4d0: 6361 7465 6420 6279 2063 6f6d 6269 6e69 cated by combini │ │ │ │ -0000f4e0: 6e67 2074 776f 2073 6365 6e61 7269 6f73 ng two scenarios │ │ │ │ -0000f4f0: 2069 6e74 6f20 613c 2f73 7061 6e3e 3c2f into a.
3 │ │ │ │ -0000f550: 3733 3c2f 7370 616e 3e3c 7370 616e 2063 73/ │ │ │ │ -0000f570: 2f20 2073 696e 676c 6520 696d 706c 656d / single implem │ │ │ │ -0000f580: 656e 7461 7469 6f6e 202d 2d20 6569 7468 entation -- eith │ │ │ │ -0000f590: 6572 2074 6865 2063 616c 6c65 7220 6b6e er the caller kn │ │ │ │ -0000f5a0: 6f77 7320 7468 6520 7061 7265 6e74 2061 ows the parent a │ │ │ │ -0000f5b0: 6e64 2063 6869 6c64 2072 756c 6573 2061 nd child rules a │ │ │ │ -0000f5c0: 6e64 3c2f 7370 616e 3e3c 2f64 6976 3e0a nd
. │ │ │ │ -0000f5d0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.< │ │ │ │ -0000f6a0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000f6b0: 3e3c 6120 6964 3d22 6c30 3033 3735 2220 > 375// val │ │ │ │ -0000f710: 7565 732e 2020 426f 7468 2063 6173 6573 ues. Both cases │ │ │ │ -0000f720: 2069 6e63 6c75 6465 2071 7569 636b 2072 include quick r │ │ │ │ -0000f730: 6574 7572 6e20 6f6e 6365 2074 6865 2070 eturn once the p │ │ │ │ -0000f740: 6172 656e 7420 6973 2064 6574 6572 6d69 arent is determi │ │ │ │ -0000f750: 6e65 6420 746f 2062 653c 2f73 7061 6e3e ned to be │ │ │ │ -0000f760: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0000f7b0: 2033 3736 3c2f 7370 616e 3e3c 7370 616e 376// smooth or t │ │ │ │ -0000f7e0: 6865 2063 6869 6c64 2061 2063 7265 6173 he child a creas │ │ │ │ -0000f7f0: 652c 206c 6561 7669 6e67 2074 6865 2074 e, leaving the t │ │ │ │ -0000f800: 7261 6e73 6974 696f 6e61 6c20 6361 7365 ransitional case │ │ │ │ -0000f810: 2072 656d 6169 6e69 6e67 2e3c 2f73 7061 remaining.
.
377//.
378 │ │ │ │ -0000f8f0: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ -0000f910: 2054 6865 206f 7665 7261 6c6c 2070 726f The overall pro │ │ │ │ -0000f920: 6365 7373 2069 7320 6173 2066 6f6c 6c6f cess is as follo │ │ │ │ -0000f930: 7773 3a3c 2f73 7061 6e3e 3c2f 6469 763e ws:
│ │ │ │ -0000f940: 0a3c 6469 7620 636c 6173 733d 226c 696e .
.
380< │ │ │ │ -0000fa10: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -0000fa20: 656e 7422 3e2f 2f20 2020 2020 202d 2071 ent">// - q │ │ │ │ -0000fa30: 7569 636b 6c79 2064 6574 6563 7420 7468 uickly detect th │ │ │ │ -0000fa40: 6520 6d6f 7374 2063 6f6d 6d6f 6e20 7370 e most common sp │ │ │ │ -0000fa50: 6563 6966 6965 6420 6f72 2064 6574 6563 ecified or detec │ │ │ │ -0000fa60: 7465 6420 536d 6f6f 7468 2063 6173 6520 ted Smooth case │ │ │ │ -0000fa70: 616e 6420 7265 7475 726e 3c2f 7370 616e and return
.
│ │ │ │ -0000fad0: 2020 3338 313c 2f73 7061 6e3e 3c73 7061 381// - quic │ │ │ │ -0000fb00: 6b6c 7920 6465 7465 6374 2061 2066 756c kly detect a ful │ │ │ │ -0000fb10: 6c20 4372 6561 7365 2062 7920 6368 696c l Crease by chil │ │ │ │ -0000fb20: 6420 5275 6c65 2061 7373 6967 6e6d 656e d Rule assignmen │ │ │ │ -0000fb30: 7420 616e 6420 7265 7475 726e 3c2f 7370 t and return
.
382// - de │ │ │ │ -0000fbc0: 7465 726d 696e 6520 6672 6f6d 2073 6861 termine from sha │ │ │ │ -0000fbd0: 7270 6e65 7373 2069 6620 756e 7370 6563 rpness if unspec │ │ │ │ -0000fbe0: 6966 6965 6420 6368 696c 6420 6973 2061 ified child is a │ │ │ │ -0000fbf0: 2063 7265 6173 6520 2d2d 2072 6574 7572 crease -- retur │ │ │ │ -0000fc00: 6e20 6966 2073 6f3c 2f73 7061 6e3e 3c2f n if so.
3 │ │ │ │ -0000fc60: 3833 3c2f 7370 616e 3e3c 7370 616e 2063 83/ │ │ │ │ -0000fc80: 2f20 2020 2020 202d 2063 6f6d 7075 7465 / - compute │ │ │ │ -0000fc90: 2073 6d6f 6f74 6820 6d61 736b 2066 6f72 smooth mask for │ │ │ │ -0000fca0: 2063 6869 6c64 2061 6e64 2063 6f6d 6269 child and combi │ │ │ │ -0000fcb0: 6e65 2077 6974 6820 6372 6561 7365 2066 ne with crease f │ │ │ │ -0000fcc0: 726f 6d20 7061 7265 6e74 3c2f 7370 616e rom parent
.
│ │ │ │ -0000fd20: 2020 3338 343c 2f73 7061 6e3e 3c73 7061 384//
.
385< │ │ │ │ -0000fda0: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -0000fdc0: 5573 6167 6520 6f66 2074 6865 2070 6172 Usage of the par │ │ │ │ -0000fdd0: 656e 7420 5275 6c65 2068 6572 6520 616c ent Rule here al │ │ │ │ -0000fde0: 6c6f 7773 2073 6f6d 6520 6d69 7375 7365 lows some misuse │ │ │ │ -0000fdf0: 2069 6e20 7468 6174 206f 6e6c 7920 7468 in that only th │ │ │ │ -0000fe00: 7265 6520 6f66 2066 6976 6520 706f 7373 ree of five poss │ │ │ │ -0000fe10: 6962 6c65 3c2f 7370 616e 3e3c 2f64 6976 ible
.
386< │ │ │ │ -0000fe70: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -0000fe90: 6173 7369 676e 6d65 6e74 7320 6172 6520 assignments are │ │ │ │ -0000fea0: 6c65 6769 7469 6d61 7465 2066 6f72 2074 legitimate for t │ │ │ │ -0000feb0: 6865 2070 6172 656e 7420 616e 6420 666f he parent and fo │ │ │ │ -0000fec0: 7572 2066 6f72 2074 6865 2063 6869 6c64 ur for the child │ │ │ │ -0000fed0: 2028 4461 7274 2062 6569 6e67 206f 6e6c (Dart being onl │ │ │ │ -0000fee0: 793c 2f73 7061 6e3e 3c2f 6469 763e 0a3c y
.< │ │ │ │ -0000fef0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0000ff00: 3e3c 6120 6964 3d22 6c30 3033 3837 2220 > 387
// val │ │ │ │ -0000ff60: 6964 2066 6f72 2074 6865 2063 6869 6c64 id for the child │ │ │ │ -0000ff70: 2061 6e64 2043 6f72 6e65 7220 666f 7220 and Corner for │ │ │ │ -0000ff80: 6e65 6974 6865 7229 2e20 2052 6573 756c neither). Resul │ │ │ │ -0000ff90: 7473 2061 7265 2075 6e64 6566 696e 6564 ts are undefined │ │ │ │ -0000ffa0: 2069 6e20 7468 6573 6520 6361 7365 732e in these cases. │ │ │ │ -0000ffb0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -0000ffd0: 3c61 2069 643d 226c 3030 3338 3822 206e 388//
.
│ │ │ │ -00010080: 2020 3338 393c 2f73 7061 6e3e 3c73 7061 389template <SchemeType │ │ │ │ -000100c0: 2053 4348 454d 4526 6774 3b3c 2f64 6976 SCHEME>
.
390< │ │ │ │ -00010120: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>temp │ │ │ │ -00010140: 6c61 7465 3c2f 7370 616e 3e20 266c 743b late < │ │ │ │ -00010150: 3c73 7061 6e20 636c 6173 733d 226b 6579 typename EDGE, typename MASK>
│ │ │ │ -000101b0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -000101e0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 391v │ │ │ │ -00010220: 6f69 643c 2f73 7061 6e3e 3c2f 6469 763e oid
│ │ │ │ -00010230: 0a3c 6469 7620 636c 6173 733d 2266 6f6c .
.
< │ │ │ │ -000102c0: 6120 636c 6173 733d 226c 696e 6522 2068 a class="line" h │ │ │ │ -000102d0: 7265 663d 2261 3031 3334 312e 6874 6d6c ref="a01341.html │ │ │ │ -000102e0: 2361 3562 3561 3533 3737 6130 3165 6234 #a5b5a5377a01eb4 │ │ │ │ -000102f0: 6261 3434 3665 3137 3465 6666 3965 3435 ba446e174eff9e45 │ │ │ │ -00010300: 6163 223e 2020 3339 323c 2f61 3e3c 2f73 ac"> 392Scheme<S │ │ │ │ -00010370: 4348 454d 4526 6774 3b3a 3a43 6f6d 7075 CHEME>::Compu │ │ │ │ -00010380: 7465 4564 6765 5665 7274 6578 4d61 736b teEdgeVertexMask │ │ │ │ -00010390: 3c2f 613e 2845 4447 4520 3c73 7061 6e20 (EDGE │ │ │ │ -000103b0: 636f 6e73 743c 2f73 7061 6e3e 2661 6d70 const& │ │ │ │ -000103c0: 3b20 2020 2020 6564 6765 2c3c 2f64 6976 ; edge,
.
393< │ │ │ │ -00010420: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ -00010430: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00010440: 2020 2020 2020 2020 2020 2020 2020 204d M │ │ │ │ -00010450: 4153 4b26 616d 703b 2020 2020 2020 2020 ASK& │ │ │ │ -00010460: 2020 206d 6173 6b2c 3c2f 6469 763e 0a3c mask,
.< │ │ │ │ -00010470: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00010480: 3e3c 6120 6964 3d22 6c30 3033 3934 2220 > 394 │ │ │ │ -000104d0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -000104e0: 2020 2020 2020 2020 2020 2020 3c61 2063 │ │ │ │ -00010540: 4372 6561 7365 3a3a 5275 6c65 3c2f 613e Crease::Rule │ │ │ │ -00010550: 2070 6172 656e 7452 756c 652c 3c2f 6469 parentRule,.
395 │ │ │ │ -000105b0: 3c2f 7370 616e 3e20 2020 2020 2020 2020 │ │ │ │ -000105c0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -000105d0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -000105e0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Crease::Rule │ │ │ │ -00010640: 3c2f 613e 2063 6869 6c64 5275 6c65 293c childRule)< │ │ │ │ -00010650: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00010660: 6f72 6422 3e20 636f 6e73 7420 3c2f 7370 ord"> const {
.
396 │ │ │ │ -000106d0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00010720: 2033 3937 3c2f 7370 616e 3e20 2020 203c 397 < │ │ │ │ -00010730: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00010740: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
3 │ │ │ │ -000107a0: 3938 3c2f 7370 616e 3e20 2020 203c 7370 98 // If the pa │ │ │ │ -000107d0: 7265 6e74 2077 6173 2073 7065 6369 6669 rent was specifi │ │ │ │ -000107e0: 6564 206f 7220 6465 7465 726d 696e 6564 ed or determined │ │ │ │ -000107f0: 2074 6f20 6265 2053 6d6f 6f74 682c 2077 to be Smooth, w │ │ │ │ -00010800: 6520 6361 6e20 7175 6963 6b6c 7920 7265 e can quickly re │ │ │ │ -00010810: 7475 726e 3c2f 7370 616e 3e3c 2f64 6976 turn
.
399< │ │ │ │ -00010870: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -00010890: 2f2f 2020 7769 7468 2061 2053 6d6f 6f74 // with a Smoot │ │ │ │ -000108a0: 6820 6d61 736b 2e20 204f 7468 6572 7769 h mask. Otherwi │ │ │ │ -000108b0: 7365 2074 6865 2070 6172 656e 7420 6973 se the parent is │ │ │ │ -000108c0: 2061 2063 7265 6173 6520 2d2d 2069 6620 a crease -- if │ │ │ │ -000108d0: 7468 6520 6368 696c 6420 7761 733c 2f73 the child was
.
400 │ │ │ │ -00010940: 2020 203c 7370 616e 2063 6c61 7373 3d22 // als │ │ │ │ -00010960: 6f20 7370 6563 6966 6965 6420 746f 2062 o specified to b │ │ │ │ -00010970: 6520 6120 6372 6561 7365 2c20 7765 2063 e a crease, we c │ │ │ │ -00010980: 616e 2071 7569 636b 6c79 2072 6574 7572 an quickly retur │ │ │ │ -00010990: 6e20 7769 7468 2061 2043 7265 6173 6520 n with a Crease │ │ │ │ -000109a0: 6d61 736b 2e3c 2f73 7061 6e3e 3c2f 6469 mask..
401 │ │ │ │ -00010a00: 3c2f 7370 616e 3e20 2020 203c 7370 616e //
│ │ │ │ -00010a30: 0a3c 6469 7620 636c 6173 733d 226c 696e ..
403< │ │ │ │ -00010ba0: 2f73 7061 6e3e 2020 2020 2020 2028 2870 /span> ((p │ │ │ │ -00010bb0: 6172 656e 7452 756c 6520 3d3d 203c 6120 arentRule == │ │ │ │ -00010c30: 4372 6561 7365 3a3a 5255 4c45 5f55 4e4b Crease::RULE_UNK │ │ │ │ -00010c40: 4e4f 574e 3c2f 613e 2920 2661 6d70 3b26 NOWN) && │ │ │ │ -00010c50: 616d 703b 2028 6564 6765 2e47 6574 5368 amp; (edge.GetSh │ │ │ │ -00010c60: 6172 706e 6573 7328 2920 266c 743b 3d20 arpness() <= │ │ │ │ -00010c70: 302e 3066 2929 2920 7b3c 2f64 6976 3e0a 0.0f))) {
. │ │ │ │ -00010c80: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
│ │ │ │ -00010d50: 2034 3035 3c2f 7370 616e 3e20 2020 2020 405 │ │ │ │ -00010d60: 2020 203c 7370 616e 2063 6c61 7373 3d22 ret │ │ │ │ -00010d80: 7572 6e3c 2f73 7061 6e3e 3b3c 2f64 6976 urn;
.
406< │ │ │ │ -00010de0: 2f73 7061 6e3e 2020 2020 7d3c 2f64 6976 /span> }
.
407< │ │ │ │ -00010e40: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> if (c │ │ │ │ -00010e70: 6869 6c64 5275 6c65 203d 3d20 3c61 2063 hildRule == C │ │ │ │ -00010ef0: 7265 6173 653a 3a52 554c 455f 4352 4541 rease::RULE_CREA │ │ │ │ -00010f00: 5345 3c2f 613e 2920 7b3c 2f64 6976 3e0a SE) {
. │ │ │ │ -00010f10: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
│ │ │ │ -00010fe0: 2034 3039 3c2f 7370 616e 3e20 2020 2020 409 │ │ │ │ -00010ff0: 2020 203c 7370 616e 2063 6c61 7373 3d22 ret │ │ │ │ -00011010: 7572 6e3c 2f73 7061 6e3e 3b3c 2f64 6976 urn;
.
410< │ │ │ │ -00011070: 2f73 7061 6e3e 2020 2020 7d3c 2f64 6976 /span> }
.
411< │ │ │ │ -000110d0: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ -000110f0: 3c61 2069 643d 226c 3030 3431 3222 206e 412 //
.
< │ │ │ │ -00011190: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -000111a0: 6e6f 223e 2020 3431 333c 2f73 7061 6e3e no"> 413 │ │ │ │ -000111b0: 2020 2020 3c73 7061 6e20 636c 6173 733d // We │ │ │ │ -000111d0: 2068 6176 6520 6120 4372 6561 7365 206f have a Crease o │ │ │ │ -000111e0: 6e20 7468 6520 7061 7265 6e74 2061 6e64 n the parent and │ │ │ │ -000111f0: 2074 6865 2063 6869 6c64 2077 6173 2065 the child was e │ │ │ │ -00011200: 6974 6865 7220 7370 6563 6966 6965 6420 ither specified │ │ │ │ -00011210: 6173 2053 6d6f 6f74 683c 2f73 7061 6e3e as Smooth │ │ │ │ -00011220: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00011270: 2034 3134 3c2f 7370 616e 3e20 2020 203c 414 < │ │ │ │ -00011280: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00011290: 656e 7422 3e2f 2f20 206f 7220 7761 7320 ent">// or was │ │ │ │ -000112a0: 6e6f 7420 7370 6563 6966 6965 6420 6174 not specified at │ │ │ │ -000112b0: 2061 6c6c 202d 2d20 6465 616c 2077 6974 all -- deal wit │ │ │ │ -000112c0: 6820 7468 6520 756e 7370 6563 6966 6965 h the unspecifie │ │ │ │ -000112d0: 6420 6361 7365 2066 6972 7374 2028 6167 d case first (ag │ │ │ │ -000112e0: 6169 6e3c 2f73 7061 6e3e 3c2f 6469 763e ain
│ │ │ │ -000112f0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00011320: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 415 / │ │ │ │ -00011360: 2f20 2072 6574 7572 6e69 6e67 2061 2043 / returning a C │ │ │ │ -00011370: 7265 6173 6520 6d61 736b 2069 6620 7468 rease mask if th │ │ │ │ -00011380: 6520 6368 696c 6420 6973 2061 6c73 6f20 e child is also │ │ │ │ -00011390: 6465 7465 726d 696e 6564 2074 6f20 6265 determined to be │ │ │ │ -000113a0: 2061 2043 7265 6173 6529 2061 6e64 3c2f a Crease) and
.
< │ │ │ │ -000113f0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00011400: 6e6f 223e 2020 3431 363c 2f73 7061 6e3e no"> 416 │ │ │ │ -00011410: 2020 2020 3c73 7061 6e20 636c 6173 733d // co │ │ │ │ -00011430: 6e74 696e 7565 2069 6620 7765 2068 6176 ntinue if we hav │ │ │ │ -00011440: 6520 6120 7472 616e 7369 7469 6f6e 2074 e a transition t │ │ │ │ -00011450: 6f20 536d 6f6f 7468 2e3c 2f73 7061 6e3e o Smooth. │ │ │ │ -00011460: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000114b0: 2034 3137 3c2f 7370 616e 3e20 2020 203c 417 < │ │ │ │ -000114c0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -000114d0: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
4 │ │ │ │ -00011530: 3138 3c2f 7370 616e 3e20 2020 203c 7370 18 // Note when │ │ │ │ -00011560: 2071 7561 6c69 6679 696e 6720 7468 6520 qualifying the │ │ │ │ -00011570: 6368 696c 6420 7468 6174 2069 6620 7468 child that if th │ │ │ │ -00011580: 6520 7061 7265 6e74 2073 6861 7270 6e65 e parent sharpne │ │ │ │ -00011590: 7373 2026 6774 3b20 312e 302c 2072 6567 ss > 1.0, reg │ │ │ │ -000115a0: 6172 646c 6573 733c 2f73 7061 6e3e 3c2f ardless.
4 │ │ │ │ -00011600: 3139 3c2f 7370 616e 3e20 2020 203c 7370 19 // of the cr │ │ │ │ -00011630: 6561 7369 6e67 206d 6574 686f 642c 2077 easing method, w │ │ │ │ -00011640: 6865 7468 6572 2074 6865 2063 6869 6c64 hether the child │ │ │ │ -00011650: 2073 6861 7270 6e65 7373 2076 616c 7565 sharpness value │ │ │ │ -00011660: 7320 6465 6361 7920 746f 207a 6572 6f20 s decay to zero │ │ │ │ -00011670: 6973 3c2f 7370 616e 3e3c 2f64 6976 3e0a is
. │ │ │ │ -00011680: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
< │ │ │ │ -00011780: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00011790: 6e6f 223e 2020 3432 313c 2f73 7061 6e3e no"> 421 │ │ │ │ -000117a0: 2020 2020 3c73 7061 6e20 636c 6173 733d // sh │ │ │ │ -000117c0: 6172 706e 6573 7329 2069 7320 2667 743b arpness) is > │ │ │ │ -000117d0: 2031 2e30 2c20 616e 6420 7768 656e 2063 1.0, and when c │ │ │ │ -000117e0: 6c61 6d70 6564 2074 6f20 3120 6566 6665 lamped to 1 effe │ │ │ │ -000117f0: 6374 6976 656c 7920 7969 656c 6473 2061 ctively yields a │ │ │ │ -00011800: 2066 756c 6c20 6372 6561 7365 2e3c 2f73 full crease.
.
422 │ │ │ │ -00011870: 2020 203c 7370 616e 2063 6c61 7373 3d22 //
.
423 │ │ │ │ -000118f0: 203c 7370 616e 2063 6c61 7373 3d22 6b65 if (childRule │ │ │ │ -00011920: 3d3d 203c 6120 636c 6173 733d 2263 6f64 == Crease::RU │ │ │ │ -000119a0: 4c45 5f55 4e4b 4e4f 574e 3c2f 613e 2920 LE_UNKNOWN) │ │ │ │ -000119b0: 7b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 {
.
│ │ │ │ -00011a00: 2020 3432 343c 2f73 7061 6e3e 2020 2020 424 │ │ │ │ -00011a10: 2020 2020 3c61 2063 6c61 7373 3d22 636f │ │ │ │ -00011a40: 4372 6561 7365 3c2f 613e 2063 7265 6173 Crease creas │ │ │ │ -00011a50: 6528 5f6f 7074 696f 6e73 293b 3c2f 6469 e(_options);.
425 │ │ │ │ -00011ab0: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ -00011ac0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00011ad0: 3e3c 6120 6964 3d22 6c30 3034 3236 2220 > 426 bool │ │ │ │ -00011b40: 2063 6869 6c64 4973 4372 6561 7365 203d childIsCrease = │ │ │ │ -00011b50: 203c 7370 616e 2063 6c61 7373 3d22 6b65 false;
.
427 │ │ │ │ -00011bd0: 2020 2020 2020 203c 7370 616e 2063 6c61 if (pare │ │ │ │ -00011c00: 6e74 5275 6c65 203d 3d20 3c61 2063 6c61 ntRule == Cre │ │ │ │ -00011c80: 6173 653a 3a52 554c 455f 4352 4541 5345 ase::RULE_CREASE │ │ │ │ -00011c90: 3c2f 613e 2920 7b3c 2f64 6976 3e0a 3c64 ) {
. │ │ │ │ -00011cb0: 3c61 2069 643d 226c 3030 3432 3822 206e 428 // Child un │ │ │ │ -00011d20: 6b6e 6f77 6e20 6173 2064 6566 6175 6c74 known as default │ │ │ │ -00011d30: 2076 616c 7565 2062 7574 2070 6172 656e value but paren │ │ │ │ -00011d40: 7420 5275 6c65 2073 7065 6369 6669 6564 t Rule specified │ │ │ │ -00011d50: 2061 7320 4372 6561 7365 3c2f 7370 616e as Crease
.
│ │ │ │ -00011db0: 2020 3432 393c 2f73 7061 6e3e 2020 2020 429 │ │ │ │ -00011dc0: 2020 2020 2020 2020 6368 696c 6449 7343 childIsC │ │ │ │ -00011dd0: 7265 6173 6520 3d20 3c73 7061 6e20 636c rease = tr │ │ │ │ -00011df0: 7565 3c2f 7370 616e 3e3b 3c2f 6469 763e ue;
│ │ │ │ -00011e00: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00011e30: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 430 } < │ │ │ │ -00011e60: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00011e70: 6f72 6466 6c6f 7722 3e65 6c73 653c 2f73 ordflow">else i │ │ │ │ -00011ea0: 663c 2f73 7061 6e3e 2028 6564 6765 2e47 f (edge.G │ │ │ │ -00011eb0: 6574 5368 6172 706e 6573 7328 2920 2667 etSharpness() &g │ │ │ │ -00011ec0: 743b 3d20 312e 3066 2920 7b3c 2f64 6976 t;= 1.0f) {
.
431< │ │ │ │ -00011f20: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ -00011f30: 2020 3c73 7061 6e20 636c 6173 733d 2263 // Shar │ │ │ │ -00011f50: 706e 6573 7320 2667 743b 3d20 312e 3020 pness >= 1.0 │ │ │ │ -00011f60: 616c 7761 7973 2061 2063 7265 6173 6520 always a crease │ │ │ │ -00011f70: 2d2d 2073 6565 206e 6f74 6520 6162 6f76 -- see note abov │ │ │ │ -00011f80: 653c 2f73 7061 6e3e 3c2f 6469 763e 0a3c e
.< │ │ │ │ -00011f90: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00011fa0: 3e3c 6120 6964 3d22 6c30 3034 3332 2220 > 432 c │ │ │ │ -00011ff0: 6869 6c64 4973 4372 6561 7365 203d 203c hildIsCrease = < │ │ │ │ -00012000: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00012010: 6f72 6422 3e74 7275 653c 2f73 7061 6e3e ord">true │ │ │ │ -00012020: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00012070: 2020 3433 333c 2f73 7061 6e3e 2020 2020 433 │ │ │ │ -00012080: 2020 2020 7d20 3c73 7061 6e20 636c 6173 } │ │ │ │ -000120a0: 656c 7365 3c2f 7370 616e 3e20 3c73 7061 else if │ │ │ │ -000120d0: 2863 7265 6173 652e 3c61 2063 6c61 7373 (crease.IsUnifo │ │ │ │ -00012130: 726d 3c2f 613e 2829 2920 7b3c 2f64 6976 rm()) {
.
434< │ │ │ │ -00012190: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ -000121a0: 2020 3c73 7061 6e20 636c 6173 733d 2263 // Shar │ │ │ │ -000121c0: 706e 6573 7320 266c 743b 2031 2e30 2069 pness < 1.0 i │ │ │ │ -000121d0: 7320 6775 6172 616e 7465 6564 2074 6f20 s guaranteed to │ │ │ │ -000121e0: 6465 6361 7920 746f 2030 2e30 2066 6f72 decay to 0.0 for │ │ │ │ -000121f0: 2055 6e69 666f 726d 2063 6869 6c64 2065 Uniform child e │ │ │ │ -00012200: 6467 6573 3c2f 7370 616e 3e3c 2f64 6976 dges
.
435< │ │ │ │ -00012260: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ -00012270: 2020 6368 696c 6449 7343 7265 6173 6520 childIsCrease │ │ │ │ -00012280: 3d20 3c73 7061 6e20 636c 6173 733d 226b = false;
.
< │ │ │ │ -000122e0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -000122f0: 6e6f 223e 2020 3433 363c 2f73 7061 6e3e no"> 436 │ │ │ │ -00012300: 2020 2020 2020 2020 7d20 3c73 7061 6e20 } else │ │ │ │ -00012330: 7b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 {
.
│ │ │ │ -00012380: 2020 3433 373c 2f73 7061 6e3e 2020 2020 437 │ │ │ │ -00012390: 2020 2020 2020 2020 3c73 7061 6e20 636c // │ │ │ │ -000123b0: 2020 5368 6172 706e 6573 7320 266c 743b Sharpness < │ │ │ │ -000123c0: 3d20 312e 3020 646f 6573 206e 6f74 206e = 1.0 does not n │ │ │ │ -000123d0: 6563 6573 7361 7269 6c79 2064 6563 6179 ecessarily decay │ │ │ │ -000123e0: 2074 6f20 302e 3020 666f 7220 626f 7468 to 0.0 for both │ │ │ │ -000123f0: 2063 6869 6c64 2065 6467 6573 2e2e 2e3c child edges...< │ │ │ │ -00012400: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -00012420: 6120 6964 3d22 6c30 3034 3338 2220 6e61 a id="l00438" na │ │ │ │ -00012430: 6d65 3d22 6c30 3034 3338 223e 3c2f 613e me="l00438"> │ │ │ │ -00012440: 3c73 7061 6e20 636c 6173 733d 226c 696e 438 float cEdgeSharpne │ │ │ │ -000124a0: 7373 5b32 5d3b 3c2f 6469 763e 0a3c 6469 ss[2];
.< │ │ │ │ -000124c0: 6120 6964 3d22 6c30 3034 3339 2220 6e61 a id="l00439" na │ │ │ │ -000124d0: 6d65 3d22 6c30 3034 3339 223e 3c2f 613e me="l00439"> │ │ │ │ -000124e0: 3c73 7061 6e20 636c 6173 733d 226c 696e 439 edg │ │ │ │ -00012510: 652e 4765 7443 6869 6c64 5368 6172 706e e.GetChildSharpn │ │ │ │ -00012520: 6573 7365 7328 6372 6561 7365 2c20 6345 esses(crease, cE │ │ │ │ -00012530: 6467 6553 6861 7270 6e65 7373 293b 3c2f dgeSharpness);.
4 │ │ │ │ -00012590: 3430 3c2f 7370 616e 3e20 2020 2020 2020 40 │ │ │ │ -000125a0: 2020 2020 2063 6869 6c64 4973 4372 6561 childIsCrea │ │ │ │ -000125b0: 7365 203d 2028 6345 6467 6553 6861 7270 se = (cEdgeSharp │ │ │ │ -000125c0: 6e65 7373 5b30 5d20 2667 743b 2030 2e30 ness[0] > 0.0 │ │ │ │ -000125d0: 6629 2026 616d 703b 2661 6d70 3b20 2863 f) && (c │ │ │ │ -000125e0: 4564 6765 5368 6172 706e 6573 735b 315d EdgeSharpness[1] │ │ │ │ -000125f0: 2026 6774 3b20 302e 3066 293b 3c2f 6469 > 0.0f);.
441 │ │ │ │ -00012650: 3c2f 7370 616e 3e20 2020 2020 2020 207d } │ │ │ │ -00012660: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000126b0: 2034 3432 3c2f 7370 616e 3e20 2020 2020 442 │ │ │ │ -000126c0: 2020 203c 7370 616e 2063 6c61 7373 3d22 if< │ │ │ │ -000126e0: 2f73 7061 6e3e 2028 6368 696c 6449 7343 /span> (childIsC │ │ │ │ -000126f0: 7265 6173 6529 207b 3c2f 6469 763e 0a3c rease) {
.< │ │ │ │ -00012700: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00012710: 3e3c 6120 6964 3d22 6c30 3034 3433 2220 > 443 a │ │ │ │ -00012760: 7373 6967 6e43 7265 6173 654d 6173 6b46 ssignCreaseMaskF │ │ │ │ -00012770: 6f72 4564 6765 2865 6467 652c 206d 6173 orEdge(edge, mas │ │ │ │ -00012780: 6b29 3b3c 2f64 6976 3e0a 3c64 6976 2063 k);
.
444 │ │ │ │ -000127e0: 2020 2020 2020 2020 2020 3c73 7061 6e20 return;
.
445 │ │ │ │ -00012870: 2020 2020 207d 3c2f 6469 763e 0a3c 6469 }
.< │ │ │ │ -00012890: 6120 6964 3d22 6c30 3034 3436 2220 6e61 a id="l00446" na │ │ │ │ -000128a0: 6d65 3d22 6c30 3034 3436 223e 3c2f 613e me="l00446"> │ │ │ │ -000128b0: 3c73 7061 6e20 636c 6173 733d 226c 696e 446 }
.< │ │ │ │ -000128f0: 6120 6964 3d22 6c30 3034 3437 2220 6e61 a id="l00447" na │ │ │ │ -00012900: 6d65 3d22 6c30 3034 3437 223e 3c2f 613e me="l00447"> │ │ │ │ -00012910: 3c73 7061 6e20 636c 6173 733d 226c 696e 447
.
448 │ │ │ │ -00012990: 203c 7370 616e 2063 6c61 7373 3d22 636f // │ │ │ │ -000129b0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00012a00: 2034 3439 3c2f 7370 616e 3e20 2020 203c 449 < │ │ │ │ -00012a10: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00012a20: 656e 7422 3e2f 2f20 2057 6520 6172 6520 ent">// We are │ │ │ │ -00012a30: 6e6f 7720 6c65 6674 2077 6974 6820 7468 now left with th │ │ │ │ -00012a40: 6520 4372 6561 7365 2d74 6f2d 536d 6f6f e Crease-to-Smoo │ │ │ │ -00012a50: 7468 2063 6173 6520 2d2d 2063 6f6d 7075 th case -- compu │ │ │ │ -00012a60: 7465 2074 6865 2053 6d6f 6f74 6820 6d61 te the Smooth ma │ │ │ │ -00012a70: 736b 3c2f 7370 616e 3e3c 2f64 6976 3e0a sk
. │ │ │ │ -00012a80: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
│ │ │ │ -00012b90: 2020 3435 313c 2f73 7061 6e3e 2020 2020 451 │ │ │ │ -00012ba0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ -00012bc0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00012c10: 3435 323c 2f73 7061 6e3e 2020 2020 3c73 452 // A genera │ │ │ │ -00012c40: 6c20 636f 6d62 696e 6174 696f 6e20 6f66 l combination of │ │ │ │ -00012c50: 2073 6570 6172 6174 656c 7920 6173 7369 separately assi │ │ │ │ -00012c60: 676e 6564 206d 6173 6b73 2068 6572 6520 gned masks here │ │ │ │ -00012c70: 2861 7320 646f 6e65 2069 6e20 7468 6520 (as done in the │ │ │ │ -00012c80: 7665 7274 6578 2d3c 2f73 7061 6e3e 3c2f vertex-.
4 │ │ │ │ -00012ce0: 3533 3c2f 7370 616e 3e20 2020 203c 7370 53 // vertex ca │ │ │ │ -00012d10: 7365 2920 6973 206f 7665 726b 696c 6c20 se) is overkill │ │ │ │ -00012d20: 2d2d 2074 7269 7669 616c 6c79 2063 6f6d -- trivially com │ │ │ │ -00012d30: 6269 6e65 2074 6865 2030 2e35 6620 7665 bine the 0.5f ve │ │ │ │ -00012d40: 7274 6578 2063 6f65 6666 6963 6965 6e74 rtex coefficient │ │ │ │ -00012d50: 2066 6f72 3c2f 7370 616e 3e3c 2f64 6976 for
.
454< │ │ │ │ -00012db0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -00012dd0: 2f2f 2020 7468 6520 4372 6561 7365 206f // the Crease o │ │ │ │ -00012de0: 6620 7468 6520 7061 7265 6e74 2077 6974 f the parent wit │ │ │ │ -00012df0: 6820 7468 6520 7665 7274 6578 2077 6569 h the vertex wei │ │ │ │ -00012e00: 6768 7473 2061 6e64 2061 7474 656e 7561 ghts and attenua │ │ │ │ -00012e10: 7465 2074 6865 2066 6163 6520 7765 6967 te the face weig │ │ │ │ -00012e20: 6874 733c 2f73 7061 6e3e 3c2f 6469 763e hts
│ │ │ │ -00012e30: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00012e60: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 455 / │ │ │ │ -00012ea0: 2f20 2061 6363 6f72 6469 6e67 6c79 2e3c / accordingly.< │ │ │ │ -00012eb0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ -00012ed0: 6120 6964 3d22 6c30 3034 3536 2220 6e61 a id="l00456" na │ │ │ │ -00012ee0: 6d65 3d22 6c30 3034 3536 223e 3c2f 613e me="l00456"> │ │ │ │ -00012ef0: 3c73 7061 6e20 636c 6173 733d 226c 696e 456 //
.
457 │ │ │ │ -00012f90: 2020 2061 7373 6967 6e53 6d6f 6f74 684d assignSmoothM │ │ │ │ -00012fa0: 6173 6b46 6f72 4564 6765 2865 6467 652c askForEdge(edge, │ │ │ │ -00012fb0: 206d 6173 6b29 3b3c 2f64 6976 3e0a 3c64 mask);
. │ │ │ │ -00012fd0: 3c61 2069 643d 226c 3030 3435 3822 206e 458
.
459 │ │ │ │ -00013070: 2020 3c73 7061 6e20 636c 6173 733d 226b typedef< │ │ │ │ -00013090: 2f73 7061 6e3e 203c 7370 616e 2063 6c61 /span> typ │ │ │ │ -000130b0: 656e 616d 653c 2f73 7061 6e3e 204d 4153 ename MAS │ │ │ │ -000130c0: 4b3a 3a57 6569 6768 7420 5765 6967 6874 K::Weight Weight │ │ │ │ -000130d0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00013120: 2020 3436 303c 2f73 7061 6e3e 203c 2f64 460 .
46 │ │ │ │ -00013180: 313c 2f73 7061 6e3e 2020 2020 5765 6967 1 Weig │ │ │ │ -00013190: 6874 2070 5765 6967 6874 203d 2065 6467 ht pWeight = edg │ │ │ │ -000131a0: 652e 4765 7453 6861 7270 6e65 7373 2829 e.GetSharpness() │ │ │ │ -000131b0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00013200: 2020 3436 323c 2f73 7061 6e3e 2020 2020 462 │ │ │ │ -00013210: 5765 6967 6874 2063 5765 6967 6874 203d Weight cWeight = │ │ │ │ -00013220: 2031 2e30 6620 2d20 7057 6569 6768 743b 1.0f - pWeight; │ │ │ │ -00013230: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00013280: 2034 3633 3c2f 7370 616e 3e20 3c2f 6469 463 .
464 │ │ │ │ -000132e0: 3c2f 7370 616e 3e20 2020 206d 6173 6b2e mask. │ │ │ │ -000132f0: 5665 7274 6578 5765 6967 6874 2830 2920 VertexWeight(0) │ │ │ │ -00013300: 3d20 7057 6569 6768 7420 2a20 302e 3566 = pWeight * 0.5f │ │ │ │ -00013310: 202b 2063 5765 6967 6874 202a 206d 6173 + cWeight * mas │ │ │ │ -00013320: 6b2e 5665 7274 6578 5765 6967 6874 2830 k.VertexWeight(0 │ │ │ │ -00013330: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
465 │ │ │ │ -00013390: 206d 6173 6b2e 5665 7274 6578 5765 6967 mask.VertexWeig │ │ │ │ -000133a0: 6874 2831 2920 3d20 7057 6569 6768 7420 ht(1) = pWeight │ │ │ │ -000133b0: 2a20 302e 3566 202b 2063 5765 6967 6874 * 0.5f + cWeight │ │ │ │ -000133c0: 202a 206d 6173 6b2e 5665 7274 6578 5765 * mask.VertexWe │ │ │ │ -000133d0: 6967 6874 2831 293b 3c2f 6469 763e 0a3c ight(1);
.< │ │ │ │ -000133e0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -000133f0: 3e3c 6120 6964 3d22 6c30 3034 3636 2220 > 466
.
467 │ │ │ │ -00013490: 2020 203c 7370 616e 2063 6c61 7373 3d22 int │ │ │ │ -000134b0: 3c2f 7370 616e 3e20 6661 6365 436f 756e faceCoun │ │ │ │ -000134c0: 7420 3d20 6d61 736b 2e47 6574 4e75 6d46 t = mask.GetNumF │ │ │ │ -000134d0: 6163 6557 6569 6768 7473 2829 3b3c 2f64 aceWeights();.
46 │ │ │ │ -00013530: 383c 2f73 7061 6e3e 2020 2020 3c73 7061 8 for │ │ │ │ -00013560: 2028 3c73 7061 6e20 636c 6173 733d 226b (int< │ │ │ │ -00013580: 2f73 7061 6e3e 2069 203d 2030 3b20 6920 /span> i = 0; i │ │ │ │ -00013590: 266c 743b 2066 6163 6543 6f75 6e74 3b20 < faceCount; │ │ │ │ -000135a0: 2b2b 6929 207b 3c2f 6469 763e 0a3c 6469 ++i) {
.< │ │ │ │ -000135c0: 6120 6964 3d22 6c30 3034 3639 2220 6e61 a id="l00469" na │ │ │ │ -000135d0: 6d65 3d22 6c30 3034 3639 223e 3c2f 613e me="l00469"> │ │ │ │ -000135e0: 3c73 7061 6e20 636c 6173 733d 226c 696e 469 mask.Fa │ │ │ │ -00013610: 6365 5765 6967 6874 2869 2920 2a3d 2063 ceWeight(i) *= c │ │ │ │ -00013620: 5765 6967 6874 3b3c 2f64 6976 3e0a 3c64 Weight;
. │ │ │ │ -00013640: 3c61 2069 643d 226c 3030 3437 3022 206e 470 }
. │ │ │ │ -000136a0: 3c61 2069 643d 226c 3030 3437 3122 206e 471}
.
│ │ │ │ -000136f0: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -00013760: 6120 6964 3d22 6c30 3034 3733 2220 6e61 a id="l00473" na │ │ │ │ -00013770: 6d65 3d22 6c30 3034 3733 223e 3c2f 613e me="l00473"> │ │ │ │ -00013780: 3c73 7061 6e20 636c 6173 733d 226c 696e 473// │ │ │ │ -000137c0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00013810: 2034 3734 3c2f 7370 616e 3e3c 7370 616e 474// The computa │ │ │ │ -00013840: 7469 6f6e 206f 6620 6120 7665 7274 6578 tion of a vertex │ │ │ │ -00013850: 2d76 6572 7465 7820 6d61 736b 2072 6571 -vertex mask req │ │ │ │ -00013860: 7569 7265 7320 696e 7370 6563 7469 6f6e uires inspection │ │ │ │ -00013870: 206f 6620 6372 6561 7369 6e67 2073 6861 of creasing sha │ │ │ │ -00013880: 7270 6e65 7373 2076 616c 7565 733c 2f73 rpness values
.
475< │ │ │ │ -000138f0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00013900: 656e 7422 3e2f 2f20 2074 6f20 6465 7465 ent">// to dete │ │ │ │ -00013910: 726d 696e 6520 7768 6174 2073 7562 6469 rmine what subdi │ │ │ │ -00013920: 7669 7369 6f6e 2052 756c 6573 2061 7070 vision Rules app │ │ │ │ -00013930: 6c79 2074 6f20 7468 6520 7061 7265 6e74 ly to the parent │ │ │ │ -00013940: 2061 6e64 2069 7473 2063 6869 6c64 2076 and its child v │ │ │ │ -00013950: 6572 7465 782c 2061 6e64 2061 6c73 6f20 ertex, and also │ │ │ │ -00013960: 746f 3c2f 7370 616e 3e3c 2f64 6976 3e0a to
. │ │ │ │ -00013970: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -000139a0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 476// de │ │ │ │ -000139e0: 7465 6374 2061 6e64 2061 7070 6c79 2061 tect and apply a │ │ │ │ -000139f0: 2074 7261 6e73 6974 696f 6e20 6265 7477 transition betw │ │ │ │ -00013a00: 6565 6e20 7477 6f20 6469 6666 6572 696e een two differin │ │ │ │ -00013a10: 6720 5275 6c65 732e 2020 5573 696e 6720 g Rules. Using │ │ │ │ -00013a20: 7468 6520 7072 6f74 6563 7465 6420 6d65 the protected me │ │ │ │ -00013a30: 7468 6f64 7320 746f 3c2f 7370 616e 3e3c thods to< │ │ │ │ -00013a40: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00013a90: 3437 373c 2f73 7061 6e3e 3c73 7061 6e20 477 │ │ │ │ -00013ab0: 2f2f 2020 6173 7369 676e 2073 7065 6369 // assign speci │ │ │ │ -00013ac0: 6669 6320 6d61 736b 732c 2074 6869 7320 fic masks, this │ │ │ │ -00013ad0: 696d 706c 656d 656e 7461 7469 6f6e 2073 implementation s │ │ │ │ -00013ae0: 686f 756c 6420 7365 7276 6520 616c 6c20 hould serve all │ │ │ │ -00013af0: 6e6f 6e2d 6c69 6e65 6172 2073 6368 656d non-linear schem │ │ │ │ -00013b00: 6573 2028 6375 7272 656e 746c 793c 2f73 es (currently
.
478< │ │ │ │ -00013b70: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00013b80: 656e 7422 3e2f 2f20 2043 6174 6d61 726b ent">// Catmark │ │ │ │ -00013b90: 2061 6e64 204c 6f6f 7029 2061 6e64 206f and Loop) and o │ │ │ │ -00013ba0: 6e6c 7920 6e65 6564 7320 746f 2062 6520 nly needs to be │ │ │ │ -00013bb0: 7370 6563 6961 6c69 7a65 6420 666f 7220 specialized for │ │ │ │ -00013bc0: 4269 6c69 6e65 6172 2074 6f20 7265 6d6f Bilinear to remo │ │ │ │ -00013bd0: 7665 2061 6c6c 2075 6e6e 6563 6573 7361 ve all unnecessa │ │ │ │ -00013be0: 7279 3c2f 7370 616e 3e3c 2f64 6976 3e0a ry
. │ │ │ │ -00013bf0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
│ │ │ │ -00013ce0: 2020 3438 303c 2f73 7061 6e3e 3c73 7061 480//
.
481< │ │ │ │ -00013d60: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -00013d80: 5468 6520 696d 706c 656d 656e 7461 7469 The implementati │ │ │ │ -00013d90: 6f6e 2068 6572 6520 6973 2073 6c69 6768 on here is sligh │ │ │ │ -00013da0: 746c 7920 636f 6d70 6c69 6361 7465 6420 tly complicated │ │ │ │ -00013db0: 6279 2063 6f6d 6269 6e69 6e67 2074 776f by combining two │ │ │ │ -00013dc0: 2073 6365 6e61 7269 6f73 2069 6e74 6f20 scenarios into │ │ │ │ -00013dd0: 6f6e 6520 2d2d 3c2f 7370 616e 3e3c 2f64 one --.
48 │ │ │ │ -00013e30: 323c 2f73 7061 6e3e 3c73 7061 6e20 636c 2// │ │ │ │ -00013e50: 2020 6569 7468 6572 2074 6865 2063 616c either the cal │ │ │ │ -00013e60: 6c65 7220 6b6e 6f77 7320 7468 6520 7061 ler knows the pa │ │ │ │ -00013e70: 7265 6e74 2061 6e64 2063 6869 6c64 2072 rent and child r │ │ │ │ -00013e80: 756c 6573 2061 6e64 2070 726f 7669 6465 ules and provide │ │ │ │ -00013e90: 7320 7468 656d 2c20 6f72 2074 6865 7920 s them, or they │ │ │ │ -00013ea0: 646f 6e26 2333 393b 7420 616e 643c 2f73 don't and
.
483< │ │ │ │ -00013f10: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00013f20: 656e 7422 3e2f 2f20 2074 6865 2052 756c ent">// the Rul │ │ │ │ -00013f30: 6573 2068 6176 6520 746f 2062 6520 6465 es have to be de │ │ │ │ -00013f40: 7465 726d 696e 6564 2066 726f 6d20 7368 termined from sh │ │ │ │ -00013f50: 6172 706e 6573 7320 7661 6c75 6573 2e20 arpness values. │ │ │ │ -00013f60: 2045 7665 6e20 7768 656e 2074 6865 2052 Even when the R │ │ │ │ -00013f70: 756c 6573 2061 7265 206b 6e6f 776e 2061 ules are known a │ │ │ │ -00013f80: 6e64 3c2f 7370 616e 3e3c 2f64 6976 3e0a nd
. │ │ │ │ -00013f90: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -00013fc0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 484// pr │ │ │ │ -00014000: 6f76 6964 6564 2074 686f 7567 682c 2074 ovided though, t │ │ │ │ -00014010: 6865 7265 2061 7265 2063 6173 6573 2077 here are cases w │ │ │ │ -00014020: 6865 7265 2074 6865 2070 6172 656e 7420 here the parent │ │ │ │ -00014030: 616e 6420 6368 696c 6420 7368 6172 706e and child sharpn │ │ │ │ -00014040: 6573 7320 7661 6c75 6573 206e 6565 6420 ess values need │ │ │ │ -00014050: 746f 2062 653c 2f73 7061 6e3e 3c2f 6469 to be.
485 │ │ │ │ -000140b0: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ -000140d0: 2069 6465 6e74 6966 6965 642c 2073 6f20 identified, so │ │ │ │ -000140e0: 6163 636f 756e 7469 6e67 2066 6f72 2074 accounting for t │ │ │ │ -000140f0: 6865 2075 6e6b 6e6f 776e 2052 756c 6573 he unknown Rules │ │ │ │ -00014100: 2074 6f6f 2069 7320 6e6f 7420 6d75 6368 too is not much │ │ │ │ -00014110: 206f 6620 616e 2061 6464 6564 2063 6f6d of an added com │ │ │ │ -00014120: 706c 6963 6174 696f 6e2e 3c2f 7370 616e plication.
.
│ │ │ │ -00014180: 2020 3438 363c 2f73 7061 6e3e 3c73 7061 486//
.
487< │ │ │ │ -00014200: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>// │ │ │ │ -00014220: 5468 6520 6265 6e65 6669 7420 6f66 2073 The benefit of s │ │ │ │ -00014230: 7570 706f 7274 696e 6720 7370 6563 6966 upporting specif │ │ │ │ -00014240: 6965 6420 5275 6c65 7320 6973 2074 6861 ied Rules is tha │ │ │ │ -00014250: 7420 7468 6579 2063 616e 206f 6674 656e t they can often │ │ │ │ -00014260: 2062 6520 7472 6976 6961 6c6c 793c 2f73 be trivially
.
488< │ │ │ │ -000142d0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -000142e0: 656e 7422 3e2f 2f20 2064 6574 6572 6d69 ent">// determi │ │ │ │ -000142f0: 6e65 6420 6672 6f6d 2063 6f6e 7465 7874 ned from context │ │ │ │ -00014300: 2028 652e 672e 2061 2076 6572 7465 7820 (e.g. a vertex │ │ │ │ -00014310: 6465 7269 7665 6420 6672 6f6d 2061 2066 derived from a f │ │ │ │ -00014320: 6163 6520 6174 2061 2070 7265 7669 6f75 ace at a previou │ │ │ │ -00014330: 7320 6c65 7665 6c20 7769 6c6c 2061 6c77 s level will alw │ │ │ │ -00014340: 6179 733c 2f73 7061 6e3e 3c2f 6469 763e ays
│ │ │ │ -00014350: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00014380: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 489// b │ │ │ │ -000143c0: 6520 736d 6f6f 7468 2920 7261 7468 6572 e smooth) rather │ │ │ │ -000143d0: 2074 6861 6e20 6d6f 7265 2067 656e 6572 than more gener │ │ │ │ -000143e0: 616c 6c79 2c20 616e 6420 6174 2067 7265 ally, and at gre │ │ │ │ -000143f0: 6174 6572 2063 6f73 742c 2069 6e73 7065 ater cost, inspe │ │ │ │ -00014400: 6374 696e 6720 6e65 6967 6862 6f72 696e cting neighborin │ │ │ │ -00014410: 6720 616e 643c 2f73 7061 6e3e 3c2f 6469 g and.
490 │ │ │ │ -00014470: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 // │ │ │ │ -00014490: 2074 6865 7920 6172 6520 6f66 7465 6e20 they are often │ │ │ │ -000144a0: 7468 6520 7361 6d65 2066 6f72 2070 6172 the same for par │ │ │ │ -000144b0: 656e 7420 616e 6420 6368 696c 642e 3c2f ent and child.
.
< │ │ │ │ -00014500: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00014510: 6e6f 223e 2020 3439 313c 2f73 7061 6e3e no"> 491 │ │ │ │ -00014520: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ -00014540: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00014590: 3439 323c 2f73 7061 6e3e 3c73 7061 6e20 492 │ │ │ │ -000145b0: 2f2f 2020 5468 6520 6f76 6572 616c 6c20 // The overall │ │ │ │ -000145c0: 7072 6f63 6573 7320 6973 2061 7320 666f process is as fo │ │ │ │ -000145d0: 6c6c 6f77 733a 3c2f 7370 616e 3e3c 2f64 llows:.
49 │ │ │ │ -00014630: 333c 2f73 7061 6e3e 3c73 7061 6e20 636c 3// │ │ │ │ -00014650: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00014670: 3c61 2069 643d 226c 3030 3439 3422 206e 494// │ │ │ │ -000146d0: 2d20 7175 6963 6b6c 7920 6465 7465 6374 - quickly detect │ │ │ │ -000146e0: 2074 6865 206d 6f73 7420 636f 6d6d 6f6e the most common │ │ │ │ -000146f0: 2053 6d6f 6f74 6820 6361 7365 2077 6865 Smooth case whe │ │ │ │ -00014700: 6e20 7370 6563 6966 6965 6420 616e 6420 n specified and │ │ │ │ -00014710: 7265 7475 726e 3c2f 7370 616e 3e3c 2f64 return.
49 │ │ │ │ -00014770: 353c 2f73 7061 6e3e 3c73 7061 6e20 636c 5// │ │ │ │ -00014790: 2020 2020 2020 2d20 6465 7465 726d 696e - determin │ │ │ │ -000147a0: 6520 6966 2073 6861 7270 6e65 7373 2066 e if sharpness f │ │ │ │ -000147b0: 6f72 2070 6172 656e 7420 6973 2072 6571 or parent is req │ │ │ │ -000147c0: 7569 7265 6420 616e 6420 6761 7468 6572 uired and gather │ │ │ │ -000147d0: 2069 6620 736f 3c2f 7370 616e 3e3c 2f64 if so.
49 │ │ │ │ -00014830: 363c 2f73 7061 6e3e 3c73 7061 6e20 636c 6// │ │ │ │ -00014850: 2020 2020 2020 2d20 6966 2075 6e73 7065 - if unspe │ │ │ │ -00014860: 6369 6669 6564 2c20 6465 7465 726d 696e cified, determin │ │ │ │ -00014870: 6520 7468 6520 7061 7265 6e74 2072 756c e the parent rul │ │ │ │ -00014880: 653c 2f73 7061 6e3e 3c2f 6469 763e 0a3c e
.< │ │ │ │ -00014890: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -000148a0: 3e3c 6120 6964 3d22 6c30 3034 3937 2220 > 497// │ │ │ │ -00014900: 202d 2061 7373 6967 6e20 6d61 736b 2066 - assign mask f │ │ │ │ -00014910: 6f72 2074 6865 2070 6172 656e 7420 7275 or the parent ru │ │ │ │ -00014920: 6c65 202d 2d20 7265 7475 726e 696e 6720 le -- returning │ │ │ │ -00014930: 6966 2053 6d6f 6f74 682f 4461 7274 3c2f if Smooth/Dart
.
< │ │ │ │ -00014980: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00014990: 6e6f 223e 2020 3439 383c 2f73 7061 6e3e no"> 498 │ │ │ │ -000149a0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // - │ │ │ │ -000149c0: 7265 7475 726e 2069 6620 6368 696c 6420 return if child │ │ │ │ -000149d0: 7275 6c65 206d 6174 6368 6573 2070 6172 rule matches par │ │ │ │ -000149e0: 656e 743c 2f73 7061 6e3e 3c2f 6469 763e ent
│ │ │ │ -000149f0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00014a20: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 499// │ │ │ │ -00014a60: 2020 202d 2067 6174 6865 7220 7368 6172 - gather shar │ │ │ │ -00014a70: 706e 6573 7320 666f 7220 6368 696c 6420 pness for child │ │ │ │ -00014a80: 746f 2064 6574 6572 6d69 6e65 206f 7220 to determine or │ │ │ │ -00014a90: 636f 6d62 696e 6520 6368 696c 6420 7275 combine child ru │ │ │ │ -00014aa0: 6c65 3c2f 7370 616e 3e3c 2f64 6976 3e0a le
. │ │ │ │ -00014ab0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
501// - as │ │ │ │ -00014bf0: 7369 676e 206c 6f63 616c 206d 6173 6b20 sign local mask │ │ │ │ -00014c00: 666f 7220 6368 696c 6420 7275 6c65 3c2f for child rule
.
< │ │ │ │ -00014c50: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00014c60: 6e6f 223e 2020 3530 323c 2f73 7061 6e3e no"> 502 │ │ │ │ -00014c70: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // - │ │ │ │ -00014c90: 636f 6d62 696e 6520 6c6f 6361 6c20 6368 combine local ch │ │ │ │ -00014ca0: 696c 6420 6d61 736b 2077 6974 6820 7468 ild mask with th │ │ │ │ -00014cb0: 6520 7061 7265 6e74 206d 6173 6b3c 2f73 e parent mask
.
503< │ │ │ │ -00014d20: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00014d30: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
5 │ │ │ │ -00014d90: 3034 3c2f 7370 616e 3e3c 7370 616e 2063 04/ │ │ │ │ -00014db0: 2f20 2052 656d 656d 6265 7220 2d2d 2069 / Remember -- i │ │ │ │ -00014dc0: 6620 7468 6520 7061 7265 6e74 2072 756c f the parent rul │ │ │ │ -00014dd0: 6520 6973 2073 7065 6369 6669 6564 2062 e is specified b │ │ │ │ -00014de0: 7574 2074 6865 2063 6869 6c64 2069 7320 ut the child is │ │ │ │ -00014df0: 6e6f 742c 2074 6869 7320 696d 706c 6965 not, this implie │ │ │ │ -00014e00: 7320 6f6e 6c79 206f 6e65 3c2f 7370 616e s only one
.
│ │ │ │ -00014e60: 2020 3530 353c 2f73 7061 6e3e 3c73 7061 505// of the two │ │ │ │ -00014e90: 206f 7074 696f 6e61 6c20 7275 6c65 7320 optional rules │ │ │ │ -00014ea0: 7761 7320 7370 6563 6966 6965 6420 616e was specified an │ │ │ │ -00014eb0: 6420 6973 206d 6561 6e74 2074 6f20 696e d is meant to in │ │ │ │ -00014ec0: 6469 6361 7465 2074 6865 7265 2069 7320 dicate there is │ │ │ │ -00014ed0: 6e6f 2074 7261 6e73 6974 696f 6e2c 3c2f no transition,
.
< │ │ │ │ -00014f20: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00014f30: 6e6f 223e 2020 3530 363c 2f73 7061 6e3e no"> 506 │ │ │ │ -00014f40: 3c73 7061 6e20 636c 6173 733d 2263 6f6d // so the │ │ │ │ -00014f60: 2063 6869 6c64 2072 756c 6520 7368 6f75 child rule shou │ │ │ │ -00014f70: 6c64 2062 6520 6173 7369 676e 6564 2074 ld be assigned t │ │ │ │ -00014f80: 6f20 6265 2074 6865 2073 616d 6520 2877 o be the same (w │ │ │ │ -00014f90: 6973 6820 7468 6520 636f 6d70 696c 6572 ish the compiler │ │ │ │ -00014fa0: 2077 6f75 6c64 2061 6c6c 6f77 2074 6869 would allow thi │ │ │ │ -00014fb0: 733c 2f73 7061 6e3e 3c2f 6469 763e 0a3c s
.< │ │ │ │ -00014fc0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00014fd0: 3e3c 6120 6964 3d22 6c30 3035 3037 2220 > 507// in │ │ │ │ -00015030: 6465 6661 756c 7420 7661 6c75 6520 6173 default value as │ │ │ │ -00015040: 7369 676e 6d65 6e74 292e 3c2f 7370 616e signment).
.
│ │ │ │ -000150a0: 2020 3530 383c 2f73 7061 6e3e 3c73 7061 508//
.
509< │ │ │ │ -00015120: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>temp │ │ │ │ -00015140: 6c61 7465 3c2f 7370 616e 3e20 266c 743b late < │ │ │ │ -00015150: 5363 6865 6d65 5479 7065 2053 4348 454d SchemeType SCHEM │ │ │ │ -00015160: 4526 6774 3b3c 2f64 6976 3e0a 3c64 6976 E>
.
< │ │ │ │ -000151a0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -000151b0: 6e6f 223e 2020 3531 303c 2f73 7061 6e3e no"> 510 │ │ │ │ -000151c0: 3c73 7061 6e20 636c 6173 733d 226b 6579 template < │ │ │ │ -00015200: 7479 7065 6e61 6d65 3c2f 7370 616e 3e20 typename │ │ │ │ -00015210: 5645 5254 4558 2c20 3c73 7061 6e20 636c VERTEX, ty │ │ │ │ -00015230: 7065 6e61 6d65 3c2f 7370 616e 3e20 4d41 pename MA │ │ │ │ -00015240: 534b 2667 743b 3c2f 6469 763e 0a3c 6469 SK>
.< │ │ │ │ -00015260: 6120 6964 3d22 6c30 3035 3131 2220 6e61 a id="l00511" na │ │ │ │ -00015270: 6d65 3d22 6c30 3035 3131 223e 3c2f 613e me="l00511"> │ │ │ │ -00015280: 3c73 7061 6e20 636c 6173 733d 226c 696e 511void< │ │ │ │ -000152c0: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
...
513< │ │ │ │ -000154c0: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ -000154d0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -000154e0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -000154f0: 204d 4153 4b26 616d 703b 2020 2020 2020 MASK& │ │ │ │ -00015500: 2020 2020 206d 6173 6b2c 3c2f 6469 763e mask,
│ │ │ │ -00015510: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00015540: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 514 │ │ │ │ -00015570: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00015580: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00015590: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Crease::Rule │ │ │ │ -000155f0: 3c2f 613e 2070 5275 6c65 2c3c 2f64 6976 pRule,
.
515< │ │ │ │ -00015650: 2f73 7061 6e3e 2020 2020 2020 2020 2020 /span> │ │ │ │ -00015660: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00015670: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00015680: 203c 6120 636c 6173 733d 2263 6f64 6520 Crease::Rul │ │ │ │ -000156e0: 653c 2f61 3e20 6352 756c 6529 3c73 7061 e cRule) const │ │ │ │ -00015710: 7b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 {
.
│ │ │ │ -00015760: 2020 3531 363c 2f73 7061 6e3e 203c 2f64 516 .
51 │ │ │ │ -000157c0: 373c 2f73 7061 6e3e 2020 2020 3c73 7061 7 // Quick assi │ │ │ │ -000157f0: 676e 6d65 6e74 2061 6e64 2072 6574 7572 gnment and retur │ │ │ │ -00015800: 6e20 666f 7220 7468 6520 6d6f 7374 2063 n for the most c │ │ │ │ -00015810: 6f6d 6d6f 6e20 6361 7365 3a3c 2f73 7061 ommon case:
.
518 │ │ │ │ -00015880: 203c 7370 616e 2063 6c61 7373 3d22 6b65 if ((pRule == │ │ │ │ -000158b0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 Crease::RULE_ │ │ │ │ -00015930: 534d 4f4f 5448 3c2f 613e 2920 7c7c 2028 SMOOTH) || ( │ │ │ │ -00015940: 7052 756c 6520 3d3d 203c 6120 636c 6173 pRule == Crea │ │ │ │ -000159c0: 7365 3a3a 5255 4c45 5f44 4152 543c 2f61 se::RULE_DART)) {
.
< │ │ │ │ -00015a10: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00015a20: 6e6f 223e 2020 3531 393c 2f73 7061 6e3e no"> 519 │ │ │ │ -00015a30: 2020 2020 2020 2020 6173 7369 676e 536d assignSm │ │ │ │ -00015a40: 6f6f 7468 4d61 736b 466f 7256 6572 7465 oothMaskForVerte │ │ │ │ -00015a50: 7828 7665 7274 6578 2c20 6d61 736b 293b x(vertex, mask); │ │ │ │ -00015a60: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00015ab0: 2035 3230 3c2f 7370 616e 3e20 2020 2020 520 │ │ │ │ -00015ac0: 2020 203c 7370 616e 2063 6c61 7373 3d22 ret │ │ │ │ -00015ae0: 7572 6e3c 2f73 7061 6e3e 3b3c 2f64 6976 urn;
.
521< │ │ │ │ -00015b40: 2f73 7061 6e3e 2020 2020 7d3c 2f64 6976 /span> }
.
522< │ │ │ │ -00015ba0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -00015bc0: 2f2f 2020 4966 2075 6e73 7065 6369 6669 // If unspecifi │ │ │ │ -00015bd0: 6564 2c20 6173 7369 676e 2074 6865 2063 ed, assign the c │ │ │ │ -00015be0: 6869 6c64 2072 756c 6520 746f 206d 6174 hild rule to mat │ │ │ │ -00015bf0: 6368 2074 6865 2070 6172 656e 7420 7275 ch the parent ru │ │ │ │ -00015c00: 6c65 2069 6620 7370 6563 6966 6965 643a le if specified: │ │ │ │ -00015c10: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -00015c30: 3c61 2069 643d 226c 3030 3532 3322 206e 523 │ │ │ │ -00015c90: 6966 3c2f 7370 616e 3e20 2828 6352 756c if ((cRul │ │ │ │ -00015ca0: 6520 3d3d 203c 6120 636c 6173 733d 2263 e == Crease:: │ │ │ │ -00015d20: 5255 4c45 5f55 4e4b 4e4f 574e 3c2f 613e RULE_UNKNOWN │ │ │ │ -00015d30: 2920 2661 6d70 3b26 616d 703b 2028 7052 ) && (pR │ │ │ │ -00015d40: 756c 6520 213d 203c 6120 636c 6173 733d ule != Crease │ │ │ │ -00015dc0: 3a3a 5255 4c45 5f55 4e4b 4e4f 574e 3c2f ::RULE_UNKNOWN)) {
.< │ │ │ │ -00015df0: 6120 6964 3d22 6c30 3035 3234 2220 6e61 a id="l00524" na │ │ │ │ -00015e00: 6d65 3d22 6c30 3035 3234 223e 3c2f 613e me="l00524"> │ │ │ │ -00015e10: 3c73 7061 6e20 636c 6173 733d 226c 696e 524 cRule = │ │ │ │ -00015e40: 2070 5275 6c65 3b3c 2f64 6976 3e0a 3c64 pRule;
. │ │ │ │ -00015e60: 3c61 2069 643d 226c 3030 3532 3522 206e 525 }
. │ │ │ │ -00015ec0: 3c61 2069 643d 226c 3030 3532 3622 206e 526 │ │ │ │ -00015f20: 696e 743c 2f73 7061 6e3e 2076 616c 656e int valen │ │ │ │ -00015f30: 6365 203d 2076 6572 7465 782e 4765 744e ce = vertex.GetN │ │ │ │ -00015f40: 756d 4564 6765 7328 293b 3c2f 6469 763e umEdges();
│ │ │ │ -00015f50: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -00015fc0: 6120 6964 3d22 6c30 3035 3238 2220 6e61 a id="l00528" na │ │ │ │ -00015fd0: 6d65 3d22 6c30 3035 3238 223e 3c2f 613e me="l00528"> │ │ │ │ -00015fe0: 3c73 7061 6e20 636c 6173 733d 226c 696e 528 //
.
529 │ │ │ │ -00016080: 2020 203c 7370 616e 2063 6c61 7373 3d22 // Det │ │ │ │ -000160a0: 6572 6d69 6e65 2069 6620 7765 206e 6565 ermine if we nee │ │ │ │ -000160b0: 6420 7468 6520 7061 7265 6e74 2065 6467 d the parent edg │ │ │ │ -000160c0: 6520 7368 6172 706e 6573 7320 7661 6c75 e sharpness valu │ │ │ │ -000160d0: 6573 202d 2d20 6964 656e 7469 6679 2f67 es -- identify/g │ │ │ │ -000160e0: 6174 6865 7220 6966 2073 6f3c 2f73 7061 ather if so
.
530 │ │ │ │ -00016150: 203c 7370 616e 2063 6c61 7373 3d22 636f // and u │ │ │ │ -00016170: 7365 2069 7420 746f 2063 6f6d 7075 7465 se it to compute │ │ │ │ -00016180: 2074 6865 2070 6172 656e 7420 7275 6c65 the parent rule │ │ │ │ -00016190: 2069 6620 756e 7370 6563 6966 6965 643a if unspecified: │ │ │ │ -000161a0: 3c2f 7370 616e 3e3c 2f64 6976 3e0a 3c64
. │ │ │ │ -000161c0: 3c61 2069 643d 226c 3030 3533 3122 206e 531 //
.
< │ │ │ │ -00016260: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00016270: 6e6f 223e 2020 3533 323c 2f73 7061 6e3e no"> 532 │ │ │ │ -00016280: 2020 2020 3c73 7061 6e20 636c 6173 733d fl │ │ │ │ -000162a0: 6f61 743c 2f73 7061 6e3e 202a 2070 4564 oat * pEd │ │ │ │ -000162b0: 6765 5368 6172 706e 6573 7342 7566 6665 geSharpnessBuffe │ │ │ │ -000162c0: 7220 3d20 283c 7370 616e 2063 6c61 7373 r = (f │ │ │ │ -000162e0: 6c6f 6174 3c2f 7370 616e 3e20 2a29 616c loat *)al │ │ │ │ -000162f0: 6c6f 6361 2876 616c 656e 6365 2a3c 7370 loca(valence*sizeof │ │ │ │ -00016320: 283c 7370 616e 2063 6c61 7373 3d22 6b65 (float │ │ │ │ -00016340: 3c2f 7370 616e 3e29 292c 3c2f 6469 763e )),
│ │ │ │ -00016350: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00016380: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 533 * │ │ │ │ -000163b0: 2070 4564 6765 5368 6172 706e 6573 7320 pEdgeSharpness │ │ │ │ -000163c0: 2020 3d20 302c 3c2f 6469 763e 0a3c 6469 = 0,
.< │ │ │ │ -000163e0: 6120 6964 3d22 6c30 3035 3334 2220 6e61 a id="l00534" na │ │ │ │ -000163f0: 6d65 3d22 6c30 3035 3334 223e 3c2f 613e me="l00534"> │ │ │ │ -00016400: 3c73 7061 6e20 636c 6173 733d 226c 696e 534 pVe │ │ │ │ -00016430: 7274 6578 5368 6172 706e 6573 7320 3d20 rtexSharpness = │ │ │ │ -00016440: 302e 3066 3b3c 2f64 6976 3e0a 3c64 6976 0.0f;
.
< │ │ │ │ -00016480: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00016490: 6e6f 223e 2020 3533 353c 2f73 7061 6e3e no"> 535 │ │ │ │ -000164a0: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ -000164f0: 2020 3533 363c 2f73 7061 6e3e 2020 2020 536 │ │ │ │ -00016500: 3c73 7061 6e20 636c 6173 733d 226b 6579 bool requirePar │ │ │ │ -00016530: 656e 7453 6861 7270 6e65 7373 203d 2028 entSharpness = ( │ │ │ │ -00016540: 7052 756c 6520 3d3d 203c 6120 636c 6173 pRule == Crea │ │ │ │ -000165c0: 7365 3a3a 5255 4c45 5f55 4e4b 4e4f 574e se::RULE_UNKNOWN │ │ │ │ -000165d0: 3c2f 613e 2920 7c7c 3c2f 6469 763e 0a3c ) ||
.< │ │ │ │ -000165e0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -000165f0: 3e3c 6120 6964 3d22 6c30 3035 3337 2220 > 537 │ │ │ │ -00016640: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00016650: 2020 2020 2028 7052 756c 6520 3d3d 203c (pRule == < │ │ │ │ -00016660: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00016670: 5f65 6e75 6d76 616c 7565 2220 6872 6566 _enumvalue" href │ │ │ │ -00016680: 3d22 6130 3133 3333 2e68 746d 6c23 6131 ="a01333.html#a1 │ │ │ │ -00016690: 3166 6364 3531 6566 3836 3131 3866 3635 1fcd51ef86118f65 │ │ │ │ -000166a0: 6536 3033 6331 3437 3433 3737 6137 3861 e603c1474377a78a │ │ │ │ -000166b0: 3936 3666 6131 6165 3861 6562 3835 3837 966fa1ae8aeb8587 │ │ │ │ -000166c0: 6334 3938 6366 3661 3932 6363 3333 3335 c498cf6a92cc3335 │ │ │ │ -000166d0: 223e 4372 6561 7365 3a3a 5255 4c45 5f43 ">Crease::RULE_C │ │ │ │ -000166e0: 5245 4153 453c 2f61 3e29 207c 7c3c 2f64 REASE) ||.
53 │ │ │ │ -00016740: 383c 2f73 7061 6e3e 2020 2020 2020 2020 8 │ │ │ │ -00016750: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00016760: 2020 2020 2020 2020 2020 2870 5275 6c65 (pRule │ │ │ │ -00016770: 2021 3d20 6352 756c 6529 3b3c 2f64 6976 != cRule);
.
539< │ │ │ │ -000167d0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> if (r │ │ │ │ -00016800: 6571 7569 7265 5061 7265 6e74 5368 6172 equireParentShar │ │ │ │ -00016810: 706e 6573 7329 207b 3c2f 6469 763e 0a3c pness) {
.< │ │ │ │ -00016820: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00016830: 3e3c 6120 6964 3d22 6c30 3035 3430 2220 > 540 pVert │ │ │ │ -00016880: 6578 5368 6172 706e 6573 7320 3d20 7665 exSharpness = ve │ │ │ │ -00016890: 7274 6578 2e47 6574 5368 6172 706e 6573 rtex.GetSharpnes │ │ │ │ -000168a0: 7328 293b 3c2f 6469 763e 0a3c 6469 7620 s();
.
541 │ │ │ │ -00016900: 2020 2020 2020 2070 4564 6765 5368 6172 pEdgeShar │ │ │ │ -00016910: 706e 6573 7320 2020 3d20 7665 7274 6578 pness = vertex │ │ │ │ -00016920: 2e47 6574 5368 6172 706e 6573 7350 6572 .GetSharpnessPer │ │ │ │ -00016930: 4564 6765 2870 4564 6765 5368 6172 706e Edge(pEdgeSharpn │ │ │ │ -00016940: 6573 7342 7566 6665 7229 3b3c 2f64 6976 essBuffer);
.
542< │ │ │ │ -000169a0: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ -000169c0: 3c61 2069 643d 226c 3030 3534 3322 206e 543 if (p │ │ │ │ -00016a30: 5275 6c65 203d 3d20 3c61 2063 6c61 7373 Rule == Creas │ │ │ │ -00016ab0: 653a 3a52 554c 455f 554e 4b4e 4f57 4e3c e::RULE_UNKNOWN< │ │ │ │ -00016ac0: 2f61 3e29 207b 3c2f 6469 763e 0a3c 6469 /a>) {
.< │ │ │ │ -00016ae0: 6120 6964 3d22 6c30 3035 3434 2220 6e61 a id="l00544" na │ │ │ │ -00016af0: 6d65 3d22 6c30 3035 3434 223e 3c2f 613e me="l00544"> │ │ │ │ -00016b00: 3c73 7061 6e20 636c 6173 733d 226c 696e 544 pRu │ │ │ │ -00016b30: 6c65 203d 203c 6120 636c 6173 733d 2263 le = Crease(_opt │ │ │ │ -00016b70: 696f 6e73 292e 3c61 2063 6c61 7373 3d22 ions).Determine │ │ │ │ -00016bd0: 5665 7274 6578 5665 7274 6578 5275 6c65 VertexVertexRule │ │ │ │ -00016be0: 3c2f 613e 2870 5665 7274 6578 5368 6172 (pVertexShar │ │ │ │ -00016bf0: 706e 6573 732c 2076 616c 656e 6365 2c20 pness, valence, │ │ │ │ -00016c00: 7045 6467 6553 6861 7270 6e65 7373 293b pEdgeSharpness); │ │ │ │ -00016c10: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00016c60: 2035 3435 3c2f 7370 616e 3e20 2020 2020 545 │ │ │ │ -00016c70: 2020 207d 3c2f 6469 763e 0a3c 6469 7620 }
.
546 │ │ │ │ -00016cd0: 2020 207d 3c2f 6469 763e 0a3c 6469 7620 }
.
547 │ │ │ │ -00016d30: 2020 203c 7370 616e 2063 6c61 7373 3d22 if< │ │ │ │ -00016d50: 2f73 7061 6e3e 2028 2870 5275 6c65 203d /span> ((pRule = │ │ │ │ -00016d60: 3d20 3c61 2063 6c61 7373 3d22 636f 6465 = Crease::RUL │ │ │ │ -00016de0: 455f 534d 4f4f 5448 3c2f 613e 2920 7c7c E_SMOOTH) || │ │ │ │ -00016df0: 2028 7052 756c 6520 3d3d 203c 6120 636c (pRule == Cr │ │ │ │ -00016e70: 6561 7365 3a3a 5255 4c45 5f44 4152 543c ease::RULE_DART< │ │ │ │ -00016e80: 2f61 3e29 2920 7b3c 2f64 6976 3e0a 3c64 /a>)) {
. │ │ │ │ -00016ea0: 3c61 2069 643d 226c 3030 3534 3822 206e 548 assign │ │ │ │ -00016ef0: 536d 6f6f 7468 4d61 736b 466f 7256 6572 SmoothMaskForVer │ │ │ │ -00016f00: 7465 7828 7665 7274 6578 2c20 6d61 736b tex(vertex, mask │ │ │ │ -00016f10: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
549 │ │ │ │ -00016f70: 2020 2020 203c 7370 616e 2063 6c61 7373 r │ │ │ │ -00016f90: 6574 7572 6e3c 2f73 7061 6e3e 3b20 203c eturn; < │ │ │ │ -00016fa0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -00016fb0: 656e 7422 3e2f 2f20 2041 7320 646f 6e65 ent">// As done │ │ │ │ -00016fc0: 206f 6e20 656e 7472 792c 2077 6520 6361 on entry, we ca │ │ │ │ -00016fd0: 6e20 7265 7475 726e 2069 6d6d 6564 6961 n return immedia │ │ │ │ -00016fe0: 7465 6c79 2069 6620 7061 7265 6e74 2069 tely if parent i │ │ │ │ -00016ff0: 7320 536d 6f6f 7468 2f44 6172 743c 2f73 s Smooth/Dart
.
550 │ │ │ │ -00017060: 2020 207d 203c 7370 616e 2063 6c61 7373 } e │ │ │ │ -00017080: 6c73 653c 2f73 7061 6e3e 203c 7370 616e lse if ( │ │ │ │ -000170b0: 7052 756c 6520 3d3d 203c 6120 636c 6173 pRule == Crea │ │ │ │ -00017130: 7365 3a3a 5255 4c45 5f43 5245 4153 453c se::RULE_CREASE< │ │ │ │ -00017140: 2f61 3e29 207b 3c2f 6469 763e 0a3c 6469 /a>) {
.< │ │ │ │ -00017160: 6120 6964 3d22 6c30 3035 3531 2220 6e61 a id="l00551" na │ │ │ │ -00017170: 6d65 3d22 6c30 3035 3531 223e 3c2f 613e me="l00551"> │ │ │ │ -00017180: 3c73 7061 6e20 636c 6173 733d 226c 696e 551 int cr │ │ │ │ -000171d0: 6561 7365 456e 6473 5b32 5d3b 3c2f 6469 easeEnds[2];.
552 │ │ │ │ -00017230: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ -00017240: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00017250: 5f63 6c61 7373 2220 6872 6566 3d22 6130 _class" href="a0 │ │ │ │ -00017260: 3133 3333 2e68 746d 6c22 3e43 7265 6173 1333.html">Creas │ │ │ │ -00017270: 653c 2f61 3e28 5f6f 7074 696f 6e73 292e e(_options). │ │ │ │ -00017280: 3c61 2063 6c61 7373 3d22 636f 6465 2068 GetSharpEdgePai │ │ │ │ -000172e0: 724f 6643 7265 6173 653c 2f61 3e28 7045 rOfCrease(pE │ │ │ │ -000172f0: 6467 6553 6861 7270 6e65 7373 2c20 7661 dgeSharpness, va │ │ │ │ -00017300: 6c65 6e63 652c 2063 7265 6173 6545 6e64 lence, creaseEnd │ │ │ │ -00017310: 7329 3b3c 2f64 6976 3e0a 3c64 6976 2063 s);
.
553 < │ │ │ │ -00017370: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -000173c0: 3535 343c 2f73 7061 6e3e 2020 2020 2020 554 │ │ │ │ -000173d0: 2020 6173 7369 676e 4372 6561 7365 4d61 assignCreaseMa │ │ │ │ -000173e0: 736b 466f 7256 6572 7465 7828 7665 7274 skForVertex(vert │ │ │ │ -000173f0: 6578 2c20 6d61 736b 2c20 6372 6561 7365 ex, mask, crease │ │ │ │ -00017400: 456e 6473 293b 3c2f 6469 763e 0a3c 6469 Ends);
.< │ │ │ │ -00017420: 6120 6964 3d22 6c30 3035 3535 2220 6e61 a id="l00555" na │ │ │ │ -00017430: 6d65 3d22 6c30 3035 3535 223e 3c2f 613e me="l00555"> │ │ │ │ -00017440: 3c73 7061 6e20 636c 6173 733d 226c 696e 555 } else {.
5 │ │ │ │ -000174e0: 3536 3c2f 7370 616e 3e20 2020 2020 2020 56 │ │ │ │ -000174f0: 2061 7373 6967 6e43 6f72 6e65 724d 6173 assignCornerMas │ │ │ │ -00017500: 6b46 6f72 5665 7274 6578 2876 6572 7465 kForVertex(verte │ │ │ │ -00017510: 782c 206d 6173 6b29 3b3c 2f64 6976 3e0a x, mask);
. │ │ │ │ -00017520: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
. │ │ │ │ -00017580: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ -00017670: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00017680: 6e6f 223e 2020 3535 393c 2f73 7061 6e3e no"> 559 │ │ │ │ -00017690: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ -000176e0: 2020 3536 303c 2f73 7061 6e3e 2020 2020 560 │ │ │ │ -000176f0: 3c73 7061 6e20 636c 6173 733d 2263 6f6d //< │ │ │ │ -00017710: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00017760: 3536 313c 2f73 7061 6e3e 2020 2020 3c73 561 // Identify │ │ │ │ -00017790: 2f67 6174 6865 7220 6368 696c 6420 7368 /gather child sh │ │ │ │ -000177a0: 6172 706e 6573 7320 746f 2063 6f6d 6269 arpness to combi │ │ │ │ -000177b0: 6e65 206d 6173 6b73 2066 6f72 2074 6865 ne masks for the │ │ │ │ -000177c0: 2074 776f 2064 6966 6665 7269 6e67 2052 two differing R │ │ │ │ -000177d0: 756c 6573 3a3c 2f73 7061 6e3e 3c2f 6469 ules:.
562 │ │ │ │ -00017830: 3c2f 7370 616e 3e20 2020 203c 7370 616e //
│ │ │ │ -00017860: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00017890: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 563 Crease │ │ │ │ -000178f0: 6372 6561 7365 285f 6f70 7469 6f6e 7329 crease(_options) │ │ │ │ -00017900: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -00017950: 2020 3536 343c 2f73 7061 6e3e 203c 2f64 564 .
56 │ │ │ │ -000179b0: 353c 2f73 7061 6e3e 2020 2020 3c73 7061 5 float * cEdgeSharpn │ │ │ │ -000179f0: 6573 7342 7566 6665 7220 3d20 283c 7370 essBuffer = (float *)alloca(val │ │ │ │ -00017a30: 656e 6365 2a3c 7370 616e 2063 6c61 7373 ence*sizeo │ │ │ │ -00017a50: 663c 2f73 7061 6e3e 283c 7370 616e 2063 f(float) │ │ │ │ -00017a80: 292c 3c2f 6469 763e 0a3c 6469 7620 636c ),
.
566 │ │ │ │ -00017ae0: 2020 2020 2020 202a 2063 4564 6765 5368 * cEdgeSh │ │ │ │ -00017af0: 6172 706e 6573 7320 3d20 7665 7274 6578 arpness = vertex │ │ │ │ -00017b00: 2e47 6574 4368 696c 6453 6861 7270 6e65 .GetChildSharpne │ │ │ │ -00017b10: 7373 5065 7245 6467 6528 6372 6561 7365 ssPerEdge(crease │ │ │ │ -00017b20: 2c20 6345 6467 6553 6861 7270 6e65 7373 , cEdgeSharpness │ │ │ │ -00017b30: 4275 6666 6572 292c 3c2f 6469 763e 0a3c Buffer),
.< │ │ │ │ -00017b40: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00017b50: 3e3c 6120 6964 3d22 6c30 3035 3637 2220 > 567 c │ │ │ │ -00017ba0: 5665 7274 6578 5368 6172 706e 6573 7320 VertexSharpness │ │ │ │ -00017bb0: 3d20 7665 7274 6578 2e47 6574 4368 696c = vertex.GetChil │ │ │ │ -00017bc0: 6453 6861 7270 6e65 7373 2863 7265 6173 dSharpness(creas │ │ │ │ -00017bd0: 6529 3b3c 2f64 6976 3e0a 3c64 6976 2063 e);
.
568 < │ │ │ │ -00017c30: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>. │ │ │ │ -00017d50: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -00017d80: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 570 cRu │ │ │ │ -00017db0: 6c65 203d 2063 7265 6173 652e 3c61 2063 le = crease.Det │ │ │ │ -00017e10: 6572 6d69 6e65 5665 7274 6578 5665 7274 ermineVertexVert │ │ │ │ -00017e20: 6578 5275 6c65 3c2f 613e 2863 5665 7274 exRule(cVert │ │ │ │ -00017e30: 6578 5368 6172 706e 6573 732c 2076 616c exSharpness, val │ │ │ │ -00017e40: 656e 6365 2c20 6345 6467 6553 6861 7270 ence, cEdgeSharp │ │ │ │ -00017e50: 6e65 7373 293b 3c2f 6469 763e 0a3c 6469 ness);
.< │ │ │ │ -00017e70: 6120 6964 3d22 6c30 3035 3731 2220 6e61 a id="l00571" na │ │ │ │ -00017e80: 6d65 3d22 6c30 3035 3731 223e 3c2f 613e me="l00571"> │ │ │ │ -00017e90: 3c73 7061 6e20 636c 6173 733d 226c 696e 571 if (cR │ │ │ │ -00017ee0: 756c 6520 3d3d 2070 5275 6c65 2920 3c73 ule == pRule) return;
.< │ │ │ │ -00017f30: 6120 6964 3d22 6c30 3035 3732 2220 6e61 a id="l00572" na │ │ │ │ -00017f40: 6d65 3d22 6c30 3035 3732 223e 3c2f 613e me="l00572"> │ │ │ │ -00017f50: 3c73 7061 6e20 636c 6173 733d 226c 696e 572 }
.< │ │ │ │ -00017f90: 6120 6964 3d22 6c30 3035 3733 2220 6e61 a id="l00573" na │ │ │ │ -00017fa0: 6d65 3d22 6c30 3035 3733 223e 3c2f 613e me="l00573"> │ │ │ │ -00017fb0: 3c73 7061 6e20 636c 6173 733d 226c 696e 573
.
574 │ │ │ │ -00018030: 203c 7370 616e 2063 6c61 7373 3d22 636f // │ │ │ │ -00018050: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000180a0: 2035 3735 3c2f 7370 616e 3e20 2020 203c 575 < │ │ │ │ -000180b0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ -000180c0: 656e 7422 3e2f 2f20 2049 6e69 7469 616c ent">// Initial │ │ │ │ -000180d0: 697a 6520 6120 6c6f 6361 6c20 6368 696c ize a local chil │ │ │ │ -000180e0: 6420 6d61 736b 2c20 636f 6d70 7574 6520 d mask, compute │ │ │ │ -000180f0: 7468 6520 6672 6163 7469 6f6e 616c 2077 the fractional w │ │ │ │ -00018100: 6569 6768 7420 6672 6f6d 2070 6172 656e eight from paren │ │ │ │ -00018110: 7420 616e 6420 6368 696c 643c 2f73 7061 t and child
.
576 │ │ │ │ -00018180: 203c 7370 616e 2063 6c61 7373 3d22 636f // sharp │ │ │ │ -000181a0: 6e65 7373 2076 616c 7565 7320 616e 6420 ness values and │ │ │ │ -000181b0: 636f 6d62 696e 6520 7468 6520 7477 6f20 combine the two │ │ │ │ -000181c0: 6d61 736b 733a 3c2f 7370 616e 3e3c 2f64 masks:.
57 │ │ │ │ -00018220: 373c 2f73 7061 6e3e 2020 2020 3c73 7061 7 //
.
578< │ │ │ │ -000182a0: 2f73 7061 6e3e 2020 2020 3c73 7061 6e20 /span> │ │ │ │ -000182c0: 7479 7065 6465 663c 2f73 7061 6e3e 203c typedef < │ │ │ │ -000182d0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -000182e0: 6f72 6422 3e74 7970 656e 616d 653c 2f73 ord">typename MASK::Weigh │ │ │ │ -00018300: 7420 5765 6967 6874 3b3c 2f64 6976 3e0a t Weight;
. │ │ │ │ -00018310: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ -000183a0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -000183b0: 6e6f 223e 2020 3538 303c 2f73 7061 6e3e no"> 580 │ │ │ │ -000183c0: 2020 2020 5765 6967 6874 202a 2063 4d61 Weight * cMa │ │ │ │ -000183d0: 736b 5765 6967 6874 7320 3d20 2857 6569 skWeights = (Wei │ │ │ │ -000183e0: 6768 7420 2a29 616c 6c6f 6361 2828 3120 ght *)alloca((1 │ │ │ │ -000183f0: 2b20 3220 2a20 7661 6c65 6e63 6529 2a3c + 2 * valence)*< │ │ │ │ -00018400: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00018410: 6f72 6422 3e73 697a 656f 663c 2f73 7061 ord">sizeof(Weight));..
< │ │ │ │ -00018550: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00018560: 6e6f 223e 2020 3538 323c 2f73 7061 6e3e no"> 582 │ │ │ │ -00018570: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ -000185c0: 2020 3538 333c 2f73 7061 6e3e 2020 2020 583 │ │ │ │ -000185d0: 3c73 7061 6e20 636c 6173 733d 226b 6579 if ((cRule == < │ │ │ │ -00018600: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00018610: 5f65 6e75 6d76 616c 7565 2220 6872 6566 _enumvalue" href │ │ │ │ -00018620: 3d22 6130 3133 3333 2e68 746d 6c23 6131 ="a01333.html#a1 │ │ │ │ -00018630: 3166 6364 3531 6566 3836 3131 3866 3635 1fcd51ef86118f65 │ │ │ │ -00018640: 6536 3033 6331 3437 3433 3737 6137 3861 e603c1474377a78a │ │ │ │ -00018650: 3631 6431 3337 6638 3636 3939 3765 6433 61d137f866997ed3 │ │ │ │ -00018660: 3639 3365 3366 6361 6437 3664 6566 3566 693e3fcad76def5f │ │ │ │ -00018670: 223e 4372 6561 7365 3a3a 5255 4c45 5f53 ">Crease::RULE_S │ │ │ │ -00018680: 4d4f 4f54 483c 2f61 3e29 207c 7c20 2863 MOOTH) || (c │ │ │ │ -00018690: 5275 6c65 203d 3d20 3c61 2063 6c61 7373 Rule == Creas │ │ │ │ -00018710: 653a 3a52 554c 455f 4441 5254 3c2f 613e e::RULE_DART │ │ │ │ -00018720: 2929 207b 3c2f 6469 763e 0a3c 6469 7620 )) {
.
584 │ │ │ │ -00018780: 2020 2020 2020 2061 7373 6967 6e53 6d6f assignSmo │ │ │ │ -00018790: 6f74 684d 6173 6b46 6f72 5665 7274 6578 othMaskForVertex │ │ │ │ -000187a0: 2876 6572 7465 782c 2063 4d61 736b 293b (vertex, cMask); │ │ │ │ -000187b0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00018800: 2035 3835 3c2f 7370 616e 3e20 2020 207d 585 } │ │ │ │ -00018810: 203c 7370 616e 2063 6c61 7373 3d22 6b65 else< │ │ │ │ -00018830: 2f73 7061 6e3e 203c 7370 616e 2063 6c61 /span> if (cRul │ │ │ │ -00018860: 6520 3d3d 203c 6120 636c 6173 733d 2263 e == Crease:: │ │ │ │ -000188e0: 5255 4c45 5f43 5245 4153 453c 2f61 3e29 RULE_CREASE) │ │ │ │ -000188f0: 207b 3c2f 6469 763e 0a3c 6469 7620 636c {
.
586 │ │ │ │ -00018950: 2020 2020 203c 7370 616e 2063 6c61 7373 i │ │ │ │ -00018970: 6e74 3c2f 7370 616e 3e20 6372 6561 7365 nt crease │ │ │ │ -00018980: 456e 6473 5b32 5d3b 3c2f 6469 763e 0a3c Ends[2];
.< │ │ │ │ -00018990: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -000189a0: 3e3c 6120 6964 3d22 6c30 3035 3837 2220 > 587 Crease(_options).Get │ │ │ │ -00018a80: 5368 6172 7045 6467 6550 6169 724f 6643 SharpEdgePairOfC │ │ │ │ -00018a90: 7265 6173 653c 2f61 3e28 6345 6467 6553 rease(cEdgeS │ │ │ │ -00018aa0: 6861 7270 6e65 7373 2c20 7661 6c65 6e63 harpness, valenc │ │ │ │ -00018ab0: 652c 2063 7265 6173 6545 6e64 7329 3b3c e, creaseEnds);< │ │ │ │ -00018ac0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00018b10: 3538 383c 2f73 7061 6e3e 203c 2f64 6976 588
.
589< │ │ │ │ -00018b70: 2f73 7061 6e3e 2020 2020 2020 2020 6173 /span> as │ │ │ │ -00018b80: 7369 676e 4372 6561 7365 4d61 736b 466f signCreaseMaskFo │ │ │ │ -00018b90: 7256 6572 7465 7828 7665 7274 6578 2c20 rVertex(vertex, │ │ │ │ -00018ba0: 634d 6173 6b2c 2063 7265 6173 6545 6e64 cMask, creaseEnd │ │ │ │ -00018bb0: 7329 3b3c 2f64 6976 3e0a 3c64 6976 2063 s);
.
590 │ │ │ │ -00018c10: 2020 7d20 3c73 7061 6e20 636c 6173 733d } el │ │ │ │ -00018c30: 7365 3c2f 7370 616e 3e20 7b3c 2f64 6976 se {
.
591< │ │ │ │ -00018c90: 2f73 7061 6e3e 2020 2020 2020 2020 6173 /span> as │ │ │ │ -00018ca0: 7369 676e 436f 726e 6572 4d61 736b 466f signCornerMaskFo │ │ │ │ -00018cb0: 7256 6572 7465 7828 7665 7274 6578 2c20 rVertex(vertex, │ │ │ │ -00018cc0: 634d 6173 6b29 3b3c 2f64 6976 3e0a 3c64 cMask);
. │ │ │ │ -00018ce0: 3c61 2069 643d 226c 3030 3539 3222 206e 592 }
. │ │ │ │ -00018d40: 3c61 2069 643d 226c 3030 3539 3322 206e 593
.
594 │ │ │ │ -00018de0: 2020 5765 6967 6874 2070 5765 6967 6874 Weight pWeight │ │ │ │ -00018df0: 203d 2063 7265 6173 652e 3c61 2063 6c61 = crease.Compu │ │ │ │ -00018e50: 7465 4672 6163 7469 6f6e 616c 5765 6967 teFractionalWeig │ │ │ │ -00018e60: 6874 4174 5665 7274 6578 3c2f 613e 2870 htAtVertex(p │ │ │ │ -00018e70: 5665 7274 6578 5368 6172 706e 6573 732c VertexSharpness, │ │ │ │ -00018e80: 2063 5665 7274 6578 5368 6172 706e 6573 cVertexSharpnes │ │ │ │ -00018e90: 732c 3c2f 6469 763e 0a3c 6469 7620 636c s,
.
595 │ │ │ │ -00018ef0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00018f00: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00018f10: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00018f20: 7661 6c65 6e63 652c 2070 4564 6765 5368 valence, pEdgeSh │ │ │ │ -00018f30: 6172 706e 6573 732c 2063 4564 6765 5368 arpness, cEdgeSh │ │ │ │ -00018f40: 6172 706e 6573 7329 3b3c 2f64 6976 3e0a arpness);
. │ │ │ │ -00018f50: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.< │ │ │ │ -00018fd0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00018fe0: 3e3c 6120 6964 3d22 6c30 3035 3937 2220 > 597
.
598 │ │ │ │ -00019080: 2020 2063 4d61 736b 2e3c 6120 636c 6173 cMask.Combin │ │ │ │ -000190e0: 6556 6572 7465 7856 6572 7465 784d 6173 eVertexVertexMas │ │ │ │ -000190f0: 6b73 3c2f 613e 2863 5765 6967 6874 2c20 ks(cWeight, │ │ │ │ -00019100: 7057 6569 6768 742c 206d 6173 6b29 3b3c pWeight, mask);< │ │ │ │ -00019110: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00019160: 3539 393c 2f73 7061 6e3e 7d3c 2f64 6976 599}
.
.
600 .
6 │ │ │ │ -00019220: 3031 3c2f 7370 616e 3e3c 7370 616e 2063 01/ │ │ │ │ -00019240: 2f3c 2f73 7061 6e3e 3c2f 6469 763e 0a3c /
.< │ │ │ │ -00019250: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -00019260: 3e3c 6120 6964 3d22 6c30 3036 3032 2220 > 602// The │ │ │ │ -000192c0: 2063 6f6d 7075 7461 7469 6f6e 206f 6620 computation of │ │ │ │ -000192d0: 6c69 6d69 7420 6d61 736b 7320 666f 7220 limit masks for │ │ │ │ -000192e0: 7665 7274 6963 6573 3a3c 2f73 7061 6e3e vertices: │ │ │ │ -000192f0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00019340: 2036 3033 3c2f 7370 616e 3e3c 7370 616e 603//
│ │ │ │ -00019370: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -000193a0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 604templ │ │ │ │ -000193e0: 6174 653c 2f73 7061 6e3e 2026 6c74 3b53 ate <S │ │ │ │ -000193f0: 6368 656d 6554 7970 6520 5343 4845 4d45 chemeType SCHEME │ │ │ │ -00019400: 2667 743b 3c2f 6469 763e 0a3c 6469 7620 >
.
605< │ │ │ │ -00019460: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ -00019470: 6f72 6422 3e74 656d 706c 6174 653c 2f73 ord">template <t │ │ │ │ -000194a0: 7970 656e 616d 653c 2f73 7061 6e3e 2056 ypename V │ │ │ │ -000194b0: 4552 5445 582c 203c 7370 616e 2063 6c61 ERTEX, typ │ │ │ │ -000194d0: 656e 616d 653c 2f73 7061 6e3e 204d 4153 ename MAS │ │ │ │ -000194e0: 4b26 6774 3b3c 2f64 6976 3e0a 3c64 6976 K>
.
< │ │ │ │ -00019520: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -00019530: 6e6f 223e 2020 3630 363c 2f73 7061 6e3e no"> 606 │ │ │ │ -00019540: 3c73 7061 6e20 636c 6173 733d 226b 6579 void
.
.
│ │ │ │ -00019640: 2036 3037 3c2f 613e 3c2f 7370 616e 3e3c 607< │ │ │ │ -00019650: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ -00019660: 5f66 756e 6374 696f 6e22 2068 7265 663d _function" href= │ │ │ │ -00019670: 2261 3031 3334 312e 6874 6d6c 2361 3363 "a01341.html#a3c │ │ │ │ -00019680: 3864 3736 3363 6131 3863 3435 3763 3933 8d763ca18c457c93 │ │ │ │ -00019690: 3664 6230 6534 3739 3937 3436 6632 223e 6db0e4799746f2"> │ │ │ │ -000196a0: 5363 6865 6d65 266c 743b 5343 4845 4d45 Scheme<SCHEME │ │ │ │ -000196b0: 2667 743b 3a3a 436f 6d70 7574 6556 6572 >::ComputeVer │ │ │ │ -000196c0: 7465 784c 696d 6974 4d61 736b 3c2f 613e texLimitMask │ │ │ │ -000196d0: 2856 4552 5445 5820 3c73 7061 6e20 636c (VERTEX co │ │ │ │ -000196f0: 6e73 743c 2f73 7061 6e3e 2661 6d70 3b20 nst& │ │ │ │ -00019700: 7665 7274 6578 2c3c 2f64 6976 3e0a 3c64 vertex,
. │ │ │ │ -00019720: 3c61 2069 643d 226c 3030 3630 3822 206e 608 │ │ │ │ -00019770: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00019780: 2020 2020 2020 2020 204d 4153 4b26 616d MASK&am │ │ │ │ -00019790: 703b 2020 2020 2020 2020 206d 6173 6b2c p; mask, │ │ │ │ -000197a0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -000197f0: 2036 3039 3c2f 7370 616e 3e20 2020 2020 609 │ │ │ │ -00019800: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00019810: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -00019820: 2020 3c61 2063 6c61 7373 3d22 636f 6465 Crease::Ru │ │ │ │ -00019880: 6c65 3c2f 613e 2020 7275 6c65 293c 7370 le rule) const {
.
610 .
6 │ │ │ │ -00019960: 3131 3c2f 7370 616e 3e20 2020 203c 7370 11 if │ │ │ │ -00019990: 2028 2872 756c 6520 3d3d 203c 6120 636c ((rule == Cr │ │ │ │ -00019a10: 6561 7365 3a3a 5255 4c45 5f53 4d4f 4f54 ease::RULE_SMOOT │ │ │ │ -00019a20: 483c 2f61 3e29 207c 7c20 2872 756c 6520 H) || (rule │ │ │ │ -00019a30: 3d3d 203c 6120 636c 6173 733d 2263 6f64 == Crease::RU │ │ │ │ -00019ab0: 4c45 5f44 4152 543c 2f61 3e29 2920 7b3c LE_DART)) {< │ │ │ │ -00019ac0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -00019b10: 3631 323c 2f73 7061 6e3e 2020 2020 2020 612 │ │ │ │ -00019b20: 2020 6173 7369 676e 536d 6f6f 7468 4c69 assignSmoothLi │ │ │ │ -00019b30: 6d69 744d 6173 6b28 7665 7274 6578 2c20 mitMask(vertex, │ │ │ │ -00019b40: 6d61 736b 293b 3c2f 6469 763e 0a3c 6469 mask);
.< │ │ │ │ -00019b60: 6120 6964 3d22 6c30 3036 3133 2220 6e61 a id="l00613" na │ │ │ │ -00019b70: 6d65 3d22 6c30 3036 3133 223e 3c2f 613e me="l00613"> │ │ │ │ -00019b80: 3c73 7061 6e20 636c 6173 733d 226c 696e 613 } else if │ │ │ │ -00019bf0: 2028 7275 6c65 203d 3d20 3c61 2063 6c61 (rule == Cre │ │ │ │ -00019c70: 6173 653a 3a52 554c 455f 4352 4541 5345 ase::RULE_CREASE │ │ │ │ -00019c80: 3c2f 613e 2920 7b3c 2f64 6976 3e0a 3c64 ) {
. │ │ │ │ -00019ca0: 3c61 2069 643d 226c 3030 3631 3422 206e 614
float │ │ │ │ -00019d10: 202a 2065 6467 6553 6861 7270 6e65 7373 * edgeSharpness │ │ │ │ -00019d20: 203d 2028 3c73 7061 6e20 636c 6173 733d = (fl │ │ │ │ -00019d40: 6f61 743c 2f73 7061 6e3e 202a 2961 6c6c oat *)all │ │ │ │ -00019d50: 6f63 6128 7665 7274 6578 2e47 6574 4e75 oca(vertex.GetNu │ │ │ │ -00019d60: 6d45 6467 6573 2829 202a 203c 7370 616e mEdges() * sizeof(f │ │ │ │ -00019d90: 6c6f 6174 2929 3b3c 2f64 6976 3e0a 3c64 loat));
. │ │ │ │ -00019db0: 3c61 2069 643d 226c 3030 3631 3522 206e 615 vertex │ │ │ │ -00019e00: 2e47 6574 5368 6172 706e 6573 7350 6572 .GetSharpnessPer │ │ │ │ -00019e10: 4564 6765 2865 6467 6553 6861 7270 6e65 Edge(edgeSharpne │ │ │ │ -00019e20: 7373 293b 3c2f 6469 763e 0a3c 6469 7620 ss);
.
616 │ │ │ │ -00019e80: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00019ed0: 2036 3137 3c2f 7370 616e 3e20 2020 2020 617 │ │ │ │ -00019ee0: 2020 203c 7370 616e 2063 6c61 7373 3d22 int │ │ │ │ -00019f00: 3c2f 7370 616e 3e20 6372 6561 7365 456e creaseEn │ │ │ │ -00019f10: 6473 5b32 5d3b 3c2f 6469 763e 0a3c 6469 ds[2];
.< │ │ │ │ -00019f30: 6120 6964 3d22 6c30 3036 3138 2220 6e61 a id="l00618" na │ │ │ │ -00019f40: 6d65 3d22 6c30 3036 3138 223e 3c2f 613e me="l00618"> │ │ │ │ -00019f50: 3c73 7061 6e20 636c 6173 733d 226c 696e 618 Crease( │ │ │ │ -00019fb0: 5f6f 7074 696f 6e73 292e 3c61 2063 6c61 _options).GetSh │ │ │ │ -0001a010: 6172 7045 6467 6550 6169 724f 6643 7265 arpEdgePairOfCre │ │ │ │ -0001a020: 6173 653c 2f61 3e28 6564 6765 5368 6172 ase(edgeShar │ │ │ │ -0001a030: 706e 6573 732c 2076 6572 7465 782e 4765 pness, vertex.Ge │ │ │ │ -0001a040: 744e 756d 4564 6765 7328 292c 2063 7265 tNumEdges(), cre │ │ │ │ -0001a050: 6173 6545 6e64 7329 3b3c 2f64 6976 3e0a aseEnds);
. │ │ │ │ -0001a060: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
< │ │ │ │ -0001a0f0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0001a100: 6e6f 223e 2020 3632 303c 2f73 7061 6e3e no"> 620 │ │ │ │ -0001a110: 2020 2020 2020 2020 6173 7369 676e 4372 assignCr │ │ │ │ -0001a120: 6561 7365 4c69 6d69 744d 6173 6b28 7665 easeLimitMask(ve │ │ │ │ -0001a130: 7274 6578 2c20 6d61 736b 2c20 6372 6561 rtex, mask, crea │ │ │ │ -0001a140: 7365 456e 6473 293b 3c2f 6469 763e 0a3c seEnds);
.< │ │ │ │ -0001a150: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0001a160: 3e3c 6120 6964 3d22 6c30 3036 3231 2220 > 621 } else { │ │ │ │ -0001a1d0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0001a220: 2036 3232 3c2f 7370 616e 3e20 2020 2020 622 │ │ │ │ -0001a230: 2020 2061 7373 6967 6e43 6f72 6e65 724c assignCornerL │ │ │ │ -0001a240: 696d 6974 4d61 736b 2876 6572 7465 782c imitMask(vertex, │ │ │ │ -0001a250: 206d 6173 6b29 3b3c 2f64 6976 3e0a 3c64 mask);
. │ │ │ │ -0001a270: 3c61 2069 643d 226c 3030 3632 3322 206e 623 }
. │ │ │ │ -0001a2d0: 3c61 2069 643d 226c 3030 3632 3422 206e 624}
.
│ │ │ │ -0001a320: 0a3c 6469 7620 636c 6173 733d 226c 696e ..< │ │ │ │ -0001a390: 6120 6964 3d22 6c30 3036 3236 2220 6e61 a id="l00626" na │ │ │ │ -0001a3a0: 6d65 3d22 6c30 3036 3236 223e 3c2f 613e me="l00626"> │ │ │ │ -0001a3b0: 3c73 7061 6e20 636c 6173 733d 226c 696e 626template< │ │ │ │ -0001a3f0: 2f73 7061 6e3e 2026 6c74 3b53 6368 656d /span> <Schem │ │ │ │ -0001a400: 6554 7970 6520 5343 4845 4d45 2667 743b eType SCHEME> │ │ │ │ -0001a410: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0001a460: 2036 3237 3c2f 7370 616e 3e3c 7370 616e 627template │ │ │ │ -0001a490: 2026 6c74 3b3c 7370 616e 2063 6c61 7373 <typen │ │ │ │ -0001a4b0: 616d 653c 2f73 7061 6e3e 2056 4552 5445 ame VERTE │ │ │ │ -0001a4c0: 582c 203c 7370 616e 2063 6c61 7373 3d22 X, typenam │ │ │ │ -0001a4e0: 653c 2f73 7061 6e3e 204d 4153 4b26 6774 e MASK> │ │ │ │ -0001a4f0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ -0001a540: 2020 3632 383c 2f73 7061 6e3e 3c73 7061 628void
.
. │ │ │ │ -0001a5d0: 3c61 2069 643d 226c 3030 3632 3922 206e 629 │ │ │ │ -0001a650: 3c2f 613e 3c2f 7370 616e 3e3c 6120 636c Sche │ │ │ │ -0001a6b0: 6d65 266c 743b 5343 4845 4d45 2667 743b me<SCHEME> │ │ │ │ -0001a6c0: 3a3a 436f 6d70 7574 6556 6572 7465 784c ::ComputeVertexL │ │ │ │ -0001a6d0: 696d 6974 4d61 736b 3c2f 613e 2856 4552 imitMask(VER │ │ │ │ -0001a6e0: 5445 5820 3c73 7061 6e20 636c 6173 733d TEX const< │ │ │ │ -0001a700: 2f73 7061 6e3e 2661 6d70 3b20 7665 7274 /span>& vert │ │ │ │ -0001a710: 6578 2c3c 2f64 6976 3e0a 3c64 6976 2063 ex,
.
630 │ │ │ │ -0001a770: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0001a780: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0001a790: 2020 2020 204d 4153 4b26 616d 703b 2020 MASK& │ │ │ │ -0001a7a0: 2020 2020 2020 2070 6f73 4d61 736b 2c3c posMask,< │ │ │ │ -0001a7b0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0001a800: 3633 313c 2f73 7061 6e3e 2020 2020 2020 631 │ │ │ │ -0001a810: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0001a820: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0001a830: 204d 4153 4b26 616d 703b 2020 2020 2020 MASK& │ │ │ │ -0001a840: 2020 2074 616e 314d 6173 6b2c 3c2f 6469 tan1Mask,.
632 │ │ │ │ -0001a8a0: 3c2f 7370 616e 3e20 2020 2020 2020 2020 │ │ │ │ -0001a8b0: 2020 2020 2020 2020 2020 2020 2020 2020 │ │ │ │ -0001a8c0: 2020 2020 2020 2020 2020 2020 2020 4d41 MA │ │ │ │ -0001a8d0: 534b 2661 6d70 3b20 2020 2020 2020 2020 SK& │ │ │ │ -0001a8e0: 7461 6e32 4d61 736b 2c3c 2f64 6976 3e0a tan2Mask,
. │ │ │ │ -0001a8f0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
634< │ │ │ │ -0001aa50: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ -0001aa70: 3c61 2069 643d 226c 3030 3633 3522 206e 635 │ │ │ │ -0001aad0: 6966 3c2f 7370 616e 3e20 2828 7275 6c65 if ((rule │ │ │ │ -0001aae0: 203d 3d20 3c61 2063 6c61 7373 3d22 636f == Crease::R │ │ │ │ -0001ab60: 554c 455f 534d 4f4f 5448 3c2f 613e 2920 ULE_SMOOTH) │ │ │ │ -0001ab70: 7c7c 2028 7275 6c65 203d 3d20 3c61 2063 || (rule == C │ │ │ │ -0001abf0: 7265 6173 653a 3a52 554c 455f 4441 5254 rease::RULE_DART │ │ │ │ -0001ac00: 3c2f 613e 2929 207b 3c2f 6469 763e 0a3c )) {
.< │ │ │ │ -0001ac10: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ -0001ac20: 3e3c 6120 6964 3d22 6c30 3036 3336 2220 > 636 assig │ │ │ │ -0001ac70: 6e53 6d6f 6f74 684c 696d 6974 4d61 736b nSmoothLimitMask │ │ │ │ -0001ac80: 2876 6572 7465 782c 2070 6f73 4d61 736b (vertex, posMask │ │ │ │ -0001ac90: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
637 │ │ │ │ -0001acf0: 2020 2020 2061 7373 6967 6e53 6d6f 6f74 assignSmoot │ │ │ │ -0001ad00: 684c 696d 6974 5461 6e67 656e 744d 6173 hLimitTangentMas │ │ │ │ -0001ad10: 6b73 2876 6572 7465 782c 2074 616e 314d ks(vertex, tan1M │ │ │ │ -0001ad20: 6173 6b2c 2074 616e 324d 6173 6b29 3b3c ask, tan2Mask);< │ │ │ │ -0001ad30: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0001ad80: 3633 383c 2f73 7061 6e3e 2020 2020 7d20 638 } │ │ │ │ -0001ad90: 3c73 7061 6e20 636c 6173 733d 226b 6579 else │ │ │ │ -0001add0: 6966 3c2f 7370 616e 3e20 2872 756c 6520 if (rule │ │ │ │ -0001ade0: 3d3d 203c 6120 636c 6173 733d 2263 6f64 == Crease::RU │ │ │ │ -0001ae60: 4c45 5f43 5245 4153 453c 2f61 3e29 207b LE_CREASE) { │ │ │ │ -0001ae70: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0001aec0: 2036 3339 3c2f 7370 616e 3e20 2020 2020 639 │ │ │ │ -0001aed0: 2020 203c 7370 616e 2063 6c61 7373 3d22 flo │ │ │ │ -0001aef0: 6174 3c2f 7370 616e 3e20 2a20 6564 6765 at * edge │ │ │ │ -0001af00: 5368 6172 706e 6573 7320 3d20 283c 7370 Sharpness = (float *)alloca(ver │ │ │ │ -0001af40: 7465 782e 4765 744e 756d 4564 6765 7328 tex.GetNumEdges( │ │ │ │ -0001af50: 2920 2a20 3c73 7061 6e20 636c 6173 733d ) * sizeof │ │ │ │ -0001af70: 3c2f 7370 616e 3e28 666c 6f61 7429 293b (float)); │ │ │ │ -0001af80: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -0001afd0: 2036 3430 3c2f 7370 616e 3e20 2020 2020 640 │ │ │ │ -0001afe0: 2020 2076 6572 7465 782e 4765 7453 6861 vertex.GetSha │ │ │ │ -0001aff0: 7270 6e65 7373 5065 7245 6467 6528 6564 rpnessPerEdge(ed │ │ │ │ -0001b000: 6765 5368 6172 706e 6573 7329 3b3c 2f64 geSharpness);.
64 │ │ │ │ -0001b060: 313c 2f73 7061 6e3e 203c 2f64 6976 3e0a 1
. │ │ │ │ -0001b070: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -0001b0a0: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 642 int │ │ │ │ -0001b0f0: 2063 7265 6173 6545 6e64 735b 325d 3b3c creaseEnds[2];< │ │ │ │ -0001b100: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0001b150: 3634 333c 2f73 7061 6e3e 2020 2020 2020 643 │ │ │ │ -0001b160: 2020 3c61 2063 6c61 7373 3d22 636f 6465 Cr │ │ │ │ -0001b190: 6561 7365 3c2f 613e 285f 6f70 7469 6f6e ease(_option │ │ │ │ -0001b1a0: 7329 2e3c 6120 636c 6173 733d 2263 6f64 s).GetSharpEdge │ │ │ │ -0001b200: 5061 6972 4f66 4372 6561 7365 3c2f 613e PairOfCrease │ │ │ │ -0001b210: 2865 6467 6553 6861 7270 6e65 7373 2c20 (edgeSharpness, │ │ │ │ -0001b220: 7665 7274 6578 2e47 6574 4e75 6d45 6467 vertex.GetNumEdg │ │ │ │ -0001b230: 6573 2829 2c20 6372 6561 7365 456e 6473 es(), creaseEnds │ │ │ │ -0001b240: 293b 3c2f 6469 763e 0a3c 6469 7620 636c );
.
644 .
6 │ │ │ │ -0001b2f0: 3435 3c2f 7370 616e 3e20 2020 2020 2020 45 │ │ │ │ -0001b300: 2061 7373 6967 6e43 7265 6173 654c 696d assignCreaseLim │ │ │ │ -0001b310: 6974 4d61 736b 2876 6572 7465 782c 2070 itMask(vertex, p │ │ │ │ -0001b320: 6f73 4d61 736b 2c20 6372 6561 7365 456e osMask, creaseEn │ │ │ │ -0001b330: 6473 293b 3c2f 6469 763e 0a3c 6469 7620 ds);
.
646 │ │ │ │ -0001b390: 2020 2020 2020 2061 7373 6967 6e43 7265 assignCre │ │ │ │ -0001b3a0: 6173 654c 696d 6974 5461 6e67 656e 744d aseLimitTangentM │ │ │ │ -0001b3b0: 6173 6b73 2876 6572 7465 782c 2074 616e asks(vertex, tan │ │ │ │ -0001b3c0: 314d 6173 6b2c 2074 616e 324d 6173 6b2c 1Mask, tan2Mask, │ │ │ │ -0001b3d0: 2063 7265 6173 6545 6e64 7329 3b3c 2f64 creaseEnds);.
64 │ │ │ │ -0001b430: 373c 2f73 7061 6e3e 2020 2020 7d20 3c73 7 } else {
.
< │ │ │ │ -0001b4a0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0001b4b0: 6e6f 223e 2020 3634 383c 2f73 7061 6e3e no"> 648 │ │ │ │ -0001b4c0: 2020 2020 2020 2020 6173 7369 676e 436f assignCo │ │ │ │ -0001b4d0: 726e 6572 4c69 6d69 744d 6173 6b28 7665 rnerLimitMask(ve │ │ │ │ -0001b4e0: 7274 6578 2c20 706f 734d 6173 6b29 3b3c rtex, posMask);< │ │ │ │ -0001b4f0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0001b540: 3634 393c 2f73 7061 6e3e 2020 2020 2020 649 │ │ │ │ -0001b550: 2020 6173 7369 676e 436f 726e 6572 4c69 assignCornerLi │ │ │ │ -0001b560: 6d69 7454 616e 6765 6e74 4d61 736b 7328 mitTangentMasks( │ │ │ │ -0001b570: 7665 7274 6578 2c20 7461 6e31 4d61 736b vertex, tan1Mask │ │ │ │ -0001b580: 2c20 7461 6e32 4d61 736b 293b 3c2f 6469 , tan2Mask);.
650 │ │ │ │ -0001b5e0: 3c2f 7370 616e 3e20 2020 207d 3c2f 6469 }.
651 │ │ │ │ -0001b640: 3c2f 7370 616e 3e7d 3c2f 6469 763e 0a3c }
.< │ │ │ │ -0001b650: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ -0001b6a0: 3635 323c 2f73 7061 6e3e 203c 2f64 6976 652
.
653< │ │ │ │ -0001b700: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ -0001b720: 3c61 2069 643d 226c 3030 3635 3422 206e 654} // end │ │ │ │ -0001b780: 206e 616d 6573 7061 6365 2073 6463 3c2f namespace sdc
.
< │ │ │ │ -0001b7d0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ -0001b7e0: 6e6f 223e 2020 3635 353c 2f73 7061 6e3e no"> 655 │ │ │ │ -0001b7f0: 203c 2f64 6976 3e0a 3c64 6976 2063 6c61
.
│ │ │ │ -0001b840: 2020 3635 363c 2f73 7061 6e3e 7d20 3c73 656} // end names │ │ │ │ -0001b870: 7061 6365 204f 5045 4e53 5542 4449 565f pace OPENSUBDIV_ │ │ │ │ -0001b880: 5645 5253 494f 4e3c 2f73 7061 6e3e 3c2f VERSION.
6 │ │ │ │ -0001b8e0: 3537 3c2f 7370 616e 3e3c 7370 616e 2063 57u │ │ │ │ -0001b900: 7369 6e67 206e 616d 6573 7061 6365 203c sing namespace < │ │ │ │ -0001b910: 2f73 7061 6e3e 4f50 454e 5355 4244 4956 /span>OPENSUBDIV │ │ │ │ -0001b920: 5f56 4552 5349 4f4e 3b3c 2f64 6976 3e0a _VERSION;
. │ │ │ │ -0001b930: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
< │ │ │ │ -0001b960: 2f61 3e3c 7370 616e 2063 6c61 7373 3d22 /a> 658} // e │ │ │ │ -0001b9a0: 6e64 206e 616d 6573 7061 6365 204f 7065 nd namespace Ope │ │ │ │ -0001b9b0: 6e53 7562 6469 763c 2f73 7061 6e3e 3c2f nSubdiv.
6 │ │ │ │ -0001ba10: 3539 3c2f 7370 616e 3e20 3c2f 6469 763e 59
│ │ │ │ -0001ba20: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ -0001ba50: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 660 │ │ │ │ -0001ba90: 2365 6e64 6966 203c 2f73 7061 6e3e 3c73 #endif /* OPENSUBDI │ │ │ │ -0001bac0: 5633 5f53 4443 5f53 4348 454d 455f 4820 V3_SDC_SCHEME_H │ │ │ │ -0001bad0: 2a2f 3c2f 7370 616e 3e3c 7370 616e 2063 */
.
E │ │ │ │ -0001bcc0: 6e75 6d65 7261 7465 6420 7479 7065 2066 numerated type f │ │ │ │ -0001bcd0: 6f72 2061 6c6c 2066 6163 6520 7370 6c69 or all face spli │ │ │ │ -0001bce0: 7474 696e 6720 7363 6865 6d65 732e 3c2f tting schemes.
Defini │ │ │ │ -0001bd10: 7469 6f6e 3c2f 623e 203c 6120 6872 6566 tion typ │ │ │ │ -0001bd40: 6573 2e68 3a34 373c 2f61 3e3c 2f64 6976 es.h:47
.
< │ │ │ │ -0001bd90: 6120 6872 6566 3d22 6130 3133 3333 2e68 a href="a01333.h │ │ │ │ -0001bda0: 746d 6c22 3e4f 7065 6e53 7562 6469 763a tml">OpenSubdiv: │ │ │ │ -0001bdb0: 3a4f 5045 4e53 5542 4449 565f 5645 5253 :OPENSUBDIV_VERS │ │ │ │ -0001bdc0: 494f 4e3a 3a53 6463 3a3a 4372 6561 7365 ION::Sdc::Crease │ │ │ │ -0001bdd0: 3c2f 613e 3c2f 6469 763e 3c64 6976 2063
Typ │ │ │ │ -0001bdf0: 6573 2c20 636f 6e73 7461 6e74 7320 616e es, constants an │ │ │ │ -0001be00: 6420 7574 696c 6974 6965 7320 7265 6c61 d utilities rela │ │ │ │ -0001be10: 7465 6420 746f 2073 656d 692d 7368 6172 ted to semi-shar │ │ │ │ -0001be20: 7020 6372 6561 7369 6e67 20e2 8093 2077 p creasing ... w │ │ │ │ -0001be30: 686f 7365 2069 6d70 6c65 6d65 6e74 6174 hose implementat │ │ │ │ -0001be40: 696f 6e20 6973 2069 6e64 6570 656e 6465 ion is independe │ │ │ │ -0001be50: 6e74 206f 2e2e 2e3c 2f64 6976 3e3c 6469 nt o...
│ │ │ │ -0001be70: 3c62 3e44 6566 696e 6974 696f 6e3c 2f62 Definition crease.h:6 │ │ │ │ -0001beb0: 323c 2f61 3e3c 2f64 6976 3e3c 2f64 6976 2
.
< │ │ │ │ -0001bfc0: 623e 4465 6669 6e69 7469 6f6e 3c2f 623e b>Definition │ │ │ │ -0001bfd0: 203c 6120 6872 6566 3d22 6130 3037 3736 crease.h:82 │ │ │ │ -0001c000: 3c2f 613e 3c2f 6469 763e 3c2f 6469 763e
│ │ │ │ -0001c010: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
.
OpenSubdiv::OPE │ │ │ │ -0001c290: 4e53 5542 4449 565f 5645 5253 494f 4e3a NSUBDIV_VERSION: │ │ │ │ -0001c2a0: 3a53 6463 3a3a 4372 6561 7365 3a3a 5255 :Sdc::Crease::RU │ │ │ │ -0001c2b0: 4c45 5f53 4d4f 4f54 483c 2f61 3e3c 2f64 LE_SMOOTH
@ RULE_SM │ │ │ │ -0001c2e0: 4f4f 5448 3c2f 6469 763e 3c64 6976 2063 OOTH
│ │ │ │ -0001c300: 4465 6669 6e69 7469 6f6e 3c2f 623e 203c Definition < │ │ │ │ -0001c310: 6120 6872 6566 3d22 6130 3037 3736 5f73 a href="a00776_s │ │ │ │ -0001c320: 6f75 7263 652e 6874 6d6c 236c 3030 3038 ource.html#l0008 │ │ │ │ -0001c330: 3422 3e63 7265 6173 652e 683a 3834 3c2f 4">crease.h:84
.< │ │ │ │ -0001c350: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ -0001c360: 6964 3d22 6161 3031 3333 335f 6874 6d6c id="aa01333_html │ │ │ │ -0001c370: 5f61 3131 6663 6435 3165 6638 3631 3138 _a11fcd51ef86118 │ │ │ │ -0001c380: 6636 3565 3630 3363 3134 3734 3337 3761 f65e603c1474377a │ │ │ │ -0001c390: 3738 6139 3636 6661 3161 6538 6165 6238 78a966fa1ae8aeb8 │ │ │ │ -0001c3a0: 3538 3763 3439 3863 6636 6139 3263 6333 587c498cf6a92cc3 │ │ │ │ -0001c3b0: 3333 3522 3e3c 6469 7620 636c 6173 733d 335">. │ │ │ │ -0001c4f0: 3c64 6976 2063 6c61 7373 3d22 7474 6322 .
OpenSubdiv:: │ │ │ │ -0001c730: 4f50 454e 5355 4244 4956 5f56 4552 5349 OPENSUBDIV_VERSI │ │ │ │ -0001c740: 4f4e 3a3a 5364 633a 3a43 7265 6173 653a ON::Sdc::Crease: │ │ │ │ -0001c750: 3a47 6574 5368 6172 7045 6467 6550 6169 :GetSharpEdgePai │ │ │ │ -0001c760: 724f 6643 7265 6173 653c 2f61 3e3c 2f64 rOfCrease
void GetS │ │ │ │ -0001c790: 6861 7270 4564 6765 5061 6972 4f66 4372 harpEdgePairOfCr │ │ │ │ -0001c7a0: 6561 7365 2866 6c6f 6174 2063 6f6e 7374 ease(float const │ │ │ │ -0001c7b0: 202a 696e 6369 6465 6e74 4564 6765 5368 *incidentEdgeSh │ │ │ │ -0001c7c0: 6172 706e 6573 732c 2069 6e74 2069 6e63 arpness, int inc │ │ │ │ -0001c7d0: 6964 656e 7445 6467 6543 6f75 6e74 2c20 identEdgeCount, │ │ │ │ -0001c7e0: 696e 7420 7368 6172 7045 6467 6550 6169 int sharpEdgePai │ │ │ │ -0001c7f0: 725b 325d 2920 636f 6e73 743c 2f64 6976 r[2]) const
Definitio │ │ │ │ -0001c820: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n crease │ │ │ │ -0001c850: 2e68 3a32 3238 3c2f 613e 3c2f 6469 763e .h:228
│ │ │ │ -0001c860: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
..< │ │ │ │ -0001c9e0: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ -0001c9f0: 6964 3d22 6161 3031 3333 335f 6874 6d6c id="aa01333_html │ │ │ │ -0001ca00: 5f61 3564 6661 3638 3130 6635 3130 6661 _a5dfa6810f510fa │ │ │ │ -0001ca10: 6331 6563 3632 3166 6339 6536 6235 3330 c1ec621fc9e6b530 │ │ │ │ -0001ca20: 6334 223e 3c64 6976 2063 6c61 7373 3d22 c4"> │ │ │ │ -0001cab0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
bool IsUnifo │ │ │ │ -0001cad0: 726d 2829 2063 6f6e 7374 3c2f 6469 763e rm() const
│ │ │ │ -0001cae0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ -0001cb00: 3c2f 623e 203c 6120 6872 6566 3d22 6130 crease. │ │ │ │ -0001cb30: 683a 3935 3c2f 613e 3c2f 6469 763e 3c2f h:95
.
│ │ │ │ -0001cc40: 666c 6f61 7420 436f 6d70 7574 6546 7261 float ComputeFra │ │ │ │ -0001cc50: 6374 696f 6e61 6c57 6569 6768 7441 7456 ctionalWeightAtV │ │ │ │ -0001cc60: 6572 7465 7828 666c 6f61 7420 7665 7274 ertex(float vert │ │ │ │ -0001cc70: 6578 5368 6172 706e 6573 732c 2066 6c6f exSharpness, flo │ │ │ │ -0001cc80: 6174 2063 6869 6c64 5665 7274 6578 5368 at childVertexSh │ │ │ │ -0001cc90: 6172 706e 6573 732c 2069 6e74 2069 6e63 arpness, int inc │ │ │ │ -0001cca0: 6964 656e 7445 6467 6543 6f75 6e74 2c20 identEdgeCount, │ │ │ │ -0001ccb0: 666c 6f61 7420 636f 6e73 7420 2a69 6e63 float const *inc │ │ │ │ -0001ccc0: 6964 656e 7445 6467 6553 6861 7270 6e65 identEdgeSharpne │ │ │ │ -0001ccd0: 7373 2c20 666c 6f61 7420 636f 6e73 7420 ss, float const │ │ │ │ -0001cce0: 2a63 6869 6c64 4564 6765 7353 6861 7270 *childEdgesSharp │ │ │ │ -0001ccf0: 6e65 7373 2920 636f 6e73 743c 2f64 6976 ness) const
Transitional │ │ │ │ -0001cd20: 2077 6569 6768 7469 6e67 3a20 5768 656e weighting: When │ │ │ │ -0001cd30: 2074 6865 2072 756c 6573 2061 7070 6c69 the rules appli │ │ │ │ -0001cd40: 6361 626c 6520 746f 2061 2070 6172 656e cable to a paren │ │ │ │ -0001cd50: 7420 7665 7274 6578 2061 6e64 2069 7473 t vertex and its │ │ │ │ -0001cd60: 2063 6869 6c64 2064 6966 6665 722c 2e2e child differ,.. │ │ │ │ -0001cd70: 2e3c 2f64 6976 3e3c 2f64 6976 3e0a 3c64 .
.
All supporte │ │ │ │ -0001ce20: 6420 6f70 7469 6f6e 7320 6170 706c 7969 d options applyi │ │ │ │ -0001ce30: 6e67 2074 6f20 7375 6264 6976 6973 696f ng to subdivisio │ │ │ │ -0001ce40: 6e20 7363 6865 6d65 2e3c 2f64 6976 3e3c n scheme.
< │ │ │ │ -0001ce50: 6469 7620 636c 6173 733d 2274 7464 6566 div class="ttdef │ │ │ │ -0001ce60: 223e 3c62 3e44 6566 696e 6974 696f 6e3c ">Definition< │ │ │ │ -0001ce70: 2f62 3e20 3c61 2068 7265 663d 2261 3030 /b> options. │ │ │ │ -0001cea0: 683a 3531 3c2f 613e 3c2f 6469 763e 3c2f h:51
.
Scheme │ │ │ │ -0001cf50: 2069 7320 6120 636c 6173 7320 7465 6d70 is a class temp │ │ │ │ -0001cf60: 6c61 7465 2077 6869 6368 2070 726f 7669 late which provi │ │ │ │ -0001cf70: 6465 7320 616c 6c20 696d 706c 656d 656e des all implemen │ │ │ │ -0001cf80: 7461 7469 6f6e 2066 6f72 2074 6865 2073 tation for the s │ │ │ │ -0001cf90: 7562 6469 7669 7369 6f6e 2073 6368 656d ubdivision schem │ │ │ │ -0001cfa0: 6573 2073 7570 706f 7274 6564 2062 792e es supported by. │ │ │ │ -0001cfb0: 2e2e 3c2f 6469 763e 3c64 6976 2063 6c61 ..
De │ │ │ │ -0001cfd0: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:66 │ │ │ │ -0001d010: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.
│ │ │ │ -0001d110: 766f 6964 2061 7373 6967 6e53 6d6f 6f74 void assignSmoot │ │ │ │ -0001d120: 684d 6173 6b46 6f72 4564 6765 2845 4447 hMaskForEdge(EDG │ │ │ │ -0001d130: 4520 636f 6e73 7420 2661 6d70 3b65 6467 E const &edg │ │ │ │ -0001d140: 652c 204d 4153 4b20 2661 6d70 3b6d 6173 e, MASK &mas │ │ │ │ -0001d150: 6b29 2063 6f6e 7374 3c2f 6469 763e 3c2f k) const
.
OpenSubdiv │ │ │ │ -0001d200: 3a3a 4f50 454e 5355 4244 4956 5f56 4552 ::OPENSUBDIV_VER │ │ │ │ -0001d210: 5349 4f4e 3a3a 5364 633a 3a53 6368 656d SION::Sdc::Schem │ │ │ │ -0001d220: 653a 3a47 6574 546f 706f 6c6f 6769 6361 e::GetTopologica │ │ │ │ -0001d230: 6c53 706c 6974 5479 7065 3c2f 613e 3c2f lSplitType
static S │ │ │ │ -0001d260: 706c 6974 2047 6574 546f 706f 6c6f 6769 plit GetTopologi │ │ │ │ -0001d270: 6361 6c53 706c 6974 5479 7065 2829 3c2f calSplitType()
.
│ │ │ │ -0001d2d0: 3c64 6976 2063 6c61 7373 3d22 7474 6e61
│ │ │ │ -0001d380: 766f 6964 2061 7373 6967 6e43 7265 6173 void assignCreas │ │ │ │ -0001d390: 654d 6173 6b46 6f72 5665 7274 6578 2856 eMaskForVertex(V │ │ │ │ -0001d3a0: 4552 5445 5820 636f 6e73 7420 2661 6d70 ERTEX const & │ │ │ │ -0001d3b0: 3b65 6467 652c 204d 4153 4b20 2661 6d70 ;edge, MASK & │ │ │ │ -0001d3c0: 3b6d 6173 6b2c 2069 6e74 2063 6f6e 7374 ;mask, int const │ │ │ │ -0001d3d0: 2063 7265 6173 6545 6e64 735b 325d 2920 creaseEnds[2]) │ │ │ │ -0001d3e0: 636f 6e73 743c 2f64 6976 3e3c 2f64 6976 const
.
void Comput │ │ │ │ -0001d4f0: 6556 6572 7465 7856 6572 7465 784d 6173 eVertexVertexMas │ │ │ │ -0001d500: 6b28 5645 5254 4558 2063 6f6e 7374 2026 k(VERTEX const & │ │ │ │ -0001d510: 616d 703b 7665 7274 6578 4e65 6967 6862 amp;vertexNeighb │ │ │ │ -0001d520: 6f72 686f 6f64 2c20 4d41 534b 2026 616d orhood, MASK &am │ │ │ │ -0001d530: 703b 7665 7274 6578 5665 7274 6578 4d61 p;vertexVertexMa │ │ │ │ -0001d540: 736b 2c20 4372 6561 7365 3a3a 5275 6c65 sk, Crease::Rule │ │ │ │ -0001d550: 2070 6172 656e 7452 756c 653d 4372 6561 parentRule=Crea │ │ │ │ -0001d560: 7365 3a3a 5255 4c45 5f55 4e4b 4e4f 574e se::RULE_UNKNOWN │ │ │ │ -0001d570: 2c20 4372 6561 7365 3a3a 5275 6c65 2063 , Crease::Rule c │ │ │ │ -0001d580: 6869 6c64 5275 6c65 3d43 7265 6173 653a hildRule=Crease: │ │ │ │ -0001d590: 3a52 554c 455f 554e 4b4e 4f57 4e29 2063 :RULE_UNKNOWN) c │ │ │ │ -0001d5a0: 6f6e 7374 3c2f 6469 763e 3c64 6976 2063 onst
Ver │ │ │ │ -0001d5c0: 7465 782d 7665 7274 6578 206d 6173 6b73 tex-vertex masks │ │ │ │ -0001d5d0: 2049 6620 6b6e 6f77 6e2c 2061 2073 696e If known, a sin │ │ │ │ -0001d5e0: 676c 6520 5275 6c65 206f 7220 7061 6972 gle Rule or pair │ │ │ │ -0001d5f0: 206f 6620 5275 6c65 7320 6361 6e20 6265 of Rules can be │ │ │ │ -0001d600: 2073 7065 6369 6669 6564 2028 696e 6469 specified (indi │ │ │ │ -0001d610: 6361 7469 6e67 2061 2063 7265 6173 6520 cating a crease │ │ │ │ -0001d620: 7472 2e2e 2e3c 2f64 6976 3e3c 6469 7620 tr...
Definition │ │ │ │ -0001d650: 3c61 2068 7265 663d 2261 3030 3737 335f scheme.h:512 │ │ │ │ -0001d680: 3c2f 613e 3c2f 6469 763e 3c2f 6469 763e
│ │ │ │ -0001d690: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
< │ │ │ │ -0001d770: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ -0001d780: 6922 3e76 6f69 6420 436f 6d70 7574 6556 i">void ComputeV │ │ │ │ -0001d790: 6572 7465 784c 696d 6974 4d61 736b 2856 ertexLimitMask(V │ │ │ │ -0001d7a0: 4552 5445 5820 636f 6e73 7420 2661 6d70 ERTEX const & │ │ │ │ -0001d7b0: 3b76 6572 7465 784e 6569 6768 626f 7268 ;vertexNeighborh │ │ │ │ -0001d7c0: 6f6f 642c 204d 4153 4b20 2661 6d70 3b70 ood, MASK &p │ │ │ │ -0001d7d0: 6f73 6974 696f 6e4d 6173 6b2c 2043 7265 ositionMask, Cre │ │ │ │ -0001d7e0: 6173 653a 3a52 756c 6520 7665 7274 6578 ase::Rule vertex │ │ │ │ -0001d7f0: 5275 6c65 2920 636f 6e73 743c 2f64 6976 Rule) const
Limit masks │ │ │ │ -0001d820: 666f 7220 7665 7274 6963 6573 20e2 8093 for vertices ... │ │ │ │ -0001d830: 2070 6f73 6974 696f 6e20 616e 6420 7461 position and ta │ │ │ │ -0001d840: 6e67 656e 7473 2054 6865 7365 2070 7265 ngents These pre │ │ │ │ -0001d850: 7375 6d65 2074 6861 7420 6120 7665 7274 sume that a vert │ │ │ │ -0001d860: 6578 2069 7320 7375 6974 6162 6c79 2069 ex is suitably i │ │ │ │ -0001d870: 736f 6c61 7465 6420 666f 722e 2e2e 3c2f solated for...
Defini │ │ │ │ -0001d8a0: 7469 6f6e 3c2f 623e 203c 6120 6872 6566 tion sch │ │ │ │ -0001d8d0: 656d 652e 683a 3630 373c 2f61 3e3c 2f64 eme.h:607
.< │ │ │ │ -0001d9d0: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ -0001d9e0: 6922 3e76 6f69 6420 6173 7369 676e 4372 i">void assignCr │ │ │ │ -0001d9f0: 6561 7365 4c69 6d69 7454 616e 6765 6e74 easeLimitTangent │ │ │ │ -0001da00: 4d61 736b 7328 5645 5254 4558 2063 6f6e Masks(VERTEX con │ │ │ │ -0001da10: 7374 2026 616d 703b 7665 7274 6578 2c20 st &vertex, │ │ │ │ -0001da20: 4d41 534b 2026 616d 703b 7461 6e31 2c20 MASK &tan1, │ │ │ │ -0001da30: 4d41 534b 2026 616d 703b 7461 6e32 2c20 MASK &tan2, │ │ │ │ -0001da40: 696e 7420 636f 6e73 7420 6372 6561 7365 int const crease │ │ │ │ -0001da50: 456e 6473 5b32 5d29 2063 6f6e 7374 3c2f Ends[2]) const
.
│ │ │ │ -0001dab0: 3c64 6976 2063 6c61 7373 3d22 7474 6e61
Open │ │ │ │ -0001db00: 5375 6264 6976 3a3a 4f50 454e 5355 4244 Subdiv::OPENSUBD │ │ │ │ -0001db10: 4956 5f56 4552 5349 4f4e 3a3a 5364 633a IV_VERSION::Sdc: │ │ │ │ -0001db20: 3a53 6368 656d 653a 3a47 6574 5265 6775 :Scheme::GetRegu │ │ │ │ -0001db30: 6c61 7246 6163 6553 697a 653c 2f61 3e3c larFaceSize< │ │ │ │ -0001db40: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
static │ │ │ │ -0001db60: 696e 7420 4765 7452 6567 756c 6172 4661 int GetRegularFa │ │ │ │ -0001db70: 6365 5369 7a65 2829 3c2f 6469 763e 3c2f ceSize()
.
OpenSubdiv │ │ │ │ -0001dc20: 3a3a 4f50 454e 5355 4244 4956 5f56 4552 ::OPENSUBDIV_VER │ │ │ │ -0001dc30: 5349 4f4e 3a3a 5364 633a 3a53 6368 656d SION::Sdc::Schem │ │ │ │ -0001dc40: 653a 3a61 7373 6967 6e43 7265 6173 654d e::assignCreaseM │ │ │ │ -0001dc50: 6173 6b46 6f72 4564 6765 3c2f 613e 3c2f askForEdge
void ass │ │ │ │ -0001dc80: 6967 6e43 7265 6173 654d 6173 6b46 6f72 ignCreaseMaskFor │ │ │ │ -0001dc90: 4564 6765 2845 4447 4520 636f 6e73 7420 Edge(EDGE const │ │ │ │ -0001dca0: 2661 6d70 3b65 6467 652c 204d 4153 4b20 &edge, MASK │ │ │ │ -0001dcb0: 2661 6d70 3b6d 6173 6b29 2063 6f6e 7374 &mask) const │ │ │ │ -0001dcc0: 3c2f 6469 763e 3c64 6976 2063 6c61 7373
Defi │ │ │ │ -0001dce0: 6e69 7469 6f6e 3c2f 623e 203c 6120 6872 nition s │ │ │ │ -0001dd10: 6368 656d 652e 683a 3331 373c 2f61 3e3c cheme.h:317< │ │ │ │ -0001dd20: 2f64 6976 3e3c 2f64 6976 3e0a 3c64 6976 /div>
.
voi │ │ │ │ -0001de20: 6420 436f 6d70 7574 6545 6467 6556 6572 d ComputeEdgeVer │ │ │ │ -0001de30: 7465 784d 6173 6b28 4544 4745 2063 6f6e texMask(EDGE con │ │ │ │ -0001de40: 7374 2026 616d 703b 6564 6765 4e65 6967 st &edgeNeig │ │ │ │ -0001de50: 6862 6f72 686f 6f64 2c20 4d41 534b 2026 hborhood, MASK & │ │ │ │ -0001de60: 616d 703b 6564 6765 5665 7274 6578 4d61 amp;edgeVertexMa │ │ │ │ -0001de70: 736b 2c20 4372 6561 7365 3a3a 5275 6c65 sk, Crease::Rule │ │ │ │ -0001de80: 2070 6172 656e 7452 756c 653d 4372 6561 parentRule=Crea │ │ │ │ -0001de90: 7365 3a3a 5255 4c45 5f55 4e4b 4e4f 574e se::RULE_UNKNOWN │ │ │ │ -0001dea0: 2c20 4372 6561 7365 3a3a 5275 6c65 2063 , Crease::Rule c │ │ │ │ -0001deb0: 6869 6c64 5275 6c65 3d43 7265 6173 653a hildRule=Crease: │ │ │ │ -0001dec0: 3a52 554c 455f 554e 4b4e 4f57 4e29 2063 :RULE_UNKNOWN) c │ │ │ │ -0001ded0: 6f6e 7374 3c2f 6469 763e 3c64 6976 2063 onst
│ │ │ │ -0001dfc0: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
Definitio │ │ │ │ -0001e0d0: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n scheme │ │ │ │ -0001e100: 2e68 3a37 303c 2f61 3e3c 2f64 6976 3e3c .h:70
< │ │ │ │ -0001e110: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
< │ │ │ │ -0001e170: 6120 6872 6566 3d22 6130 3133 3431 2e68 a href="a01341.h │ │ │ │ -0001e180: 746d 6c23 6137 3336 6331 3039 3434 6362 tml#a736c10944cb │ │ │ │ -0001e190: 3932 3162 3333 3466 6264 3862 3831 3836 921b334fbd8b8186 │ │ │ │ -0001e1a0: 3664 3539 6622 3e4f 7065 6e53 7562 6469 6d59f">OpenSubdi │ │ │ │ -0001e1b0: 763a 3a4f 5045 4e53 5542 4449 565f 5645 v::OPENSUBDIV_VE │ │ │ │ -0001e1c0: 5253 494f 4e3a 3a53 6463 3a3a 5363 6865 RSION::Sdc::Sche │ │ │ │ -0001e1d0: 6d65 3a3a 6173 7369 676e 536d 6f6f 7468 me::assignSmooth │ │ │ │ -0001e1e0: 4c69 6d69 744d 6173 6b3c 2f61 3e3c 2f64 LimitMask
void assi │ │ │ │ -0001e210: 676e 536d 6f6f 7468 4c69 6d69 744d 6173 gnSmoothLimitMas │ │ │ │ -0001e220: 6b28 5645 5254 4558 2063 6f6e 7374 2026 k(VERTEX const & │ │ │ │ -0001e230: 616d 703b 7665 7274 6578 2c20 4d41 534b amp;vertex, MASK │ │ │ │ -0001e240: 2026 616d 703b 706f 7329 2063 6f6e 7374 &pos) const │ │ │ │ -0001e250: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.static int GetL │ │ │ │ -0001e360: 6f63 616c 4e65 6967 6862 6f72 686f 6f64 ocalNeighborhood │ │ │ │ -0001e370: 5369 7a65 2829 3c2f 6469 763e 3c2f 6469 Size()
.
OpenSubdiv:: │ │ │ │ -0001e420: 4f50 454e 5355 4244 4956 5f56 4552 5349 OPENSUBDIV_VERSI │ │ │ │ -0001e430: 4f4e 3a3a 5364 633a 3a53 6368 656d 653a ON::Sdc::Scheme: │ │ │ │ -0001e440: 3a61 7373 6967 6e43 6f72 6e65 724d 6173 :assignCornerMas │ │ │ │ -0001e450: 6b46 6f72 5665 7274 6578 3c2f 613e 3c2f kForVertex
void ass │ │ │ │ -0001e480: 6967 6e43 6f72 6e65 724d 6173 6b46 6f72 ignCornerMaskFor │ │ │ │ -0001e490: 5665 7274 6578 2856 4552 5445 5820 636f Vertex(VERTEX co │ │ │ │ -0001e4a0: 6e73 7420 2661 6d70 3b65 6467 652c 204d nst &edge, M │ │ │ │ -0001e4b0: 4153 4b20 2661 6d70 3b6d 6173 6b29 2063 ASK &mask) c │ │ │ │ -0001e4c0: 6f6e 7374 3c2f 6469 763e 3c64 6976 2063 onst
│ │ │ │ -0001e4e0: 4465 6669 6e69 7469 6f6e 3c2f 623e 203c Definition < │ │ │ │ -0001e4f0: 6120 6872 6566 3d22 6130 3037 3733 5f73 a href="a00773_s │ │ │ │ -0001e500: 6f75 7263 652e 6874 6d6c 236c 3030 3333 ource.html#l0033 │ │ │ │ -0001e510: 3122 3e73 6368 656d 652e 683a 3333 313c 1">scheme.h:331< │ │ │ │ -0001e520: 2f61 3e3c 2f64 6976 3e3c 2f64 6976 3e0a /a>
. │ │ │ │ -0001e530: 3c64 6976 2063 6c61 7373 3d22 7474 6322
void assignCrea │ │ │ │ -0001e630: 7365 4c69 6d69 744d 6173 6b28 5645 5254 seLimitMask(VERT │ │ │ │ -0001e640: 4558 2063 6f6e 7374 2026 616d 703b 7665 EX const &ve │ │ │ │ -0001e650: 7274 6578 2c20 4d41 534b 2026 616d 703b rtex, MASK & │ │ │ │ -0001e660: 706f 732c 2069 6e74 2063 6f6e 7374 2063 pos, int const c │ │ │ │ -0001e670: 7265 6173 6545 6e64 735b 325d 2920 636f reaseEnds[2]) co │ │ │ │ -0001e680: 6e73 743c 2f64 6976 3e3c 2f64 6976 3e0a nst
. │ │ │ │ -0001e690: 3c64 6976 2063 6c61 7373 3d22 7474 6322
void assign │ │ │ │ -0001e790: 536d 6f6f 7468 4d61 736b 466f 7256 6572 SmoothMaskForVer │ │ │ │ -0001e7a0: 7465 7828 5645 5254 4558 2063 6f6e 7374 tex(VERTEX const │ │ │ │ -0001e7b0: 2026 616d 703b 6564 6765 2c20 4d41 534b &edge, MASK │ │ │ │ -0001e7c0: 2026 616d 703b 6d61 736b 2920 636f 6e73 &mask) cons │ │ │ │ -0001e7d0: 743c 2f64 6976 3e3c 2f64 6976 3e0a 3c64 t
.static int GetR │ │ │ │ -0001e8e0: 6567 756c 6172 5665 7274 6578 5661 6c65 egularVertexVale │ │ │ │ -0001e8f0: 6e63 6528 293c 2f64 6976 3e3c 2f64 6976 nce()
.
OpenSubdiv::O │ │ │ │ -0001e9a0: 5045 4e53 5542 4449 565f 5645 5253 494f PENSUBDIV_VERSIO │ │ │ │ -0001e9b0: 4e3a 3a53 6463 3a3a 5363 6865 6d65 3a3a N::Sdc::Scheme:: │ │ │ │ -0001e9c0: 4765 744f 7074 696f 6e73 3c2f 613e 3c2f GetOptions
Options │ │ │ │ -0001e9f0: 4765 744f 7074 696f 6e73 2829 2063 6f6e GetOptions() con │ │ │ │ -0001ea00: 7374 3c2f 6469 763e 3c64 6976 2063 6c61 st
De │ │ │ │ -0001ea20: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:74 │ │ │ │ -0001ea60: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.
Op │ │ │ │ -0001eb00: 656e 5375 6264 6976 3a3a 4f50 454e 5355 enSubdiv::OPENSU │ │ │ │ -0001eb10: 4244 4956 5f56 4552 5349 4f4e 3a3a 5364 BDIV_VERSION::Sd │ │ │ │ -0001eb20: 633a 3a53 6368 656d 653a 3a61 7373 6967 c::Scheme::assig │ │ │ │ -0001eb30: 6e53 6d6f 6f74 684c 696d 6974 5461 6e67 nSmoothLimitTang │ │ │ │ -0001eb40: 656e 744d 6173 6b73 3c2f 613e 3c2f 6469 entMasks
void assig │ │ │ │ -0001eb70: 6e53 6d6f 6f74 684c 696d 6974 5461 6e67 nSmoothLimitTang │ │ │ │ -0001eb80: 656e 744d 6173 6b73 2856 4552 5445 5820 entMasks(VERTEX │ │ │ │ -0001eb90: 636f 6e73 7420 2661 6d70 3b76 6572 7465 const &verte │ │ │ │ -0001eba0: 782c 204d 4153 4b20 2661 6d70 3b74 616e x, MASK &tan │ │ │ │ -0001ebb0: 312c 204d 4153 4b20 2661 6d70 3b74 616e 1, MASK &tan │ │ │ │ -0001ebc0: 3229 2063 6f6e 7374 3c2f 6469 763e 3c2f 2) const
.
OpenSubdiv │ │ │ │ -0001ec70: 3a3a 4f50 454e 5355 4244 4956 5f56 4552 ::OPENSUBDIV_VER │ │ │ │ -0001ec80: 5349 4f4e 3a3a 5364 633a 3a53 6368 656d SION::Sdc::Schem │ │ │ │ -0001ec90: 653a 3a61 7373 6967 6e43 6f72 6e65 724c e::assignCornerL │ │ │ │ -0001eca0: 696d 6974 4d61 736b 3c2f 613e 3c2f 6469 imitMask
void assig │ │ │ │ -0001ecd0: 6e43 6f72 6e65 724c 696d 6974 4d61 736b nCornerLimitMask │ │ │ │ -0001ece0: 2856 4552 5445 5820 636f 6e73 7420 2661 (VERTEX const &a │ │ │ │ -0001ecf0: 6d70 3b76 6572 7465 782c 204d 4153 4b20 mp;vertex, MASK │ │ │ │ -0001ed00: 2661 6d70 3b70 6f73 2920 636f 6e73 743c &pos) const< │ │ │ │ -0001ed10: 2f64 6976 3e3c 2f64 6976 3e0a 3c64 6976 /div>
.
Sc │ │ │ │ -0001ee00: 6865 6d65 284f 7074 696f 6e73 2063 6f6e heme(Options con │ │ │ │ -0001ee10: 7374 2026 616d 703b 6f70 7469 6f6e 7329 st &options) │ │ │ │ -0001ee20: 3c2f 6469 763e 3c64 6976 2063 6c61 7373
Defi │ │ │ │ -0001ee40: 6e69 7469 6f6e 3c2f 623e 203c 6120 6872 nition s │ │ │ │ -0001ee70: 6368 656d 652e 683a 3732 3c2f 613e 3c2f cheme.h:72
.
│ │ │ │ -0001f090: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
void a │ │ │ │ -0001f190: 7373 6967 6e43 6f72 6e65 724c 696d 6974 ssignCornerLimit │ │ │ │ -0001f1a0: 5461 6e67 656e 744d 6173 6b73 2856 4552 TangentMasks(VER │ │ │ │ -0001f1b0: 5445 5820 636f 6e73 7420 2661 6d70 3b76 TEX const &v │ │ │ │ -0001f1c0: 6572 7465 782c 204d 4153 4b20 2661 6d70 ertex, MASK & │ │ │ │ -0001f1d0: 3b74 616e 312c 204d 4153 4b20 2661 6d70 ;tan1, MASK & │ │ │ │ -0001f1e0: 3b74 616e 3229 2063 6f6e 7374 3c2f 6469 ;tan2) const
.
v │ │ │ │ -0001f2e0: 6f69 6420 5365 744f 7074 696f 6e73 2863 oid SetOptions(c │ │ │ │ -0001f2f0: 6f6e 7374 204f 7074 696f 6e73 2026 616d onst Options &am │ │ │ │ -0001f300: 703b 6e65 774f 7074 696f 6e73 293c 2f64 p;newOptions)
Definit │ │ │ │ -0001f330: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion sche │ │ │ │ -0001f360: 6d65 2e68 3a37 353c 2f61 3e3c 2f64 6976 me.h:75
.
< │ │ │ │ -0001f3b0: 6120 6872 6566 3d22 6130 3133 3435 2e68 a href="a01345.h │ │ │ │ -0001f3c0: 746d 6c22 3e4f 7065 6e53 7562 6469 763a tml">OpenSubdiv: │ │ │ │ -0001f3d0: 3a4f 5045 4e53 5542 4449 565f 5645 5253 :OPENSUBDIV_VERS │ │ │ │ -0001f3e0: 494f 4e3a 3a53 6463 3a3a 5363 6865 6d65 ION::Sdc::Scheme │ │ │ │ -0001f3f0: 3a3a 4c6f 6361 6c4d 6173 6b3c 2f61 3e3c ::LocalMask< │ │ │ │ -0001f400: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
Defin │ │ │ │ -0001f420: 6974 696f 6e3c 2f62 3e20 3c61 2068 7265 ition sc │ │ │ │ -0001f450: 6865 6d65 2e68 3a32 3039 3c2f 613e 3c2f heme.h:209
.
│ │ │ │ -0001f4b0: 3c64 6976 2063 6c61 7373 3d22 7474 6e61 │ │ │ │ -0001f5d0: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
│ │ │ │ -0001f6c0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
bool AreFace │ │ │ │ -0001f6e0: 5765 6967 6874 7346 6f72 4661 6365 4365 WeightsForFaceCe │ │ │ │ -0001f6f0: 6e74 6572 7328 2920 636f 6e73 743c 2f64 nters() const
Definit │ │ │ │ -0001f720: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion sche │ │ │ │ -0001f750: 6d65 2e68 3a32 3339 3c2f 613e 3c2f 6469 me.h:239
.void SetNumEdge │ │ │ │ -0001f870: 5765 6967 6874 7328 696e 7420 636f 756e Weights(int coun │ │ │ │ -0001f880: 7429 3c2f 6469 763e 3c64 6976 2063 6c61 t)
De │ │ │ │ -0001f8a0: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:228
.
W │ │ │ │ -0001f9e0: 6569 6768 7420 636f 6e73 7420 2661 6d70 eight const & │ │ │ │ -0001f9f0: 3b20 4564 6765 5765 6967 6874 2869 6e74 ; EdgeWeight(int │ │ │ │ -0001fa00: 2069 6e64 6578 2920 636f 6e73 743c 2f64 index) const
Definit │ │ │ │ -0001fa30: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion sche │ │ │ │ -0001fa60: 6d65 2e68 3a32 3332 3c2f 613e 3c2f 6469 me.h:232
.
Weight │ │ │ │ -0001fb70: 2026 616d 703b 2045 6467 6557 6569 6768 & EdgeWeigh │ │ │ │ -0001fb80: 7428 696e 7420 696e 6465 7829 3c2f 6469 t(int index)
Definiti │ │ │ │ -0001fbb0: 6f6e 3c2f 623e 203c 6120 6872 6566 3d22 on schem │ │ │ │ -0001fbe0: 652e 683a 3233 363c 2f61 3e3c 2f64 6976 e.h:236
.
OpenSub │ │ │ │ -0001fc90: 6469 763a 3a4f 5045 4e53 5542 4449 565f div::OPENSUBDIV_ │ │ │ │ -0001fca0: 5645 5253 494f 4e3a 3a53 6463 3a3a 5363 VERSION::Sdc::Sc │ │ │ │ -0001fcb0: 6865 6d65 3a3a 4c6f 6361 6c4d 6173 6b3a heme::LocalMask: │ │ │ │ -0001fcc0: 3a43 6f6d 6269 6e65 5665 7274 6578 5665 :CombineVertexVe │ │ │ │ -0001fcd0: 7274 6578 4d61 736b 733c 2f61 3e3c 2f64 rtexMasks
void Comb │ │ │ │ -0001fd00: 696e 6556 6572 7465 7856 6572 7465 784d ineVertexVertexM │ │ │ │ -0001fd10: 6173 6b73 2857 6569 6768 7420 7468 6973 asks(Weight this │ │ │ │ -0001fd20: 436f 6566 662c 2057 6569 6768 7420 6473 Coeff, Weight ds │ │ │ │ -0001fd30: 7443 6f65 6666 2c20 5553 4552 5f4d 4153 tCoeff, USER_MAS │ │ │ │ -0001fd40: 4b20 2661 6d70 3b64 7374 2920 636f 6e73 K &dst) cons │ │ │ │ -0001fd50: 743c 2f64 6976 3e3c 6469 7620 636c 6173 t
Def │ │ │ │ -0001fd70: 696e 6974 696f 6e3c 2f62 3e20 3c61 2068 inition │ │ │ │ -0001fda0: 7363 6865 6d65 2e68 3a32 3439 3c2f 613e scheme.h:249 │ │ │ │ -0001fdb0: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
..
void S │ │ │ │ -00020040: 6574 4e75 6d46 6163 6557 6569 6768 7473 etNumFaceWeights │ │ │ │ -00020050: 2869 6e74 2063 6f75 6e74 293c 2f64 6976 (int count)
Definitio │ │ │ │ -00020080: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n scheme │ │ │ │ -000200b0: 2e68 3a32 3239 3c2f 613e 3c2f 6469 763e .h:229
│ │ │ │ -000200c0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ -00020120: 3c61 2068 7265 663d 2261 3031 3334 352e OpenSubd │ │ │ │ -00020160: 6976 3a3a 4f50 454e 5355 4244 4956 5f56 iv::OPENSUBDIV_V │ │ │ │ -00020170: 4552 5349 4f4e 3a3a 5364 633a 3a53 6368 ERSION::Sdc::Sch │ │ │ │ -00020180: 656d 653a 3a4c 6f63 616c 4d61 736b 3a3a eme::LocalMask:: │ │ │ │ -00020190: 4661 6365 5765 6967 6874 3c2f 613e 3c2f FaceWeight
Weight c │ │ │ │ -000201c0: 6f6e 7374 2026 616d 703b 2046 6163 6557 onst & FaceW │ │ │ │ -000201d0: 6569 6768 7428 696e 7420 696e 6465 7829 eight(int index) │ │ │ │ -000201e0: 2063 6f6e 7374 3c2f 6469 763e 3c64 6976 const
< │ │ │ │ -00020200: 623e 4465 6669 6e69 7469 6f6e 3c2f 623e b>Definition │ │ │ │ -00020210: 203c 6120 6872 6566 3d22 6130 3037 3733 scheme.h:23 │ │ │ │ -00020240: 333c 2f61 3e3c 2f64 6976 3e3c 2f64 6976 3
.
int Ge │ │ │ │ -00020350: 744e 756d 4564 6765 5765 6967 6874 7328 tNumEdgeWeights( │ │ │ │ -00020360: 2920 636f 6e73 743c 2f64 6976 3e3c 6469 ) const
│ │ │ │ -00020380: 3c62 3e44 6566 696e 6974 696f 6e3c 2f62 Definition scheme.h:2 │ │ │ │ -000203c0: 3234 3c2f 613e 3c2f 6469 763e 3c2f 6469 24
.
OpenSubdiv:: │ │ │ │ -00020470: 4f50 454e 5355 4244 4956 5f56 4552 5349 OPENSUBDIV_VERSI │ │ │ │ -00020480: 4f4e 3a3a 5364 633a 3a53 6368 656d 653a ON::Sdc::Scheme: │ │ │ │ -00020490: 3a4c 6f63 616c 4d61 736b 3a3a 5665 7274 :LocalMask::Vert │ │ │ │ -000204a0: 6578 5765 6967 6874 3c2f 613e 3c2f 6469 exWeight
Weight &am │ │ │ │ -000204d0: 703b 2056 6572 7465 7857 6569 6768 7428 p; VertexWeight( │ │ │ │ -000204e0: 696e 7420 696e 6465 7829 3c2f 6469 763e int index)
│ │ │ │ -000204f0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ -00020510: 3c2f 623e 203c 6120 6872 6566 3d22 6130 scheme. │ │ │ │ -00020540: 683a 3233 353c 2f61 3e3c 2f64 6976 3e3c h:235
< │ │ │ │ -00020550: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
< │ │ │ │ -000205b0: 6120 6872 6566 3d22 6130 3133 3435 2e68 a href="a01345.h │ │ │ │ -000205c0: 746d 6c23 6139 3366 3537 6535 3333 3733 tml#a93f57e53373 │ │ │ │ -000205d0: 3931 6332 3064 3436 6465 6664 6233 6161 91c20d46defdb3aa │ │ │ │ -000205e0: 3263 3166 6522 3e4f 7065 6e53 7562 6469 2c1fe">OpenSubdi │ │ │ │ -000205f0: 763a 3a4f 5045 4e53 5542 4449 565f 5645 v::OPENSUBDIV_VE │ │ │ │ -00020600: 5253 494f 4e3a 3a53 6463 3a3a 5363 6865 RSION::Sdc::Sche │ │ │ │ -00020610: 6d65 3a3a 4c6f 6361 6c4d 6173 6b3a 3a47 me::LocalMask::G │ │ │ │ -00020620: 6574 4e75 6d46 6163 6557 6569 6768 7473 etNumFaceWeights │ │ │ │ -00020630: 3c2f 613e 3c2f 6469 763e 3c64 6976 2063
in │ │ │ │ -00020650: 7420 4765 744e 756d 4661 6365 5765 6967 t GetNumFaceWeig │ │ │ │ -00020660: 6874 7328 2920 636f 6e73 743c 2f64 6976 hts() const
Definitio │ │ │ │ -00020690: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n scheme │ │ │ │ -000206c0: 2e68 3a32 3235 3c2f 613e 3c2f 6469 763e .h:225
│ │ │ │ -000206d0: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
void S │ │ │ │ -000207e0: 6574 4661 6365 5765 6967 6874 7346 6f72 etFaceWeightsFor │ │ │ │ -000207f0: 4661 6365 4365 6e74 6572 7328 626f 6f6c FaceCenters(bool │ │ │ │ -00020800: 206f 6e29 3c2f 6469 763e 3c64 6976 2063 on)
│ │ │ │ -00020820: 4465 6669 6e69 7469 6f6e 3c2f 623e 203c Definition < │ │ │ │ -00020830: 6120 6872 6566 3d22 6130 3037 3733 5f73 a href="a00773_s │ │ │ │ -00020840: 6f75 7263 652e 6874 6d6c 236c 3030 3234 ource.html#l0024 │ │ │ │ -00020850: 3022 3e73 6368 656d 652e 683a 3234 303c 0">scheme.h:240< │ │ │ │ -00020860: 2f61 3e3c 2f64 6976 3e3c 2f64 6976 3e0a /a>
. │ │ │ │ -00020870: 3c64 6976 2063 6c61 7373 3d22 7474 6322
void S │ │ │ │ -00020970: 6574 4e75 6d56 6572 7465 7857 6569 6768 etNumVertexWeigh │ │ │ │ -00020980: 7473 2869 6e74 2063 6f75 6e74 293c 2f64 ts(int count)
Definit │ │ │ │ -000209b0: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion sche │ │ │ │ -000209e0: 6d65 2e68 3a32 3237 3c2f 613e 3c2f 6469 me.h:227
.
OpenSu │ │ │ │ -00020a90: 6264 6976 3a3a 4f50 454e 5355 4244 4956 bdiv::OPENSUBDIV │ │ │ │ -00020aa0: 5f56 4552 5349 4f4e 3a3a 5364 633a 3a53 _VERSION::Sdc::S │ │ │ │ -00020ab0: 6368 656d 653a 3a4c 6f63 616c 4d61 736b cheme::LocalMask │ │ │ │ -00020ac0: 3a3a 4c6f 6361 6c4d 6173 6b3c 2f61 3e3c ::LocalMask< │ │ │ │ -00020ad0: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
LocalMa │ │ │ │ -00020af0: 736b 2857 6569 6768 7420 2a76 2c20 5765 sk(Weight *v, We │ │ │ │ -00020b00: 6967 6874 202a 652c 2057 6569 6768 7420 ight *e, Weight │ │ │ │ -00020b10: 2a66 293c 2f64 6976 3e3c 6469 7620 636c *f)
D │ │ │ │ -00020b30: 6566 696e 6974 696f 6e3c 2f62 3e20 3c61 efinition scheme.h:215
.< │ │ │ │ -00020b80: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ -00020b90: 6964 3d22 6161 3031 3334 355f 6874 6d6c id="aa01345_html │ │ │ │ -00020ba0: 5f61 6563 3563 3261 6266 6466 6264 6534 _aec5c2abfdfbde4 │ │ │ │ -00020bb0: 6464 3933 3463 3036 3136 3235 3939 3437 dd934c0616259947 │ │ │ │ -00020bc0: 3931 223e 3c64 6976 2063 6c61 7373 3d22 91">Weight const & │ │ │ │ -00020c80: 616d 703b 2056 6572 7465 7857 6569 6768 amp; VertexWeigh │ │ │ │ -00020c90: 7428 696e 7420 696e 6465 7829 2063 6f6e t(int index) con │ │ │ │ -00020ca0: 7374 3c2f 6469 763e 3c64 6976 2063 6c61 st
De │ │ │ │ -00020cc0: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition scheme.h:231
.
W │ │ │ │ -00020e00: 6569 6768 7420 2661 6d70 3b20 4661 6365 eight & Face │ │ │ │ -00020e10: 5765 6967 6874 2869 6e74 2069 6e64 6578 Weight(int index │ │ │ │ -00020e20: 293c 2f64 6976 3e3c 6469 7620 636c 6173 )
Def │ │ │ │ -00020e40: 696e 6974 696f 6e3c 2f62 3e20 3c61 2068 inition │ │ │ │ -00020e70: 7363 6865 6d65 2e68 3a32 3337 3c2f 613e scheme.h:237 │ │ │ │ -00020e80: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.
~L │ │ │ │ -00020f80: 6f63 616c 4d61 736b 2829 3c2f 6469 763e ocalMask()
│ │ │ │ -00020f90: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ -00020fb0: 3c2f 623e 203c 6120 6872 6566 3d22 6130 scheme. │ │ │ │ -00020fe0: 683a 3231 363c 2f61 3e3c 2f64 6976 3e3c h:216
< │ │ │ │ -00020ff0: 2f64 6976 3e0a 3c2f 6469 763e 3c21 2d2d /div>.
.
. │ │ │ │ -00021040: 3c21 2d2d 2073 7461 7274 2066 6f6f 7465 .... │ │ │ │ +000023a0: 3333 3c2f 7370 616e 3e20 3c2f 6469 763e 33
│ │ │ │ +000023b0: 0a3c 6469 7620 636c 6173 733d 226c 696e ...
│ │ │ │ +000024c0: 2020 3531 3c2f 613e 3c2f 7370 616e 3e3c 51< │ │ │ │ +000024d0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +000024e0: 6f72 6422 3e63 6c61 7373 203c 2f73 7061 ord">class Op │ │ │ │ +00002520: 7469 6f6e 733c 2f61 3e20 7b3c 2f64 6976 tions {
.
52< │ │ │ │ +00002580: 2f73 7061 6e3e 3c73 7061 6e20 636c 6173 /span>publ │ │ │ │ +000025a0: 6963 3c2f 7370 616e 3e3a 3c2f 6469 763e ic:
│ │ │ │ +000025b0: 0a3c 6469 7620 636c 6173 733d 2266 6f6c .
.
│ │ │ │ +00002640: 3c61 2063 6c61 7373 3d22 6c69 6e65 2220 53 e │ │ │ │ +000026b0: 6e75 6d3c 2f73 7061 6e3e 203c 6120 636c num V │ │ │ │ +00002710: 7478 426f 756e 6461 7279 496e 7465 7270 txBoundaryInterp │ │ │ │ +00002720: 6f6c 6174 696f 6e3c 2f61 3e20 7b3c 2f64 olation {.
5 │ │ │ │ +00002780: 343c 2f73 7061 6e3e 2020 2020 2020 2020 4 │ │ │ │ +00002790: 3c61 2063 6c61 7373 3d22 636f 6465 2068 VTX_BOUNDARY_ │ │ │ │ +00002810: 4e4f 4e45 3c2f 613e 203d 2030 2c20 2020 NONE = 0, │ │ │ │ +00002820: 2020 2020 203c 2f64 6976 3e0a 3c64 6976
.
< │ │ │ │ +00002860: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00002870: 6e6f 223e 3c61 2063 6c61 7373 3d22 6c69 no"> 56< │ │ │ │ +000028e0: 2f61 3e3c 2f73 7061 6e3e 2020 2020 2020 /a> │ │ │ │ +000028f0: 2020 3c61 2063 6c61 7373 3d22 636f 6465 VTX_BOUNDAR │ │ │ │ +00002970: 595f 4544 4745 5f4f 4e4c 593c 2f61 3e2c Y_EDGE_ONLY, │ │ │ │ +00002980: 2020 2020 2020 203c 2f64 6976 3e0a 3c64
. │ │ │ │ +000029a0: 3c61 2069 643d 226c 3030 3035 3722 206e 57 VTX │ │ │ │ +00002a60: 5f42 4f55 4e44 4152 595f 4544 4745 5f41 _BOUNDARY_EDGE_A │ │ │ │ +00002a70: 4e44 5f43 4f52 4e45 523c 2f61 3e20 203c ND_CORNER < │ │ │ │ +00002a80: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
59 };
│ │ │ │ +00002b50: 0a3c 2f64 6976 3e0a 3c64 6976 2063 6c61 .
.
.< │ │ │ │ +00002ba0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00002bb0: 3e3c 6120 6964 3d22 6c30 3030 3630 2220 > 6 │ │ │ │ +00002c30: 303c 2f61 3e3c 2f73 7061 6e3e 2020 2020 0 │ │ │ │ +00002c40: 3c73 7061 6e20 636c 6173 733d 226b 6579 enum FVarLinear │ │ │ │ +00002cc0: 496e 7465 7270 6f6c 6174 696f 6e3c 2f61 Interpolation {
.
61 │ │ │ │ +00002da0: 3c61 2063 6c61 7373 3d22 636f 6465 2068 FVAR_LINEAR_N │ │ │ │ +00002e20: 4f4e 453c 2f61 3e20 3d20 302c 2020 2020 ONE = 0, │ │ │ │ +00002e30: 2020 2020 203c 2f64 6976 3e0a 3c64 6976
.
< │ │ │ │ +00002e70: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00002e80: 6e6f 223e 3c61 2063 6c61 7373 3d22 6c69 no"> 62< │ │ │ │ +00002ef0: 2f61 3e3c 2f73 7061 6e3e 2020 2020 2020 /a> │ │ │ │ +00002f00: 2020 3c61 2063 6c61 7373 3d22 636f 6465 FVAR_LINEAR │ │ │ │ +00002f80: 5f43 4f52 4e45 5253 5f4f 4e4c 593c 2f61 _CORNERS_ONLY,
. │ │ │ │ +00002fb0: 3c61 2069 643d 226c 3030 3036 3322 206e 6 │ │ │ │ +00003050: 333c 2f61 3e3c 2f73 7061 6e3e 2020 2020 3 │ │ │ │ +00003060: 2020 2020 3c61 2063 6c61 7373 3d22 636f FVAR_LINE │ │ │ │ +000030e0: 4152 5f43 4f52 4e45 5253 5f50 4c55 5331 AR_CORNERS_PLUS1 │ │ │ │ +000030f0: 3c2f 613e 2c20 2020 203c 2f64 6976 3e0a ,
. │ │ │ │ +00003100: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 .
│ │ │ │ +00003310: 2020 2036 353c 2f61 3e3c 2f73 7061 6e3e 65 │ │ │ │ +00003320: 2020 2020 2020 2020 3c61 2063 6c61 7373 FVAR_ │ │ │ │ +000033a0: 4c49 4e45 4152 5f42 4f55 4e44 4152 4945 LINEAR_BOUNDARIE │ │ │ │ +000033b0: 533c 2f61 3e2c 2020 2020 2020 203c 2f64 S, .
6 │ │ │ │ +00003410: 363c 2f73 7061 6e3e 2020 2020 2020 2020 6 │ │ │ │ +00003420: 3c61 2063 6c61 7373 3d22 636f 6465 2068 FVAR_LINEAR_A │ │ │ │ +000034a0: 4c4c 3c2f 613e 2020 2020 2020 2020 2020 LL │ │ │ │ +000034b0: 2020 2020 203c 2f64 6976 3e0a 3c64 6976
.
< │ │ │ │ +000034f0: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00003500: 6e6f 223e 3c61 2063 6c61 7373 3d22 6c69 no"> 67< │ │ │ │ +00003570: 2f61 3e3c 2f73 7061 6e3e 2020 2020 7d3b /a> }; │ │ │ │ +00003580: 3c2f 6469 763e 0a3c 2f64 6976 3e0a 3c64
.
..
68 enum │ │ │ │ +00003690: 3c2f 7370 616e 3e20 3c61 2063 6c61 7373 Crea │ │ │ │ +000036f0: 7369 6e67 4d65 7468 6f64 3c2f 613e 207b singMethod { │ │ │ │ +00003700: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
< │ │ │ │ +00003750: 6120 636c 6173 733d 226c 696e 6522 2068 a class="line" h │ │ │ │ +00003760: 7265 663d 2261 3031 3333 372e 6874 6d6c ref="a01337.html │ │ │ │ +00003770: 2361 3136 6563 3532 3264 6330 3339 3862 #a16ec522dc0398b │ │ │ │ +00003780: 6631 3433 3561 3931 3263 6436 3639 6666 f1435a912cd669ff │ │ │ │ +00003790: 6230 6131 3066 3239 3536 6462 3438 6432 b0a10f2956db48d2 │ │ │ │ +000037a0: 3937 3534 3234 6265 3265 3532 6562 6435 975424be2e52ebd5 │ │ │ │ +000037b0: 3434 6422 3e20 2020 3639 3c2f 613e 3c2f 44d"> 69 │ │ │ │ +00003840: 4352 4541 5345 5f55 4e49 464f 524d 3c2f CREASE_UNIFORM = 0, │ │ │ │ +00003860: 2020 3c2f 6469 763e 0a3c 6469 7620 636c
.
70 │ │ │ │ +000038c0: 2020 2020 203c 6120 636c 6173 733d 2263 CREASE_C │ │ │ │ +00003940: 4841 494b 494e 3c2f 613e 2020 2020 2020 HAIKIN │ │ │ │ +00003950: 2020 2020 2020 2020 2020 3c2f 6469 763e
│ │ │ │ +00003960: 0a3c 6469 7620 636c 6173 733d 226c 696e ..
.
.
72 │ │ │ │ +00003b10: 3c2f 7370 616e 3e20 2020 203c 7370 616e enum TriangleSubdivi │ │ │ │ +00003ba0: 7369 6f6e 3c2f 613e 207b 3c2f 6469 763e sion {
│ │ │ │ +00003bb0: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00003be0: 3c2f 613e 3c73 7061 6e20 636c 6173 733d │ │ │ │ +00003c60: 2020 3733 3c2f 613e 3c2f 7370 616e 3e20 73 │ │ │ │ +00003c70: 2020 2020 2020 203c 6120 636c 6173 733d TRI_SU │ │ │ │ +00003cf0: 425f 4341 544d 4152 4b3c 2f61 3e20 3d20 B_CATMARK = │ │ │ │ +00003d00: 302c 2020 2020 2020 2020 2020 3c2f 6469 0, .
74 │ │ │ │ +00003d60: 3c2f 7370 616e 3e20 2020 2020 2020 203c < │ │ │ │ +00003d70: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +00003d80: 5f65 6e75 6d76 616c 7565 2220 6872 6566 _enumvalue" href │ │ │ │ +00003d90: 3d22 6130 3133 3337 2e68 746d 6c23 6131 ="a01337.html#a1 │ │ │ │ +00003da0: 3066 6538 6332 6237 3865 3563 3539 3337 0fe8c2b78e5c5937 │ │ │ │ +00003db0: 3736 3134 3837 3661 3336 3263 3338 6261 7614876a362c38ba │ │ │ │ +00003dc0: 6632 3232 6561 6435 6661 3438 3735 6632 f222ead5fa4875f2 │ │ │ │ +00003dd0: 6561 3237 3934 6332 6437 3635 6138 3764 ea2794c2d765a87d │ │ │ │ +00003de0: 223e 5452 495f 5355 425f 534d 4f4f 5448 ">TRI_SUB_SMOOTH │ │ │ │ +00003df0: 3c2f 613e 2020 2020 2020 2020 2020 2020 │ │ │ │ +00003e00: 2020 2020 3c2f 6469 763e 0a3c 6469 7620
..< │ │ │ │ +00003ef0: 6120 6964 3d22 6c30 3030 3736 2220 6e61 a id="l00076" na │ │ │ │ +00003f00: 6d65 3d22 6c30 3030 3736 223e 3c2f 613e me="l00076"> │ │ │ │ +00003f10: 3c73 7061 6e20 636c 6173 733d 226c 696e 76
.
77public │ │ │ │ +00003fb0: 3a3c 2f64 6976 3e0a 3c64 6976 2063 6c61 :
.
│ │ │ │ +00004000: 2020 2037 383c 2f73 7061 6e3e 203c 2f64 78 .
.
79 │ │ │ │ +000040f0: 3c2f 7370 616e 3e20 2020 203c 6120 636c Opti │ │ │ │ +00004150: 6f6e 733c 2f61 3e28 2920 3a20 5f76 7478 ons() : _vtx │ │ │ │ +00004160: 426f 756e 6449 6e74 6572 7028 3c61 2063 BoundInterp(V │ │ │ │ +000041e0: 5458 5f42 4f55 4e44 4152 595f 4e4f 4e45 TX_BOUNDARY_NONE │ │ │ │ +000041f0: 3c2f 613e 292c 3c2f 6469 763e 0a3c 6469 ),
.< │ │ │ │ +00004210: 6120 6964 3d22 6c30 3030 3830 2220 6e61 a id="l00080" na │ │ │ │ +00004220: 6d65 3d22 6c30 3030 3830 223e 3c2f 613e me="l00080"> │ │ │ │ +00004230: 3c73 7061 6e20 636c 6173 733d 226c 696e 80 │ │ │ │ +00004260: 205f 6676 6172 4c69 6e49 6e74 6572 7028 _fvarLinInterp( │ │ │ │ +00004270: 3c61 2063 6c61 7373 3d22 636f 6465 2068 FVAR_LINEAR_A │ │ │ │ +000042f0: 4c4c 3c2f 613e 292c 3c2f 6469 763e 0a3c LL),
.< │ │ │ │ +00004300: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00004310: 3e3c 6120 6964 3d22 6c30 3030 3831 2220 > 81 │ │ │ │ +00004360: 2020 205f 6372 6561 7369 6e67 4d65 7468 _creasingMeth │ │ │ │ +00004370: 6f64 283c 6120 636c 6173 733d 2263 6f64 od(CREASE_UNI │ │ │ │ +000043f0: 464f 524d 3c2f 613e 292c 3c2f 6469 763e FORM),
│ │ │ │ +00004400: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00004430: 3c2f 613e 3c73 7061 6e20 636c 6173 733d 82 │ │ │ │ +00004460: 2020 2020 205f 7472 6961 6e67 6c65 5375 _triangleSu │ │ │ │ +00004470: 6228 3c61 2063 6c61 7373 3d22 636f 6465 b(TRI_SUB_CAT │ │ │ │ +000044f0: 4d41 524b 3c2f 613e 2920 7b20 7d3c 2f64 MARK) { }.
.
83 │ │ │ │ +00004560: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
│ │ │ │ +000045b0: 2020 3834 3c2f 7370 616e 3e20 2020 203c 84 < │ │ │ │ +000045c0: 7370 616e 2063 6c61 7373 3d22 636f 6d6d span class="comm │ │ │ │ +000045d0: 656e 7422 3e2f 2f3c 2f73 7061 6e3e 3c2f ent">//.
│ │ │ │ +00004630: 3835 3c2f 7370 616e 3e20 2020 203c 7370 85 // Trivial g │ │ │ │ +00004660: 6574 2f73 6574 206d 6574 686f 6473 3a3c et/set methods:< │ │ │ │ +00004670: 2f73 7061 6e3e 3c2f 6469 763e 0a3c 6469 /span>
.< │ │ │ │ +00004690: 6120 6964 3d22 6c30 3030 3836 2220 6e61 a id="l00086" na │ │ │ │ +000046a0: 6d65 3d22 6c30 3030 3836 223e 3c2f 613e me="l00086"> │ │ │ │ +000046b0: 3c73 7061 6e20 636c 6173 733d 226c 696e 86 //
.
87 │ │ │ │ +00004750: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
< │ │ │ │ +000047a0: 6120 636c 6173 733d 226c 696e 6522 2068 a class="line" h │ │ │ │ +000047b0: 7265 663d 2261 3031 3333 372e 6874 6d6c ref="a01337.html │ │ │ │ +000047c0: 2361 3539 3033 3338 6565 3862 3534 3433 #a590338ee8b5443 │ │ │ │ +000047d0: 3036 6239 3730 6130 6331 3434 3563 6430 06b970a0c1445cd0 │ │ │ │ +000047e0: 3166 223e 2020 2038 393c 2f61 3e3c 2f73 1f"> 89 VtxB │ │ │ │ +00004850: 6f75 6e64 6172 7949 6e74 6572 706f 6c61 oundaryInterpola │ │ │ │ +00004860: 7469 6f6e 3c2f 613e 203c 6120 636c 6173 tion GetVtx │ │ │ │ +000048c0: 426f 756e 6461 7279 496e 7465 7270 6f6c BoundaryInterpol │ │ │ │ +000048d0: 6174 696f 6e3c 2f61 3e28 293c 7370 616e ation() const { │ │ │ │ +00004900: 203c 7370 616e 2063 6c61 7373 3d22 6b65 retur │ │ │ │ +00004920: 6e3c 2f73 7061 6e3e 2028 3c61 2063 6c61 n (Vt │ │ │ │ +00004980: 7842 6f75 6e64 6172 7949 6e74 6572 706f xBoundaryInterpo │ │ │ │ +00004990: 6c61 7469 6f6e 3c2f 613e 2920 5f76 7478 lation) _vtx │ │ │ │ +000049a0: 426f 756e 6449 6e74 6572 703b 207d 3c2f BoundInterp; }.
│ │ │ │ +00004a00: 3930 3c2f 7370 616e 3e20 3c2f 6469 763e 90
│ │ │ │ +00004a10: 0a3c 6469 7620 636c 6173 733d 226c 696e .
│ │ │ │ +00004a40: 3c2f 613e 3c73 7061 6e20 636c 6173 733d │ │ │ │ +00004aa0: 2039 323c 2f61 3e3c 2f73 7061 6e3e 2020 92 │ │ │ │ +00004ab0: 2020 3c73 7061 6e20 636c 6173 733d 226b void │ │ │ │ +00004ad0: 3c2f 7370 616e 3e20 3c61 2063 6c61 7373 SetVtxB │ │ │ │ +00004b30: 6f75 6e64 6172 7949 6e74 6572 706f 6c61 oundaryInterpola │ │ │ │ +00004b40: 7469 6f6e 3c2f 613e 283c 6120 636c 6173 tion(Vtx │ │ │ │ +00004ba0: 426f 756e 6461 7279 496e 7465 7270 6f6c BoundaryInterpol │ │ │ │ +00004bb0: 6174 696f 6e3c 2f61 3e20 6229 207b 205f ation b) { _ │ │ │ │ +00004bc0: 7674 7842 6f75 6e64 496e 7465 7270 203d vtxBoundInterp = │ │ │ │ +00004bd0: 2028 456e 756d 496e 7454 7970 6529 2062 (EnumIntType) b │ │ │ │ +00004be0: 3b20 7d3c 2f64 6976 3e0a 3c64 6976 2063 ; }
.
93 < │ │ │ │ +00004c40: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.. │ │ │ │ +00004ea0: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65 ..
99< │ │ │ │ +00005120: 2f73 7061 6e3e 203c 2f64 6976 3e0a 3c64 /span>
. │ │ │ │ +00005140: 3c61 2069 643d 226c 3030 3130 3122 206e 101 │ │ │ │ +000051c0: 3c2f 613e 3c2f 7370 616e 3e20 2020 203c < │ │ │ │ +000051d0: 6120 636c 6173 733d 2263 6f64 6520 686c a class="code hl │ │ │ │ +000051e0: 5f65 6e75 6d65 7261 7469 6f6e 2220 6872 _enumeration" hr │ │ │ │ +000051f0: 6566 3d22 6130 3133 3337 2e68 746d 6c23 ef="a01337.html# │ │ │ │ +00005200: 6131 3665 6335 3232 6463 3033 3938 6266 a16ec522dc0398bf │ │ │ │ +00005210: 3134 3335 6139 3132 6364 3636 3966 6662 1435a912cd669ffb │ │ │ │ +00005220: 3022 3e43 7265 6173 696e 674d 6574 686f 0">CreasingMetho │ │ │ │ +00005230: 643c 2f61 3e20 3c61 2063 6c61 7373 3d22 d GetCreasi │ │ │ │ +00005290: 6e67 4d65 7468 6f64 3c2f 613e 2829 3c73 ngMethod() const { re │ │ │ │ +000052e0: 7475 726e 3c2f 7370 616e 3e20 283c 6120 turn (CreasingMethod< │ │ │ │ +00005350: 2f61 3e29 205f 6372 6561 7369 6e67 4d65 /a>) _creasingMe │ │ │ │ +00005360: 7468 6f64 3b20 7d3c 2f64 6976 3e0a 3c64 thod; }
. │ │ │ │ +00005380: 3c61 2069 643d 226c 3030 3130 3222 206e 102
.
104 │ │ │ │ +00005460: 3c2f 7370 616e 3e20 2020 203c 7370 616e void │ │ │ │ +00005490: 203c 6120 636c 6173 733d 2263 6f64 6520 SetCreasingMet │ │ │ │ +000054f0: 686f 643c 2f61 3e28 3c61 2063 6c61 7373 hod(Crea │ │ │ │ +00005550: 7369 6e67 4d65 7468 6f64 3c2f 613e 2063 singMethod c │ │ │ │ +00005560: 2920 7b20 5f63 7265 6173 696e 674d 6574 ) { _creasingMet │ │ │ │ +00005570: 686f 6420 3d20 2845 6e75 6d49 6e74 5479 hod = (EnumIntTy │ │ │ │ +00005580: 7065 2920 633b 207d 3c2f 6469 763e 0a3c pe) c; }
.< │ │ │ │ +00005590: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +000055a0: 3e3c 6120 6964 3d22 6c30 3031 3035 2220 > 105
..
│ │ │ │ +00005880: 2031 3038 3c2f 7370 616e 3e20 3c2f 6469 108 .
│ │ │ │ +00005920: 2020 3131 303c 2f61 3e3c 2f73 7061 6e3e 110 │ │ │ │ +00005930: 2020 2020 3c73 7061 6e20 636c 6173 733d vo │ │ │ │ +00005950: 6964 3c2f 7370 616e 3e20 3c61 2063 6c61 id SetTr │ │ │ │ +000059b0: 6961 6e67 6c65 5375 6264 6976 6973 696f iangleSubdivisio │ │ │ │ +000059c0: 6e3c 2f61 3e28 3c61 2063 6c61 7373 3d22 n(Triang │ │ │ │ +00005a20: 6c65 5375 6264 6976 6973 696f 6e3c 2f61 leSubdivision t) { _triangle │ │ │ │ +00005a40: 5375 6220 3d20 2845 6e75 6d49 6e74 5479 Sub = (EnumIntTy │ │ │ │ +00005a50: 7065 2920 743b 207d 3c2f 6469 763e 0a3c pe) t; }
.< │ │ │ │ +00005a60: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00005a70: 3e3c 6120 6964 3d22 6c30 3031 3131 2220 > 111
.
112< │ │ │ │ +00005b10: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00005b20: 6f72 6422 3e70 7269 7661 7465 3c2f 7370 ord">private:
.
113 │ │ │ │ +00005b90: 2020 203c 7370 616e 2063 6c61 7373 3d22 // Use │ │ │ │ +00005bb0: 2061 2073 6d61 6c6c 2069 6e74 6567 6572 a small integer │ │ │ │ +00005bc0: 2074 7970 6520 746f 2070 6163 6b20 7468 type to pack th │ │ │ │ +00005bd0: 6573 6520 7261 7468 6572 2074 6861 6e20 ese rather than │ │ │ │ +00005be0: 6269 7466 6965 6c64 733a 3c2f 7370 616e bitfields:
.
│ │ │ │ +00005c40: 2020 3131 343c 2f73 7061 6e3e 2020 2020 114 │ │ │ │ +00005c50: 3c73 7061 6e20 636c 6173 733d 226b 6579 typedef u │ │ │ │ +00005c90: 6e73 6967 6e65 643c 2f73 7061 6e3e 203c nsigned < │ │ │ │ +00005ca0: 7370 616e 2063 6c61 7373 3d22 6b65 7977 span class="keyw │ │ │ │ +00005cb0: 6f72 6474 7970 6522 3e63 6861 723c 2f73 ordtype">char EnumIntType │ │ │ │ +00005cd0: 3b3c 2f64 6976 3e0a 3c64 6976 2063 6c61 ;
.
│ │ │ │ +00005d20: 2020 3131 353c 2f73 7061 6e3e 203c 2f64 115 .
11 │ │ │ │ +00005d80: 363c 2f73 7061 6e3e 2020 2020 456e 756d 6 Enum │ │ │ │ +00005d90: 496e 7454 7970 6520 5f76 7478 426f 756e IntType _vtxBoun │ │ │ │ +00005da0: 6449 6e74 6572 703b 3c2f 6469 763e 0a3c dInterp;
.< │ │ │ │ +00005db0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00005dc0: 3e3c 6120 6964 3d22 6c30 3031 3137 2220 > 117 EnumIntTy │ │ │ │ +00005e10: 7065 205f 6676 6172 4c69 6e49 6e74 6572 pe _fvarLinInter │ │ │ │ +00005e20: 703b 3c2f 6469 763e 0a3c 6469 7620 636c p;
.
118 │ │ │ │ +00005e80: 2045 6e75 6d49 6e74 5479 7065 205f 6372 EnumIntType _cr │ │ │ │ +00005e90: 6561 7369 6e67 4d65 7468 6f64 3b3c 2f64 easingMethod;.
11 │ │ │ │ +00005ef0: 393c 2f73 7061 6e3e 2020 2020 456e 756d 9 Enum │ │ │ │ +00005f00: 496e 7454 7970 6520 5f74 7269 616e 676c IntType _triangl │ │ │ │ +00005f10: 6553 7562 3b3c 2f64 6976 3e0a 3c64 6976 eSub;
.
< │ │ │ │ +00005f50: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00005f60: 6e6f 223e 2020 3132 303c 2f73 7061 6e3e no"> 120 │ │ │ │ +00005f70: 7d3b 3c2f 6469 763e 0a3c 2f64 6976 3e0a };
.
. │ │ │ │ +00005f80: 3c64 6976 2063 6c61 7373 3d22 6c69 6e65
.
< │ │ │ │ +00006010: 7370 616e 2063 6c61 7373 3d22 6c69 6e65 span class="line │ │ │ │ +00006020: 6e6f 223e 2020 3132 323c 2f73 7061 6e3e no"> 122 │ │ │ │ +00006030: 7d20 3c73 7061 6e20 636c 6173 733d 2263 } // end n │ │ │ │ +00006050: 616d 6573 7061 6365 2073 6463 3c2f 7370 amespace sdc
.
123 < │ │ │ │ +000060c0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
│ │ │ │ +00006110: 3132 343c 2f73 7061 6e3e 7d20 3c73 7061 124} // end namespa │ │ │ │ +00006140: 6365 204f 5045 4e53 5542 4449 565f 5645 ce OPENSUBDIV_VE │ │ │ │ +00006150: 5253 494f 4e3c 2f73 7061 6e3e 3c2f 6469 RSION.
125 │ │ │ │ +000061b0: 3c2f 7370 616e 3e3c 7370 616e 2063 6c61 usi │ │ │ │ +000061d0: 6e67 206e 616d 6573 7061 6365 203c 2f73 ng namespace OPENSUBDIV_V │ │ │ │ +000061f0: 4552 5349 4f4e 3b3c 2f64 6976 3e0a 3c64 ERSION;
. │ │ │ │ +00006210: 3c61 2069 643d 226c 3030 3132 3622 206e 126} // end │ │ │ │ +00006270: 206e 616d 6573 7061 6365 204f 7065 6e53 namespace OpenS │ │ │ │ +00006280: 7562 6469 763c 2f73 7061 6e3e 3c2f 6469 ubdiv.
127 │ │ │ │ +000062e0: 3c2f 7370 616e 3e20 3c2f 6469 763e 0a3c
.< │ │ │ │ +000062f0: 6469 7620 636c 6173 733d 226c 696e 6522 div class="line" │ │ │ │ +00006300: 3e3c 6120 6964 3d22 6c30 3031 3238 2220 > 128#e │ │ │ │ +00006360: 6e64 6966 203c 2f73 7061 6e3e 3c73 7061 ndif /* OPENSUBDIV3 │ │ │ │ +00006390: 5f53 4443 5f4f 5054 494f 4e53 5f48 202a _SDC_OPTIONS_H * │ │ │ │ +000063a0: 2f3c 2f73 7061 6e3e 3c73 7061 6e20 636c /
│ │ │ │ +000063d0: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
Op │ │ │ │ +00006420: 656e 5375 6264 6976 3c2f 613e 3c2f 6469 enSubdiv
Definiti │ │ │ │ +00006450: 6f6e 3c2f 623e 203c 6120 6872 6566 3d22 on limit │ │ │ │ +00006480: 732e 683a 3332 3c2f 613e 3c2f 6469 763e s.h:32
│ │ │ │ +00006490: 3c2f 6469 763e 0a3c 6469 7620 636c 6173
.
All │ │ │ │ +00006530: 2073 7570 706f 7274 6564 206f 7074 696f supported optio │ │ │ │ +00006540: 6e73 2061 7070 6c79 696e 6720 746f 2073 ns applying to s │ │ │ │ +00006550: 7562 6469 7669 7369 6f6e 2073 6368 656d ubdivision schem │ │ │ │ +00006560: 652e 3c2f 6469 763e 3c64 6976 2063 6c61 e.
De │ │ │ │ +00006580: 6669 6e69 7469 6f6e 3c2f 623e 203c 6120 finition options.h:51
.
Tr │ │ │ │ +000066c0: 6961 6e67 6c65 5375 6264 6976 6973 696f iangleSubdivisio │ │ │ │ +000066d0: 6e3c 2f64 6976 3e3c 6469 7620 636c 6173 n
Def │ │ │ │ +000066f0: 696e 6974 696f 6e3c 2f62 3e20 3c61 2068 inition │ │ │ │ +00006720: 6f70 7469 6f6e 732e 683a 3732 3c2f 613e options.h:72 │ │ │ │ +00006730: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.
@ TRI │ │ │ │ +00006870: 5f53 5542 5f43 4154 4d41 524b 3c2f 6469 _SUB_CATMARK
Catmark wei │ │ │ │ +000068a0: 6768 7473 2028 4361 746d 6172 6b20 7363 ghts (Catmark sc │ │ │ │ +000068b0: 6865 6d65 206f 6e6c 7929 3c2f 6469 763e heme only)
│ │ │ │ +000068c0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ +000068e0: 3c2f 623e 203c 6120 6872 6566 3d22 6130 options │ │ │ │ +00006910: 2e68 3a37 333c 2f61 3e3c 2f64 6976 3e3c .h:73
< │ │ │ │ +00006920: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
< │ │ │ │ +00006a40: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ +00006a50: 6922 3e40 2054 5249 5f53 5542 5f53 4d4f i">@ TRI_SUB_SMO │ │ │ │ +00006a60: 4f54 483c 2f64 6976 3e3c 6469 7620 636c OTH
&quo │ │ │ │ +00006a80: 743b 736d 6f6f 7468 2074 7269 616e 676c t;smooth triangl │ │ │ │ +00006a90: 6526 7175 6f74 3b20 7765 6967 6874 7320 e" weights │ │ │ │ +00006aa0: 2843 6174 6d61 726b 2073 6368 656d 6520 (Catmark scheme │ │ │ │ +00006ab0: 6f6e 6c79 293c 2f64 6976 3e3c 6469 7620 only)
Definition │ │ │ │ +00006ae0: 3c61 2068 7265 663d 2261 3030 3737 335f options.h:74 │ │ │ │ +00006b10: 3c2f 613e 3c2f 6469 763e 3c2f 6469 763e
│ │ │ │ +00006b20: 0a3c 6469 7620 636c 6173 733d 2274 7463 .
│ │ │ │ +00006c20: 3c64 6976 2063 6c61 7373 3d22 7474 6465 < │ │ │ │ +00006c80: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
< │ │ │ │ +00006da0: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ +00006db0: 6922 3e40 2043 5245 4153 455f 554e 4946 i">@ CREASE_UNIF │ │ │ │ +00006dc0: 4f52 4d3c 2f64 6976 3e3c 6469 7620 636c ORM
Catm │ │ │ │ +00006de0: 6172 6b20 7275 6c65 2e3c 2f64 6976 3e3c ark rule.
< │ │ │ │ +00006df0: 6469 7620 636c 6173 733d 2274 7464 6566 div class="ttdef │ │ │ │ +00006e00: 223e 3c62 3e44 6566 696e 6974 696f 6e3c ">Definition< │ │ │ │ +00006e10: 2f62 3e20 3c61 2068 7265 663d 2261 3030 /b> options. │ │ │ │ +00006e40: 683a 3639 3c2f 613e 3c2f 6469 763e 3c2f h:69
.
< │ │ │ │ +00006ed0: 6120 6872 6566 3d22 6130 3133 3337 2e68 a href="a01337.h │ │ │ │ +00006ee0: 746d 6c23 6131 3665 6335 3232 6463 3033 tml#a16ec522dc03 │ │ │ │ +00006ef0: 3938 6266 3134 3335 6139 3132 6364 3636 98bf1435a912cd66 │ │ │ │ +00006f00: 3966 6662 3061 3165 3331 6135 3833 3636 9ffb0a1e31a58366 │ │ │ │ +00006f10: 3364 6436 3561 3762 3266 6566 6665 6232 3dd65a7b2feffeb2 │ │ │ │ +00006f20: 3432 3638 6235 223e 4f70 656e 5375 6264 4268b5">OpenSubd │ │ │ │ +00006f30: 6976 3a3a 4f50 454e 5355 4244 4956 5f56 iv::OPENSUBDIV_V │ │ │ │ +00006f40: 4552 5349 4f4e 3a3a 5364 633a 3a4f 7074 ERSION::Sdc::Opt │ │ │ │ +00006f50: 696f 6e73 3a3a 4352 4541 5345 5f43 4841 ions::CREASE_CHA │ │ │ │ +00006f60: 494b 494e 3c2f 613e 3c2f 6469 763e 3c64 IKIN
@ CREASE_CHAIK │ │ │ │ +00006f90: 494e 3c2f 6469 763e 3c64 6976 2063 6c61 IN
Chaik │ │ │ │ +00006fb0: 696e 2072 756c 652e 3c2f 6469 763e 3c64 in rule.
Definition options.h │ │ │ │ +00007010: 3a37 303c 2f61 3e3c 2f64 6976 3e3c 2f64 :70
.
OpenSubdiv: │ │ │ │ +000070c0: 3a4f 5045 4e53 5542 4449 565f 5645 5253 :OPENSUBDIV_VERS │ │ │ │ +000070d0: 494f 4e3a 3a53 6463 3a3a 4f70 7469 6f6e ION::Sdc::Option │ │ │ │ +000070e0: 733a 3a47 6574 5472 6961 6e67 6c65 5375 s::GetTriangleSu │ │ │ │ +000070f0: 6264 6976 6973 696f 6e3c 2f61 3e3c 2f64 bdivision
TriangleS │ │ │ │ +00007120: 7562 6469 7669 7369 6f6e 2047 6574 5472 ubdivision GetTr │ │ │ │ +00007130: 6961 6e67 6c65 5375 6264 6976 6973 696f iangleSubdivisio │ │ │ │ +00007140: 6e28 2920 636f 6e73 743c 2f64 6976 3e3c n() const
< │ │ │ │ +00007150: 6469 7620 636c 6173 733d 2274 7464 6f63 div class="ttdoc │ │ │ │ +00007160: 223e 4765 7420 7472 6961 6e67 6c65 2073 ">Get triangle s │ │ │ │ +00007170: 7562 6469 7669 7369 6f6e 2077 6569 6768 ubdivision weigh │ │ │ │ +00007180: 7473 2072 756c 6520 2843 6174 6d61 726b ts rule (Catmark │ │ │ │ +00007190: 2073 6368 656d 6520 6f6e 6c79 2021 293c scheme only !)< │ │ │ │ +000071a0: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
Defin │ │ │ │ +000071c0: 6974 696f 6e3c 2f62 3e20 3c61 2068 7265 ition op │ │ │ │ +000071f0: 7469 6f6e 732e 683a 3130 373c 2f61 3e3c tions.h:107< │ │ │ │ +00007200: 2f64 6976 3e3c 2f64 6976 3e0a 3c64 6976 /div>
.
Creasi │ │ │ │ +00007300: 6e67 4d65 7468 6f64 2047 6574 4372 6561 ngMethod GetCrea │ │ │ │ +00007310: 7369 6e67 4d65 7468 6f64 2829 2063 6f6e singMethod() con │ │ │ │ +00007320: 7374 3c2f 6469 763e 3c64 6976 2063 6c61 st
Get e │ │ │ │ +00007340: 6467 6520 6372 6561 7365 2072 756c 652e dge crease rule. │ │ │ │ +00007350: 3c2f 6469 763e 3c64 6976 2063 6c61 7373
Defi │ │ │ │ +00007370: 6e69 7469 6f6e 3c2f 623e 203c 6120 6872 nition o │ │ │ │ +000073a0: 7074 696f 6e73 2e68 3a31 3031 3c2f 613e ptions.h:101 │ │ │ │ +000073b0: 3c2f 6469 763e 3c2f 6469 763e 0a3c 6469
.Options()
│ │ │ │ +000074b0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ +000074d0: 3c2f 623e 203c 6120 6872 6566 3d22 6130 options │ │ │ │ +00007500: 2e68 3a37 393c 2f61 3e3c 2f64 6976 3e3c .h:79
< │ │ │ │ +00007510: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
< │ │ │ │ +00007570: 6120 6872 6566 3d22 6130 3133 3337 2e68 a href="a01337.h │ │ │ │ +00007580: 746d 6c23 6132 6233 3335 6562 3232 3731 tml#a2b335eb2271 │ │ │ │ +00007590: 3934 6234 6663 3666 6365 6337 6633 6334 94b4fc6fcec7f3c4 │ │ │ │ +000075a0: 6232 3563 6522 3e4f 7065 6e53 7562 6469 b25ce">OpenSubdi │ │ │ │ +000075b0: 763a 3a4f 5045 4e53 5542 4449 565f 5645 v::OPENSUBDIV_VE │ │ │ │ +000075c0: 5253 494f 4e3a 3a53 6463 3a3a 4f70 7469 RSION::Sdc::Opti │ │ │ │ +000075d0: 6f6e 733a 3a53 6574 4656 6172 4c69 6e65 ons::SetFVarLine │ │ │ │ +000075e0: 6172 496e 7465 7270 6f6c 6174 696f 6e3c arInterpolation< │ │ │ │ +000075f0: 2f61 3e3c 2f64 6976 3e3c 6469 7620 636c /a>
voi │ │ │ │ +00007610: 6420 5365 7446 5661 724c 696e 6561 7249 d SetFVarLinearI │ │ │ │ +00007620: 6e74 6572 706f 6c61 7469 6f6e 2846 5661 nterpolation(FVa │ │ │ │ +00007630: 724c 696e 6561 7249 6e74 6572 706f 6c61 rLinearInterpola │ │ │ │ +00007640: 7469 6f6e 2062 293c 2f64 6976 3e3c 6469 tion b)
│ │ │ │ +00007660: 5365 7420 6661 6365 2d76 6172 7969 6e67 Set face-varying │ │ │ │ +00007670: 2069 6e74 6572 706f 6c61 7469 6f6e 2072 interpolation r │ │ │ │ +00007680: 756c 652e 3c2f 6469 763e 3c64 6976 2063 ule.
│ │ │ │ +000076a0: 4465 6669 6e69 7469 6f6e 3c2f 623e 203c Definition < │ │ │ │ +000076b0: 6120 6872 6566 3d22 6130 3037 3733 5f73 a href="a00773_s │ │ │ │ +000076c0: 6f75 7263 652e 6874 6d6c 236c 3030 3039 ource.html#l0009 │ │ │ │ +000076d0: 3822 3e6f 7074 696f 6e73 2e68 3a39 383c 8">options.h:98< │ │ │ │ +000076e0: 2f61 3e3c 2f64 6976 3e3c 2f64 6976 3e0a /a>
. │ │ │ │ +000076f0: 3c64 6976 2063 6c61 7373 3d22 7474 6322
< │ │ │ │ +000077d0: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ +000077e0: 6922 3e76 6f69 6420 5365 7454 7269 616e i">void SetTrian │ │ │ │ +000077f0: 676c 6553 7562 6469 7669 7369 6f6e 2854 gleSubdivision(T │ │ │ │ +00007800: 7269 616e 676c 6553 7562 6469 7669 7369 riangleSubdivisi │ │ │ │ +00007810: 6f6e 2074 293c 2f64 6976 3e3c 6469 7620 on t)
Se │ │ │ │ +00007830: 7420 7472 6961 6e67 6c65 2073 7562 6469 t triangle subdi │ │ │ │ +00007840: 7669 7369 6f6e 2077 6569 6768 7473 2072 vision weights r │ │ │ │ +00007850: 756c 6520 2843 6174 6d61 726b 2073 6368 ule (Catmark sch │ │ │ │ +00007860: 656d 6520 6f6e 6c79 2021 293c 2f64 6976 eme only !)
Definitio │ │ │ │ +00007890: 6e3c 2f62 3e20 3c61 2068 7265 663d 2261 n option │ │ │ │ +000078c0: 732e 683a 3131 303c 2f61 3e3c 2f64 6976 s.h:110
.
│ │ │ │ +000079d0: 5674 7842 6f75 6e64 6172 7949 6e74 6572 VtxBoundaryInter │ │ │ │ +000079e0: 706f 6c61 7469 6f6e 2047 6574 5674 7842 polation GetVtxB │ │ │ │ +000079f0: 6f75 6e64 6172 7949 6e74 6572 706f 6c61 oundaryInterpola │ │ │ │ +00007a00: 7469 6f6e 2829 2063 6f6e 7374 3c2f 6469 tion() const
Get vertex │ │ │ │ +00007a30: 626f 756e 6461 7279 2069 6e74 6572 706f boundary interpo │ │ │ │ +00007a40: 6c61 7469 6f6e 2072 756c 652e 3c2f 6469 lation rule.
Definiti │ │ │ │ +00007a70: 6f6e 3c2f 623e 203c 6120 6872 6566 3d22 on optio │ │ │ │ +00007aa0: 6e73 2e68 3a38 393c 2f61 3e3c 2f64 6976 ns.h:89
.
.< │ │ │ │ +00007c30: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ +00007c40: 6964 3d22 6161 3031 3333 375f 6874 6d6c id="aa01337_html │ │ │ │ +00007c50: 5f61 3562 3837 6561 6361 3663 6130 3833 _a5b87eaca6ca083 │ │ │ │ +00007c60: 3334 3632 6339 6434 6164 3834 6466 3136 3462c9d4ad84df16 │ │ │ │ +00007c70: 3762 6132 6430 6564 6234 6464 3130 6533 7ba2d0edb4dd10e3 │ │ │ │ +00007c80: 3535 6638 3038 3962 3461 3761 6231 6431 55f8089b4a7ab1d1 │ │ │ │ +00007c90: 6437 3222 3e3c 6469 7620 636c 6173 733d d72">
OpenSubdiv::OP │ │ │ │ +00007d10: 454e 5355 4244 4956 5f56 4552 5349 4f4e ENSUBDIV_VERSION │ │ │ │ +00007d20: 3a3a 5364 633a 3a4f 7074 696f 6e73 3a3a ::Sdc::Options:: │ │ │ │ +00007d30: 4656 4152 5f4c 494e 4541 525f 434f 524e FVAR_LINEAR_CORN │ │ │ │ +00007d40: 4552 535f 4f4e 4c59 3c2f 613e 3c2f 6469 ERS_ONLY
@ FVAR_LIN │ │ │ │ +00007d70: 4541 525f 434f 524e 4552 535f 4f4e 4c59 EAR_CORNERS_ONLY │ │ │ │ +00007d80: 3c2f 6469 763e 3c64 6976 2063 6c61 7373
sharpen │ │ │ │ +00007da0: 2063 6f72 6e65 7273 206f 6e6c 793c 2f64 corners only
Definit │ │ │ │ +00007dd0: 696f 6e3c 2f62 3e20 3c61 2068 7265 663d ion opti │ │ │ │ +00007e00: 6f6e 732e 683a 3632 3c2f 613e 3c2f 6469 ons.h:62
.
@ │ │ │ │ +00007f50: 4656 4152 5f4c 494e 4541 525f 424f 554e FVAR_LINEAR_BOUN │ │ │ │ +00007f60: 4441 5249 4553 3c2f 6469 763e 3c64 6976 DARIES
s │ │ │ │ +00007f80: 6861 7270 656e 2061 6c6c 2062 6f75 6e64 harpen all bound │ │ │ │ +00007f90: 6172 6965 7320 2826 7175 6f74 3b61 6c77 aries ("alw │ │ │ │ +00007fa0: 6179 7320 7368 6172 7026 7175 6f74 3b29 ays sharp") │ │ │ │ +00007fb0: 3c2f 6469 763e 3c64 6976 2063 6c61 7373
Defi │ │ │ │ +00007fd0: 6e69 7469 6f6e 3c2f 623e 203c 6120 6872 nition o │ │ │ │ +00008000: 7074 696f 6e73 2e68 3a36 353c 2f61 3e3c ptions.h:65< │ │ │ │ +00008010: 2f64 6976 3e3c 2f64 6976 3e0a 3c64 6976 /div>
.
│ │ │ │ +00008140: 3c64 6976 2063 6c61 7373 3d22 7474 6465
@ FVAR_LINEA │ │ │ │ +00008160: 525f 434f 524e 4552 535f 504c 5553 323c R_CORNERS_PLUS2< │ │ │ │ +00008170: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
("e │ │ │ │ +00008190: 6467 6520 616e 6420 636f 726e 6572 202b dge and corner + │ │ │ │ +000081a0: 2070 726f 7061 6761 7465 2063 6f72 6e65 propagate corne │ │ │ │ +000081b0: 7226 7175 6f74 3b29 3c2f 6469 763e 3c64 r")
Definition options.h │ │ │ │ +00008210: 3a36 343c 2f61 3e3c 2f64 6976 3e3c 2f64 :64
.< │ │ │ │ +000083b0: 6469 7620 636c 6173 733d 2274 7464 6566 div class="ttdef │ │ │ │ +000083c0: 223e 3c62 3e44 6566 696e 6974 696f 6e3c ">Definition< │ │ │ │ +000083d0: 2f62 3e20 3c61 2068 7265 663d 2261 3030 /b> options. │ │ │ │ +00008400: 683a 3633 3c2f 613e 3c2f 6469 763e 3c2f h:63
.
< │ │ │ │ +00008490: 6120 6872 6566 3d22 6130 3133 3337 2e68 a href="a01337.h │ │ │ │ +000084a0: 746d 6c23 6135 6238 3765 6163 6136 6361 tml#a5b87eaca6ca │ │ │ │ +000084b0: 3038 3333 3436 3263 3964 3461 6438 3464 0833462c9d4ad84d │ │ │ │ +000084c0: 6631 3637 6261 3864 3464 6630 3833 3130 f167ba8d4df08310 │ │ │ │ +000084d0: 3439 3733 6661 6431 3437 3931 3039 3938 4973fad147910998 │ │ │ │ +000084e0: 3865 3033 3837 223e 4f70 656e 5375 6264 8e0387">OpenSubd │ │ │ │ +000084f0: 6976 3a3a 4f50 454e 5355 4244 4956 5f56 iv::OPENSUBDIV_V │ │ │ │ +00008500: 4552 5349 4f4e 3a3a 5364 633a 3a4f 7074 ERSION::Sdc::Opt │ │ │ │ +00008510: 696f 6e73 3a3a 4656 4152 5f4c 494e 4541 ions::FVAR_LINEA │ │ │ │ +00008520: 525f 414c 4c3c 2f61 3e3c 2f64 6976 3e3c R_ALL
< │ │ │ │ +00008530: 6469 7620 636c 6173 733d 2274 7464 6563 div class="ttdec │ │ │ │ +00008540: 6922 3e40 2046 5641 525f 4c49 4e45 4152 i">@ FVAR_LINEAR │ │ │ │ +00008550: 5f41 4c4c 3c2f 6469 763e 3c64 6976 2063 _ALL
bil │ │ │ │ +00008570: 696e 6561 7220 696e 7465 7270 6f6c 6174 inear interpolat │ │ │ │ +00008580: 696f 6e20 2826 7175 6f74 3b62 696c 696e ion ("bilin │ │ │ │ +00008590: 6561 7226 7175 6f74 3b29 3c2f 6469 763e ear")
│ │ │ │ +000085a0: 3c64 6976 2063 6c61 7373 3d22 7474 6465
Definition │ │ │ │ +000085c0: 3c2f 623e 203c 6120 6872 6566 3d22 6130 options │ │ │ │ +000085f0: 2e68 3a36 363c 2f61 3e3c 2f64 6976 3e3c .h:66
< │ │ │ │ +00008600: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
@ FVAR_LINE │ │ │ │ +00008740: 4152 5f4e 4f4e 453c 2f64 6976 3e3c 6469 AR_NONE
│ │ │ │ +00008760: 736d 6f6f 7468 2065 7665 7279 7768 6572 smooth everywher │ │ │ │ +00008770: 6520 2826 7175 6f74 3b65 6467 6520 6f6e e ("edge on │ │ │ │ +00008780: 6c79 2671 756f 743b 293c 2f64 6976 3e3c ly")
< │ │ │ │ +00008790: 6469 7620 636c 6173 733d 2274 7464 6566 div class="ttdef │ │ │ │ +000087a0: 223e 3c62 3e44 6566 696e 6974 696f 6e3c ">Definition< │ │ │ │ +000087b0: 2f62 3e20 3c61 2068 7265 663d 2261 3030 /b> options. │ │ │ │ +000087e0: 683a 3631 3c2f 613e 3c2f 6469 763e 3c2f h:61
.< │ │ │ │ +00008970: 6469 7620 636c 6173 733d 2274 7464 6566 div class="ttdef │ │ │ │ +00008980: 223e 3c62 3e44 6566 696e 6974 696f 6e3c ">Definition< │ │ │ │ +00008990: 2f62 3e20 3c61 2068 7265 663d 2261 3030 /b> options. │ │ │ │ +000089c0: 683a 3932 3c2f 613e 3c2f 6469 763e 3c2f h:92
..< │ │ │ │ +00008bb0: 6469 7620 636c 6173 733d 2274 7463 2220 div class="ttc" │ │ │ │ +00008bc0: 6964 3d22 6161 3031 3333 375f 6874 6d6c id="aa01337_html │ │ │ │ +00008bd0: 5f61 6362 6637 3866 3161 3661 6266 6338 _acbf78f1a6abfc8 │ │ │ │ +00008be0: 6462 3038 3065 6637 6662 3363 3366 3431 db080ef7fb3c3f41 │ │ │ │ +00008bf0: 3765 223e 3c64 6976 2063 6c61 7373 3d22 7e"> │ │ │ │ +00008c90: 3c64 6976 2063 6c61 7373 3d22 7474 6465
VtxBoundaryI │ │ │ │ +00008cb0: 6e74 6572 706f 6c61 7469 6f6e 3c2f 6469 nterpolation
Definiti │ │ │ │ +00008ce0: 6f6e 3c2f 623e 203c 6120 6872 6566 3d22 on optio │ │ │ │ +00008d10: 6e73 2e68 3a35 333c 2f61 3e3c 2f64 6976 ns.h:53
.. │ │ │ │ +00009070: 3c64 6976 2063 6c61 7373 3d22 7474 6465 < │ │ │ │ +000090d0: 2f64 6976 3e0a 3c64 6976 2063 6c61 7373 /div>.
@ VTX_BOUNDARY_ │ │ │ │ +00009220: 4544 4745 5f41 4e44 5f43 4f52 4e45 523c EDGE_AND_CORNER< │ │ │ │ +00009230: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
Defin │ │ │ │ +00009250: 6974 696f 6e3c 2f62 3e20 3c61 2068 7265 ition op │ │ │ │ +00009280: 7469 6f6e 732e 683a 3537 3c2f 613e 3c2f tions.h:57
.
│ │ │ │ +000092e0: 3c64 6976 2063 6c61 7373 3d22 7474 6e61
Open │ │ │ │ +00009330: 5375 6264 6976 3a3a 4f50 454e 5355 4244 Subdiv::OPENSUBD │ │ │ │ +00009340: 4956 5f56 4552 5349 4f4e 3a3a 5364 633a IV_VERSION::Sdc: │ │ │ │ +00009350: 3a4f 7074 696f 6e73 3a3a 5365 7443 7265 :Options::SetCre │ │ │ │ +00009360: 6173 696e 674d 6574 686f 643c 2f61 3e3c asingMethod< │ │ │ │ +00009370: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
void Se │ │ │ │ +00009390: 7443 7265 6173 696e 674d 6574 686f 6428 tCreasingMethod( │ │ │ │ +000093a0: 4372 6561 7369 6e67 4d65 7468 6f64 2063 CreasingMethod c │ │ │ │ +000093b0: 293c 2f64 6976 3e3c 6469 7620 636c 6173 )
Set ed │ │ │ │ +000093d0: 6765 2063 7265 6173 6520 7275 6c65 2e3c ge crease rule.< │ │ │ │ +000093e0: 2f64 6976 3e3c 6469 7620 636c 6173 733d /div>
Defin │ │ │ │ +00009400: 6974 696f 6e3c 2f62 3e20 3c61 2068 7265 ition op │ │ │ │ +00009430: 7469 6f6e 732e 683a 3130 343c 2f61 3e3c tions.h:104< │ │ │ │ +00009440: 2f64 6976 3e3c 2f64 6976 3e0a 3c2f 6469 /div>
.
.
. │ │ │ │ +000094b0: 0a3c 6469 7620 6964 3d22 6e61 762d 7061 . │ │ │ │ +00009700: 0a3c 2f62 6f64 793e 0a3c 2f68 746d 6c3e .. │ │ │ │ +00009710: 0a . │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -scheme.h │ │ │ │ │ +options.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -23,847 +23,200 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_SDC_SCHEME_H │ │ │ │ │ -25#define OPENSUBDIV3_SDC_SCHEME_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_SDC_OPTIONS_H │ │ │ │ │ +25#define OPENSUBDIV3_SDC_OPTIONS_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ -29#include "../sdc/types.h" │ │ │ │ │ -30#include "../sdc/options.h" │ │ │ │ │ -31#include "../sdc/crease.h" │ │ │ │ │ -32 │ │ │ │ │ -33#include │ │ │ │ │ -34#include │ │ │ │ │ -35#include │ │ │ │ │ -36 │ │ │ │ │ -37namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -38namespace OPENSUBDIV_VERSION { │ │ │ │ │ -39 │ │ │ │ │ -40namespace Sdc { │ │ │ │ │ -41 │ │ │ │ │ -65template │ │ │ │ │ -_6_6class _S_c_h_e_m_e { │ │ │ │ │ -67 │ │ │ │ │ -68public: │ │ │ │ │ -69 │ │ │ │ │ -_7_0 _S_c_h_e_m_e() : _options() { } │ │ │ │ │ -71 │ │ │ │ │ -_7_2 _S_c_h_e_m_e(_O_p_t_i_o_n_s const& options) : _options(options) { } │ │ │ │ │ -73 │ │ │ │ │ -_7_4 _O_p_t_i_o_n_s _G_e_t_O_p_t_i_o_n_s() const { return _options; } │ │ │ │ │ -_7_5 void _S_e_t_O_p_t_i_o_n_s(const _O_p_t_i_o_n_s& newOptions) { _options = newOptions; } │ │ │ │ │ +29namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +30namespace OPENSUBDIV_VERSION { │ │ │ │ │ +31 │ │ │ │ │ +32namespace Sdc { │ │ │ │ │ +33 │ │ │ │ │ +50 │ │ │ │ │ +_5_1class _O_p_t_i_o_n_s { │ │ │ │ │ +52public: │ │ │ │ │ +_5_3 enum _V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n { │ │ │ │ │ +54 _V_T_X___B_O_U_N_D_A_R_Y___N_O_N_E = 0, │ │ │ │ │ +_5_6 _V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___O_N_L_Y, │ │ │ │ │ +57 _V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___A_N_D___C_O_R_N_E_R │ │ │ │ │ +_5_9 }; │ │ │ │ │ +_6_0 enum _F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n { │ │ │ │ │ +_6_1 _F_V_A_R___L_I_N_E_A_R___N_O_N_E = 0, │ │ │ │ │ +_6_2 _F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___O_N_L_Y, │ │ │ │ │ +_6_3 _F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___P_L_U_S_1, │ │ │ │ │ +_6_4 _F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___P_L_U_S_2, │ │ │ │ │ +_6_5 _F_V_A_R___L_I_N_E_A_R___B_O_U_N_D_A_R_I_E_S, │ │ │ │ │ +66 _F_V_A_R___L_I_N_E_A_R___A_L_L │ │ │ │ │ +_6_7 }; │ │ │ │ │ +_6_8 enum _C_r_e_a_s_i_n_g_M_e_t_h_o_d { │ │ │ │ │ +_6_9 _C_R_E_A_S_E___U_N_I_F_O_R_M = 0, │ │ │ │ │ +70 _C_R_E_A_S_E___C_H_A_I_K_I_N │ │ │ │ │ +_7_1 }; │ │ │ │ │ +_7_2 enum _T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n { │ │ │ │ │ +_7_3 _T_R_I___S_U_B___C_A_T_M_A_R_K = 0, │ │ │ │ │ +74 _T_R_I___S_U_B___S_M_O_O_T_H │ │ │ │ │ +_7_5 }; │ │ │ │ │ 76 │ │ │ │ │ -80 template │ │ │ │ │ -81 void _C_o_m_p_u_t_e_F_a_c_e_V_e_r_t_e_x_M_a_s_k(FACE const& faceNeighborhood, MASK& │ │ │ │ │ -faceVertexMask) const; │ │ │ │ │ -82 │ │ │ │ │ -98 template │ │ │ │ │ -99 void _C_o_m_p_u_t_e_E_d_g_e_V_e_r_t_e_x_M_a_s_k(EDGE const& edgeNeighborhood, MASK& │ │ │ │ │ -edgeVertexMask, │ │ │ │ │ -100 _C_r_e_a_s_e_:_:_R_u_l_e parentRule = _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N, │ │ │ │ │ -101 _C_r_e_a_s_e_:_:_R_u_l_e childRule = _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) const; │ │ │ │ │ +77public: │ │ │ │ │ +78 │ │ │ │ │ +_7_9 _O_p_t_i_o_n_s() : _vtxBoundInterp(_V_T_X___B_O_U_N_D_A_R_Y___N_O_N_E), │ │ │ │ │ +80 _fvarLinInterp(_F_V_A_R___L_I_N_E_A_R___A_L_L), │ │ │ │ │ +81 _creasingMethod(_C_R_E_A_S_E___U_N_I_F_O_R_M), │ │ │ │ │ +82 _triangleSub(_T_R_I___S_U_B___C_A_T_M_A_R_K) { } │ │ │ │ │ +83 │ │ │ │ │ +84 // │ │ │ │ │ +85 // Trivial get/set methods: │ │ │ │ │ +86 // │ │ │ │ │ +87 │ │ │ │ │ +_8_9 _V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n _G_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n() const { return │ │ │ │ │ +(_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n) _vtxBoundInterp; } │ │ │ │ │ +90 │ │ │ │ │ +_9_2 void _S_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n(_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n b) │ │ │ │ │ +{ _vtxBoundInterp = (EnumIntType) b; } │ │ │ │ │ +93 │ │ │ │ │ +_9_5 _F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n _G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n() const { return │ │ │ │ │ +(_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n) _fvarLinInterp; } │ │ │ │ │ +96 │ │ │ │ │ +_9_8 void _S_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n(_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n b) { _fvarLinInterp │ │ │ │ │ += (EnumIntType) b; } │ │ │ │ │ +99 │ │ │ │ │ +_1_0_1 _C_r_e_a_s_i_n_g_M_e_t_h_o_d _G_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d() const { return (_C_r_e_a_s_i_n_g_M_e_t_h_o_d) │ │ │ │ │ +_creasingMethod; } │ │ │ │ │ 102 │ │ │ │ │ -112 template │ │ │ │ │ -113 void _C_o_m_p_u_t_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k(VERTEX const& vertexNeighborhood, MASK& │ │ │ │ │ -vertexVertexMask, │ │ │ │ │ -114 _C_r_e_a_s_e_:_:_R_u_l_e parentRule = _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N, │ │ │ │ │ -115 _C_r_e_a_s_e_:_:_R_u_l_e childRule = _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) const; │ │ │ │ │ -116 │ │ │ │ │ -141 template │ │ │ │ │ -142 void _C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k(VERTEX const& vertexNeighborhood, MASK& │ │ │ │ │ -positionMask, │ │ │ │ │ -143 _C_r_e_a_s_e_:_:_R_u_l_e vertexRule) const; │ │ │ │ │ -144 │ │ │ │ │ -145 template │ │ │ │ │ -146 void _C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k(VERTEX const& vertexNeighborhood, MASK& │ │ │ │ │ -positionMask, │ │ │ │ │ -147 MASK& tangent1Mask, MASK& tangent2Mask, │ │ │ │ │ -148 _C_r_e_a_s_e_:_:_R_u_l_e vertexRule) const; │ │ │ │ │ -149 │ │ │ │ │ -150 // │ │ │ │ │ -151 // Static methods defining traits/properties of the scheme: │ │ │ │ │ -152 // │ │ │ │ │ -_1_5_3 static _S_p_l_i_t _G_e_t_T_o_p_o_l_o_g_i_c_a_l_S_p_l_i_t_T_y_p_e(); │ │ │ │ │ -_1_5_4 static int _G_e_t_R_e_g_u_l_a_r_F_a_c_e_S_i_z_e(); │ │ │ │ │ -_1_5_5 static int _G_e_t_R_e_g_u_l_a_r_V_e_r_t_e_x_V_a_l_e_n_c_e(); │ │ │ │ │ -_1_5_6 static int _G_e_t_L_o_c_a_l_N_e_i_g_h_b_o_r_h_o_o_d_S_i_z_e(); │ │ │ │ │ -157 │ │ │ │ │ -158protected: │ │ │ │ │ -159 │ │ │ │ │ -160 // │ │ │ │ │ -161 // Supporting internal methods -- optionally implemented, depending on │ │ │ │ │ -specialization: │ │ │ │ │ -162 // │ │ │ │ │ -163 │ │ │ │ │ -164 // Subdivision/refinement masks -- two for edge-vertices and three for │ │ │ │ │ -vertex-vertices: │ │ │ │ │ -165 // │ │ │ │ │ -166 template │ │ │ │ │ -167 void _a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e(EDGE const& edge, MASK& mask) const; │ │ │ │ │ -168 template │ │ │ │ │ -_1_6_9 void _a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_E_d_g_e(EDGE const& edge, MASK& mask) const; │ │ │ │ │ -170 │ │ │ │ │ -171 template │ │ │ │ │ -172 void _a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& edge, MASK& mask) const; │ │ │ │ │ -173 template │ │ │ │ │ -_1_7_4 void _a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& edge, MASK& mask, int const │ │ │ │ │ -creaseEnds[2]) const; │ │ │ │ │ -175 template │ │ │ │ │ -_1_7_6 void _a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& edge, MASK& mask) const; │ │ │ │ │ -177 │ │ │ │ │ -178 // │ │ │ │ │ -179 // Limit masks for position and tangents at vertices -- three cases for │ │ │ │ │ -each: │ │ │ │ │ -180 // │ │ │ │ │ -181 template │ │ │ │ │ -_1_8_2 void _a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& pos) const; │ │ │ │ │ -183 template │ │ │ │ │ -_1_8_4 void _a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& pos, int const │ │ │ │ │ -creaseEnds[2]) const; │ │ │ │ │ -185 template │ │ │ │ │ -_1_8_6 void _a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& pos) const; │ │ │ │ │ -187 │ │ │ │ │ -188 template │ │ │ │ │ -_1_8_9 void _a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, MASK& tan1, MASK& │ │ │ │ │ -tan2) const; │ │ │ │ │ -190 template │ │ │ │ │ -_1_9_1 void _a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, MASK& tan1, MASK& │ │ │ │ │ -tan2, int const creaseEnds[2]) const; │ │ │ │ │ -192 template │ │ │ │ │ -_1_9_3 void _a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, MASK& tan1, MASK& │ │ │ │ │ -tan2) const; │ │ │ │ │ -194 │ │ │ │ │ -195private: │ │ │ │ │ -196 _O_p_t_i_o_n_s _options; │ │ │ │ │ -197 │ │ │ │ │ -198protected: │ │ │ │ │ -199 │ │ │ │ │ -200 // │ │ │ │ │ -201 // Internal implementation support: │ │ │ │ │ -202 // │ │ │ │ │ -203 // We need a local "mask" class to be declared locally within the vertex- │ │ │ │ │ -vertex mask query │ │ │ │ │ -204 // to hold one of the two possible masks required and to combine the local │ │ │ │ │ -mask with the mask │ │ │ │ │ -205 // the caller provides. It has been parameterized by so that a │ │ │ │ │ -version compatible │ │ │ │ │ -206 // with the caller's mask class is created. │ │ │ │ │ -207 // │ │ │ │ │ -208 template │ │ │ │ │ -_2_0_9 class _L_o_c_a_l_M_a_s_k { │ │ │ │ │ -210 │ │ │ │ │ -211 public: │ │ │ │ │ -_2_1_2 typedef WEIGHT _W_e_i_g_h_t; │ │ │ │ │ -213 │ │ │ │ │ -214 public: │ │ │ │ │ -_2_1_5 _L_o_c_a_l_M_a_s_k(_W_e_i_g_h_t* v, _W_e_i_g_h_t* e, _W_e_i_g_h_t* f) : _vWeights(v), _eWeights(e), │ │ │ │ │ -_fWeights(f) { } │ │ │ │ │ -_2_1_6 _~_L_o_c_a_l_M_a_s_k() { } │ │ │ │ │ -217 │ │ │ │ │ -218 public: │ │ │ │ │ -219 │ │ │ │ │ -220 // │ │ │ │ │ -221 // Methods required for general mask assignments and queries: │ │ │ │ │ -222 // │ │ │ │ │ -_2_2_3 int _G_e_t_N_u_m_V_e_r_t_e_x_W_e_i_g_h_t_s() const { return _vCount; } │ │ │ │ │ -_2_2_4 int _G_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s() const { return _eCount; } │ │ │ │ │ -_2_2_5 int _G_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s() const { return _fCount; } │ │ │ │ │ -226 │ │ │ │ │ -_2_2_7 void _S_e_t_N_u_m_V_e_r_t_e_x_W_e_i_g_h_t_s(int count) { _vCount = count; } │ │ │ │ │ -_2_2_8 void _S_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s( int count) { _eCount = count; } │ │ │ │ │ -_2_2_9 void _S_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s( int count) { _fCount = count; } │ │ │ │ │ -230 │ │ │ │ │ -_2_3_1 _W_e_i_g_h_t const& _V_e_r_t_e_x_W_e_i_g_h_t(int index) const { return _vWeights[index]; } │ │ │ │ │ -_2_3_2 _W_e_i_g_h_t const& _E_d_g_e_W_e_i_g_h_t( int index) const { return _eWeights[index]; } │ │ │ │ │ -_2_3_3 _W_e_i_g_h_t const& _F_a_c_e_W_e_i_g_h_t( int index) const { return _fWeights[index]; } │ │ │ │ │ -234 │ │ │ │ │ -_2_3_5 _W_e_i_g_h_t& _V_e_r_t_e_x_W_e_i_g_h_t(int index) { return _vWeights[index]; } │ │ │ │ │ -_2_3_6 _W_e_i_g_h_t& _E_d_g_e_W_e_i_g_h_t( int index) { return _eWeights[index]; } │ │ │ │ │ -_2_3_7 _W_e_i_g_h_t& _F_a_c_e_W_e_i_g_h_t( int index) { return _fWeights[index]; } │ │ │ │ │ -238 │ │ │ │ │ -_2_3_9 bool _A_r_e_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s() const { return _fWeightsForCenters; } │ │ │ │ │ -_2_4_0 void _S_e_t_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s(bool on) { _fWeightsForCenters = on; } │ │ │ │ │ -241 │ │ │ │ │ -242 public: │ │ │ │ │ -243 │ │ │ │ │ -244 // │ │ │ │ │ -245 // Additional methods -- mainly the blending method for vertex-vertex │ │ │ │ │ -masks: │ │ │ │ │ -246 // │ │ │ │ │ -247 template │ │ │ │ │ -248 inline void │ │ │ │ │ -_2_4_9 _C_o_m_b_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k_s(_W_e_i_g_h_t thisCoeff, _W_e_i_g_h_t dstCoeff, USER_MASK& dst) │ │ │ │ │ -const { │ │ │ │ │ -250 │ │ │ │ │ -251 // │ │ │ │ │ -252 // This implementation is convoluted by the potential sparsity of each │ │ │ │ │ -mask. Since │ │ │ │ │ -253 // it is specific to a vertex-vertex mask, we are guaranteed to have │ │ │ │ │ -exactly one │ │ │ │ │ -254 // vertex-weight for both masks, but the edge- and face-weights are │ │ │ │ │ -optional. The │ │ │ │ │ -255 // child mask (the "source") should have a superset of the weights of the │ │ │ │ │ -parent │ │ │ │ │ -256 // (the "destination") given its reduced sharpness, so we fortunately don't │ │ │ │ │ -need to │ │ │ │ │ -257 // test all permutations. │ │ │ │ │ -258 // │ │ │ │ │ -259 dst.VertexWeight(0) = dstCoeff * dst.VertexWeight(0) + thisCoeff * this- │ │ │ │ │ ->_V_e_r_t_e_x_W_e_i_g_h_t(0); │ │ │ │ │ -260 │ │ │ │ │ -261 int edgeWeightCount = this->_G_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s(); │ │ │ │ │ -262 if (edgeWeightCount) { │ │ │ │ │ -263 if (dst.GetNumEdgeWeights() == 0) { │ │ │ │ │ -264 dst.SetNumEdgeWeights(edgeWeightCount); │ │ │ │ │ -265 for (int i = 0; i < edgeWeightCount; ++i) { │ │ │ │ │ -266 dst.EdgeWeight(i) = thisCoeff * this->_E_d_g_e_W_e_i_g_h_t(i); │ │ │ │ │ -267 } │ │ │ │ │ -268 } else { │ │ │ │ │ -269 for (int i = 0; i < edgeWeightCount; ++i) { │ │ │ │ │ -270 dst.EdgeWeight(i) = dstCoeff * dst.EdgeWeight(i) + thisCoeff * this- │ │ │ │ │ ->_E_d_g_e_W_e_i_g_h_t(i); │ │ │ │ │ -271 } │ │ │ │ │ -272 } │ │ │ │ │ -273 } │ │ │ │ │ -274 │ │ │ │ │ -275 int faceWeightCount = this->_G_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s(); │ │ │ │ │ -276 if (faceWeightCount) { │ │ │ │ │ -277 // │ │ │ │ │ -278 // If combining face weights, be sure their interpretation (i.e. face- │ │ │ │ │ -centers │ │ │ │ │ -279 // or opposite vertices) is properly set in the destination mask: │ │ │ │ │ -280 // │ │ │ │ │ -281 if (dst.GetNumFaceWeights() == 0) { │ │ │ │ │ -282 dst.SetNumFaceWeights(faceWeightCount); │ │ │ │ │ -283 dst.SetFaceWeightsForFaceCenters(this->_A_r_e_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s()); │ │ │ │ │ -284 │ │ │ │ │ -285 for (int i = 0; i < faceWeightCount; ++i) { │ │ │ │ │ -286 dst.FaceWeight(i) = thisCoeff * this->_F_a_c_e_W_e_i_g_h_t(i); │ │ │ │ │ -287 } │ │ │ │ │ -288 } else { │ │ │ │ │ -289 assert(this->_A_r_e_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s() == │ │ │ │ │ -dst.AreFaceWeightsForFaceCenters()); │ │ │ │ │ -290 │ │ │ │ │ -291 for (int i = 0; i < faceWeightCount; ++i) { │ │ │ │ │ -292 dst.FaceWeight(i) = dstCoeff * dst.FaceWeight(i) + thisCoeff * this- │ │ │ │ │ ->_F_a_c_e_W_e_i_g_h_t(i); │ │ │ │ │ -293 } │ │ │ │ │ -294 } │ │ │ │ │ -295 } │ │ │ │ │ -296 } │ │ │ │ │ -297 │ │ │ │ │ -298 private: │ │ │ │ │ -299 _W_e_i_g_h_t* _vWeights; │ │ │ │ │ -300 _W_e_i_g_h_t* _eWeights; │ │ │ │ │ -301 _W_e_i_g_h_t* _fWeights; │ │ │ │ │ -302 int _vCount; │ │ │ │ │ -303 int _eCount; │ │ │ │ │ -304 int _fCount; │ │ │ │ │ -305 bool _fWeightsForCenters; │ │ │ │ │ -306 }; │ │ │ │ │ -307}; │ │ │ │ │ -308 │ │ │ │ │ -309 │ │ │ │ │ -310// │ │ │ │ │ -311// Crease and corner masks are common to most schemes -- the rest need to be │ │ │ │ │ -provided │ │ │ │ │ -312// for each Scheme specialization. │ │ │ │ │ -313// │ │ │ │ │ -314template │ │ │ │ │ -315template │ │ │ │ │ -316inline void │ │ │ │ │ -_3_1_7_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e(EDGE const&, MASK& mask) const { │ │ │ │ │ -318 │ │ │ │ │ -319 mask.SetNumVertexWeights(2); │ │ │ │ │ -320 mask.SetNumEdgeWeights(0); │ │ │ │ │ -321 mask.SetNumFaceWeights(0); │ │ │ │ │ -322 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -323 │ │ │ │ │ -324 mask.VertexWeight(0) = 0.5f; │ │ │ │ │ -325 mask.VertexWeight(1) = 0.5f; │ │ │ │ │ -326} │ │ │ │ │ -327 │ │ │ │ │ -328template │ │ │ │ │ -329template │ │ │ │ │ -330inline void │ │ │ │ │ -_3_3_1_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const&, MASK& mask) const { │ │ │ │ │ -332 │ │ │ │ │ -333 mask.SetNumVertexWeights(1); │ │ │ │ │ -334 mask.SetNumEdgeWeights(0); │ │ │ │ │ -335 mask.SetNumFaceWeights(0); │ │ │ │ │ -336 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -337 │ │ │ │ │ -338 mask.VertexWeight(0) = 1.0f; │ │ │ │ │ -339} │ │ │ │ │ -340 │ │ │ │ │ -341 │ │ │ │ │ -342// │ │ │ │ │ -343// The computation of a face-vertex mask is trivial and consistent for all │ │ │ │ │ -schemes: │ │ │ │ │ -344// │ │ │ │ │ -345template │ │ │ │ │ -346template │ │ │ │ │ -347void │ │ │ │ │ -_3_4_8_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_F_a_c_e_V_e_r_t_e_x_M_a_s_k(FACE const& face, MASK& mask) const { │ │ │ │ │ -349 │ │ │ │ │ -350 int vertCount = face.GetNumVertices(); │ │ │ │ │ -351 │ │ │ │ │ -352 mask.SetNumVertexWeights(vertCount); │ │ │ │ │ -353 mask.SetNumEdgeWeights(0); │ │ │ │ │ -354 mask.SetNumFaceWeights(0); │ │ │ │ │ -355 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ -356 │ │ │ │ │ -357 typename MASK::Weight vWeight = 1.0f / (typename MASK::Weight) vertCount; │ │ │ │ │ -358 for (int i = 0; i < vertCount; ++i) { │ │ │ │ │ -359 mask.VertexWeight(i) = vWeight; │ │ │ │ │ -360 } │ │ │ │ │ -361} │ │ │ │ │ -362 │ │ │ │ │ -363 │ │ │ │ │ -364// │ │ │ │ │ -365// The computation of an edge-vertex mask requires inspection of sharpness │ │ │ │ │ -values to │ │ │ │ │ -366// determine if smooth or a crease, and also to detect and apply a │ │ │ │ │ -transition from a │ │ │ │ │ -367// crease to smooth. Using the protected methods to assign the specific │ │ │ │ │ -masks (only │ │ │ │ │ -368// two -- smooth or crease) this implementation should serve all non-linear │ │ │ │ │ -schemes │ │ │ │ │ -369// (currently Catmark and Loop) and only needs to be specialized for │ │ │ │ │ -Bilinear to │ │ │ │ │ -370// trivialize it to the crease case. │ │ │ │ │ -371// │ │ │ │ │ -372// The implementation here is slightly complicated by combining two │ │ │ │ │ -scenarios into a │ │ │ │ │ -373// single implementation -- either the caller knows the parent and child │ │ │ │ │ -rules and │ │ │ │ │ -374// provides them, or they don't and the Rules have to be determined from │ │ │ │ │ -sharpness │ │ │ │ │ -375// values. Both cases include quick return once the parent is determined to │ │ │ │ │ -be │ │ │ │ │ -376// smooth or the child a crease, leaving the transitional case remaining. │ │ │ │ │ -377// │ │ │ │ │ -378// The overall process is as follows: │ │ │ │ │ -379// │ │ │ │ │ -380// - quickly detect the most common specified or detected Smooth case and │ │ │ │ │ -return │ │ │ │ │ -381// - quickly detect a full Crease by child Rule assignment and return │ │ │ │ │ -382// - determine from sharpness if unspecified child is a crease -- return if │ │ │ │ │ -so │ │ │ │ │ -383// - compute smooth mask for child and combine with crease from parent │ │ │ │ │ -384// │ │ │ │ │ -385// Usage of the parent Rule here allows some misuse in that only three of │ │ │ │ │ -five possible │ │ │ │ │ -386// assignments are legitimate for the parent and four for the child (Dart │ │ │ │ │ -being only │ │ │ │ │ -387// valid for the child and Corner for neither). Results are undefined in │ │ │ │ │ -these cases. │ │ │ │ │ -388// │ │ │ │ │ -389template │ │ │ │ │ -390template │ │ │ │ │ -391void │ │ │ │ │ -_3_9_2_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_E_d_g_e_V_e_r_t_e_x_M_a_s_k(EDGE const& edge, │ │ │ │ │ -393 MASK& mask, │ │ │ │ │ -394 _C_r_e_a_s_e_:_:_R_u_l_e parentRule, │ │ │ │ │ -395 _C_r_e_a_s_e_:_:_R_u_l_e childRule) const { │ │ │ │ │ -396 │ │ │ │ │ -397 // │ │ │ │ │ -398 // If the parent was specified or determined to be Smooth, we can quickly │ │ │ │ │ -return │ │ │ │ │ -399 // with a Smooth mask. Otherwise the parent is a crease -- if the child was │ │ │ │ │ -400 // also specified to be a crease, we can quickly return with a Crease mask. │ │ │ │ │ -401 // │ │ │ │ │ -402 if ((parentRule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || │ │ │ │ │ -403 ((parentRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) && (edge.GetSharpness() <= 0.0f))) { │ │ │ │ │ -404 assignSmoothMaskForEdge(edge, mask); │ │ │ │ │ -405 return; │ │ │ │ │ -406 } │ │ │ │ │ -407 if (childRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ -408 assignCreaseMaskForEdge(edge, mask); │ │ │ │ │ -409 return; │ │ │ │ │ -410 } │ │ │ │ │ -411 │ │ │ │ │ -412 // │ │ │ │ │ -413 // We have a Crease on the parent and the child was either specified as │ │ │ │ │ -Smooth │ │ │ │ │ -414 // or was not specified at all -- deal with the unspecified case first │ │ │ │ │ -(again │ │ │ │ │ -415 // returning a Crease mask if the child is also determined to be a Crease) │ │ │ │ │ -and │ │ │ │ │ -416 // continue if we have a transition to Smooth. │ │ │ │ │ -417 // │ │ │ │ │ -418 // Note when qualifying the child that if the parent sharpness > 1.0, │ │ │ │ │ -regardless │ │ │ │ │ -419 // of the creasing method, whether the child sharpness values decay to zero │ │ │ │ │ -is │ │ │ │ │ -420 // irrelevant -- the fractional weight for such a case (the value of the │ │ │ │ │ -parent │ │ │ │ │ -421 // sharpness) is > 1.0, and when clamped to 1 effectively yields a full │ │ │ │ │ -crease. │ │ │ │ │ -422 // │ │ │ │ │ -423 if (childRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) { │ │ │ │ │ -424 _C_r_e_a_s_e crease(_options); │ │ │ │ │ -425 │ │ │ │ │ -426 bool childIsCrease = false; │ │ │ │ │ -427 if (parentRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ -428 // Child unknown as default value but parent Rule specified as Crease │ │ │ │ │ -429 childIsCrease = true; │ │ │ │ │ -430 } else if (edge.GetSharpness() >= 1.0f) { │ │ │ │ │ -431 // Sharpness >= 1.0 always a crease -- see note above │ │ │ │ │ -432 childIsCrease = true; │ │ │ │ │ -433 } else if (crease._I_s_U_n_i_f_o_r_m()) { │ │ │ │ │ -434 // Sharpness < 1.0 is guaranteed to decay to 0.0 for Uniform child edges │ │ │ │ │ -435 childIsCrease = false; │ │ │ │ │ -436 } else { │ │ │ │ │ -437 // Sharpness <= 1.0 does not necessarily decay to 0.0 for both child │ │ │ │ │ -edges... │ │ │ │ │ -438 float cEdgeSharpness[2]; │ │ │ │ │ -439 edge.GetChildSharpnesses(crease, cEdgeSharpness); │ │ │ │ │ -440 childIsCrease = (cEdgeSharpness[0] > 0.0f) && (cEdgeSharpness[1] > 0.0f); │ │ │ │ │ -441 } │ │ │ │ │ -442 if (childIsCrease) { │ │ │ │ │ -443 assignCreaseMaskForEdge(edge, mask); │ │ │ │ │ -444 return; │ │ │ │ │ -445 } │ │ │ │ │ -446 } │ │ │ │ │ -447 │ │ │ │ │ -448 // │ │ │ │ │ -449 // We are now left with the Crease-to-Smooth case -- compute the Smooth │ │ │ │ │ -mask │ │ │ │ │ -450 // for the child and augment it with the transitional Crease of the parent. │ │ │ │ │ -451 // │ │ │ │ │ -452 // A general combination of separately assigned masks here (as done in the │ │ │ │ │ -vertex- │ │ │ │ │ -453 // vertex case) is overkill -- trivially combine the 0.5f vertex │ │ │ │ │ -coefficient for │ │ │ │ │ -454 // the Crease of the parent with the vertex weights and attenuate the face │ │ │ │ │ -weights │ │ │ │ │ -455 // accordingly. │ │ │ │ │ -456 // │ │ │ │ │ -457 assignSmoothMaskForEdge(edge, mask); │ │ │ │ │ -458 │ │ │ │ │ -459 typedef typename MASK::Weight Weight; │ │ │ │ │ -460 │ │ │ │ │ -461 Weight pWeight = edge.GetSharpness(); │ │ │ │ │ -462 Weight cWeight = 1.0f - pWeight; │ │ │ │ │ -463 │ │ │ │ │ -464 mask.VertexWeight(0) = pWeight * 0.5f + cWeight * mask.VertexWeight(0); │ │ │ │ │ -465 mask.VertexWeight(1) = pWeight * 0.5f + cWeight * mask.VertexWeight(1); │ │ │ │ │ -466 │ │ │ │ │ -467 int faceCount = mask.GetNumFaceWeights(); │ │ │ │ │ -468 for (int i = 0; i < faceCount; ++i) { │ │ │ │ │ -469 mask.FaceWeight(i) *= cWeight; │ │ │ │ │ -470 } │ │ │ │ │ -471} │ │ │ │ │ -472 │ │ │ │ │ -473// │ │ │ │ │ -474// The computation of a vertex-vertex mask requires inspection of creasing │ │ │ │ │ -sharpness values │ │ │ │ │ -475// to determine what subdivision Rules apply to the parent and its child │ │ │ │ │ -vertex, and also to │ │ │ │ │ -476// detect and apply a transition between two differing Rules. Using the │ │ │ │ │ -protected methods to │ │ │ │ │ -477// assign specific masks, this implementation should serve all non-linear │ │ │ │ │ -schemes (currently │ │ │ │ │ -478// Catmark and Loop) and only needs to be specialized for Bilinear to remove │ │ │ │ │ -all unnecessary │ │ │ │ │ -479// complexity relating to creasing, Rules, etc. │ │ │ │ │ -480// │ │ │ │ │ -481// The implementation here is slightly complicated by combining two │ │ │ │ │ -scenarios into one -- │ │ │ │ │ -482// either the caller knows the parent and child rules and provides them, or │ │ │ │ │ -they don't and │ │ │ │ │ -483// the Rules have to be determined from sharpness values. Even when the │ │ │ │ │ -Rules are known and │ │ │ │ │ -484// provided though, there are cases where the parent and child sharpness │ │ │ │ │ -values need to be │ │ │ │ │ -485// identified, so accounting for the unknown Rules too is not much of an │ │ │ │ │ -added complication. │ │ │ │ │ -486// │ │ │ │ │ -487// The benefit of supporting specified Rules is that they can often be │ │ │ │ │ -trivially │ │ │ │ │ -488// determined from context (e.g. a vertex derived from a face at a previous │ │ │ │ │ -level will always │ │ │ │ │ -489// be smooth) rather than more generally, and at greater cost, inspecting │ │ │ │ │ -neighboring and │ │ │ │ │ -490// they are often the same for parent and child. │ │ │ │ │ -491// │ │ │ │ │ -492// The overall process is as follows: │ │ │ │ │ -493// │ │ │ │ │ -494// - quickly detect the most common Smooth case when specified and return │ │ │ │ │ -495// - determine if sharpness for parent is required and gather if so │ │ │ │ │ -496// - if unspecified, determine the parent rule │ │ │ │ │ -497// - assign mask for the parent rule -- returning if Smooth/Dart │ │ │ │ │ -498// - return if child rule matches parent │ │ │ │ │ -499// - gather sharpness for child to determine or combine child rule │ │ │ │ │ -500// - if unspecified, determine the child rule, returning if it matches │ │ │ │ │ -parent │ │ │ │ │ -501// - assign local mask for child rule │ │ │ │ │ -502// - combine local child mask with the parent mask │ │ │ │ │ -503// │ │ │ │ │ -504// Remember -- if the parent rule is specified but the child is not, this │ │ │ │ │ -implies only one │ │ │ │ │ -505// of the two optional rules was specified and is meant to indicate there is │ │ │ │ │ -no transition, │ │ │ │ │ -506// so the child rule should be assigned to be the same (wish the compiler │ │ │ │ │ -would allow this │ │ │ │ │ -507// in default value assignment). │ │ │ │ │ -508// │ │ │ │ │ -509template │ │ │ │ │ -510template │ │ │ │ │ -511void │ │ │ │ │ -_5_1_2_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k(VERTEX const& vertex, │ │ │ │ │ -513 MASK& mask, │ │ │ │ │ -514 _C_r_e_a_s_e_:_:_R_u_l_e pRule, │ │ │ │ │ -515 _C_r_e_a_s_e_:_:_R_u_l_e cRule) const { │ │ │ │ │ -516 │ │ │ │ │ -517 // Quick assignment and return for the most common case: │ │ │ │ │ -518 if ((pRule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ -519 assignSmoothMaskForVertex(vertex, mask); │ │ │ │ │ -520 return; │ │ │ │ │ -521 } │ │ │ │ │ -522 // If unspecified, assign the child rule to match the parent rule if │ │ │ │ │ -specified: │ │ │ │ │ -523 if ((cRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) && (pRule != _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N)) { │ │ │ │ │ -524 cRule = pRule; │ │ │ │ │ -525 } │ │ │ │ │ -526 int valence = vertex.GetNumEdges(); │ │ │ │ │ -527 │ │ │ │ │ -528 // │ │ │ │ │ -529 // Determine if we need the parent edge sharpness values -- identify/gather │ │ │ │ │ -if so │ │ │ │ │ -530 // and use it to compute the parent rule if unspecified: │ │ │ │ │ -531 // │ │ │ │ │ -532 float * pEdgeSharpnessBuffer = (float *)alloca(valence*sizeof(float)), │ │ │ │ │ -533 * pEdgeSharpness = 0, │ │ │ │ │ -534 pVertexSharpness = 0.0f; │ │ │ │ │ -535 │ │ │ │ │ -536 bool requireParentSharpness = (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) || │ │ │ │ │ -537 (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) || │ │ │ │ │ -538 (pRule != cRule); │ │ │ │ │ -539 if (requireParentSharpness) { │ │ │ │ │ -540 pVertexSharpness = vertex.GetSharpness(); │ │ │ │ │ -541 pEdgeSharpness = vertex.GetSharpnessPerEdge(pEdgeSharpnessBuffer); │ │ │ │ │ -542 │ │ │ │ │ -543 if (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) { │ │ │ │ │ -544 pRule = _C_r_e_a_s_e(_options)._D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e(pVertexSharpness, │ │ │ │ │ -valence, pEdgeSharpness); │ │ │ │ │ -545 } │ │ │ │ │ -546 } │ │ │ │ │ -547 if ((pRule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ -548 assignSmoothMaskForVertex(vertex, mask); │ │ │ │ │ -549 return; // As done on entry, we can return immediately if parent is Smooth/ │ │ │ │ │ -Dart │ │ │ │ │ -550 } else if (pRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ -551 int creaseEnds[2]; │ │ │ │ │ -552 _C_r_e_a_s_e(_options)._G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(pEdgeSharpness, valence, │ │ │ │ │ -creaseEnds); │ │ │ │ │ -553 │ │ │ │ │ -554 assignCreaseMaskForVertex(vertex, mask, creaseEnds); │ │ │ │ │ -555 } else { │ │ │ │ │ -556 assignCornerMaskForVertex(vertex, mask); │ │ │ │ │ -557 } │ │ │ │ │ -558 if (cRule == pRule) return; │ │ │ │ │ -559 │ │ │ │ │ -560 // │ │ │ │ │ -561 // Identify/gather child sharpness to combine masks for the two differing │ │ │ │ │ -Rules: │ │ │ │ │ -562 // │ │ │ │ │ -563 _C_r_e_a_s_e crease(_options); │ │ │ │ │ -564 │ │ │ │ │ -565 float * cEdgeSharpnessBuffer = (float *)alloca(valence*sizeof(float)), │ │ │ │ │ -566 * cEdgeSharpness = vertex.GetChildSharpnessPerEdge(crease, │ │ │ │ │ -cEdgeSharpnessBuffer), │ │ │ │ │ -567 cVertexSharpness = vertex.GetChildSharpness(crease); │ │ │ │ │ -568 │ │ │ │ │ -569 if (cRule == _C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N) { │ │ │ │ │ -570 cRule = crease._D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e(cVertexSharpness, valence, │ │ │ │ │ -cEdgeSharpness); │ │ │ │ │ -571 if (cRule == pRule) return; │ │ │ │ │ -572 } │ │ │ │ │ -573 │ │ │ │ │ -574 // │ │ │ │ │ -575 // Initialize a local child mask, compute the fractional weight from parent │ │ │ │ │ -and child │ │ │ │ │ -576 // sharpness values and combine the two masks: │ │ │ │ │ -577 // │ │ │ │ │ -578 typedef typename MASK::Weight Weight; │ │ │ │ │ -579 │ │ │ │ │ -580 Weight * cMaskWeights = (Weight *)alloca((1 + 2 * valence)*sizeof(Weight)); │ │ │ │ │ -581 _L_o_c_a_l_M_a_s_k_<_W_e_i_g_h_t_> cMask(cMaskWeights, cMaskWeights + 1, cMaskWeights + 1 + │ │ │ │ │ -valence); │ │ │ │ │ -582 │ │ │ │ │ -583 if ((cRule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (cRule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ -584 assignSmoothMaskForVertex(vertex, cMask); │ │ │ │ │ -585 } else if (cRule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ -586 int creaseEnds[2]; │ │ │ │ │ -587 _C_r_e_a_s_e(_options)._G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(cEdgeSharpness, valence, │ │ │ │ │ -creaseEnds); │ │ │ │ │ -588 │ │ │ │ │ -589 assignCreaseMaskForVertex(vertex, cMask, creaseEnds); │ │ │ │ │ -590 } else { │ │ │ │ │ -591 assignCornerMaskForVertex(vertex, cMask); │ │ │ │ │ -592 } │ │ │ │ │ -593 │ │ │ │ │ -594 Weight pWeight = crease._C_o_m_p_u_t_e_F_r_a_c_t_i_o_n_a_l_W_e_i_g_h_t_A_t_V_e_r_t_e_x(pVertexSharpness, │ │ │ │ │ -cVertexSharpness, │ │ │ │ │ -595 valence, pEdgeSharpness, cEdgeSharpness); │ │ │ │ │ -596 Weight cWeight = 1.0f - pWeight; │ │ │ │ │ -597 │ │ │ │ │ -598 cMask._C_o_m_b_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k_s(cWeight, pWeight, mask); │ │ │ │ │ -599} │ │ │ │ │ -600 │ │ │ │ │ -601// │ │ │ │ │ -602// The computation of limit masks for vertices: │ │ │ │ │ -603// │ │ │ │ │ -604template │ │ │ │ │ -605template │ │ │ │ │ -606void │ │ │ │ │ -_6_0_7_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, │ │ │ │ │ -608 MASK& mask, │ │ │ │ │ -609 _C_r_e_a_s_e_:_:_R_u_l_e rule) const { │ │ │ │ │ -610 │ │ │ │ │ -611 if ((rule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (rule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ -612 assignSmoothLimitMask(vertex, mask); │ │ │ │ │ -613 } else if (rule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ -614 float * edgeSharpness = (float *)alloca(vertex.GetNumEdges() * sizeof │ │ │ │ │ -(float)); │ │ │ │ │ -615 vertex.GetSharpnessPerEdge(edgeSharpness); │ │ │ │ │ -616 │ │ │ │ │ -617 int creaseEnds[2]; │ │ │ │ │ -618 _C_r_e_a_s_e(_options)._G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(edgeSharpness, vertex.GetNumEdges │ │ │ │ │ -(), creaseEnds); │ │ │ │ │ -619 │ │ │ │ │ -620 assignCreaseLimitMask(vertex, mask, creaseEnds); │ │ │ │ │ -621 } else { │ │ │ │ │ -622 assignCornerLimitMask(vertex, mask); │ │ │ │ │ -623 } │ │ │ │ │ -624} │ │ │ │ │ -625 │ │ │ │ │ -626template │ │ │ │ │ -627template │ │ │ │ │ -628void │ │ │ │ │ -_6_2_9_S_c_h_e_m_e_<_S_C_H_E_M_E_>_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, │ │ │ │ │ -630 MASK& posMask, │ │ │ │ │ -631 MASK& tan1Mask, │ │ │ │ │ -632 MASK& tan2Mask, │ │ │ │ │ -633 _C_r_e_a_s_e_:_:_R_u_l_e rule) const { │ │ │ │ │ -634 │ │ │ │ │ -635 if ((rule == _C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H) || (rule == _C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T)) { │ │ │ │ │ -636 assignSmoothLimitMask(vertex, posMask); │ │ │ │ │ -637 assignSmoothLimitTangentMasks(vertex, tan1Mask, tan2Mask); │ │ │ │ │ -638 } else if (rule == _C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E) { │ │ │ │ │ -639 float * edgeSharpness = (float *)alloca(vertex.GetNumEdges() * sizeof │ │ │ │ │ -(float)); │ │ │ │ │ -640 vertex.GetSharpnessPerEdge(edgeSharpness); │ │ │ │ │ -641 │ │ │ │ │ -642 int creaseEnds[2]; │ │ │ │ │ -643 _C_r_e_a_s_e(_options)._G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(edgeSharpness, vertex.GetNumEdges │ │ │ │ │ -(), creaseEnds); │ │ │ │ │ -644 │ │ │ │ │ -645 assignCreaseLimitMask(vertex, posMask, creaseEnds); │ │ │ │ │ -646 assignCreaseLimitTangentMasks(vertex, tan1Mask, tan2Mask, creaseEnds); │ │ │ │ │ -647 } else { │ │ │ │ │ -648 assignCornerLimitMask(vertex, posMask); │ │ │ │ │ -649 assignCornerLimitTangentMasks(vertex, tan1Mask, tan2Mask); │ │ │ │ │ -650 } │ │ │ │ │ -651} │ │ │ │ │ -652 │ │ │ │ │ -653 │ │ │ │ │ -654} // end namespace sdc │ │ │ │ │ -655 │ │ │ │ │ -656} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -657using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -658} // end namespace OpenSubdiv │ │ │ │ │ -659 │ │ │ │ │ -660#endif /* OPENSUBDIV3_SDC_SCHEME_H */ │ │ │ │ │ +_1_0_4 void _S_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d(_C_r_e_a_s_i_n_g_M_e_t_h_o_d c) { _creasingMethod = (EnumIntType) │ │ │ │ │ +c; } │ │ │ │ │ +105 │ │ │ │ │ +_1_0_7 _T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n _G_e_t_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n() const { return │ │ │ │ │ +(_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n) _triangleSub; } │ │ │ │ │ +108 │ │ │ │ │ +_1_1_0 void _S_e_t_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n(_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n t) { _triangleSub = │ │ │ │ │ +(EnumIntType) t; } │ │ │ │ │ +111 │ │ │ │ │ +112private: │ │ │ │ │ +113 // Use a small integer type to pack these rather than bitfields: │ │ │ │ │ +114 typedef unsigned char EnumIntType; │ │ │ │ │ +115 │ │ │ │ │ +116 EnumIntType _vtxBoundInterp; │ │ │ │ │ +117 EnumIntType _fvarLinInterp; │ │ │ │ │ +118 EnumIntType _creasingMethod; │ │ │ │ │ +119 EnumIntType _triangleSub; │ │ │ │ │ +120}; │ │ │ │ │ +121 │ │ │ │ │ +122} // end namespace sdc │ │ │ │ │ +123 │ │ │ │ │ +124} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +125using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +126} // end namespace OpenSubdiv │ │ │ │ │ +127 │ │ │ │ │ +128#endif /* OPENSUBDIV3_SDC_OPTIONS_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_p_l_i_t │ │ │ │ │ -Split │ │ │ │ │ -Enumerated type for all face splitting schemes. │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e │ │ │ │ │ -Types, constants and utilities related to semi-sharp creasing – whose │ │ │ │ │ -implementation is independent o... │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ -Rule │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T │ │ │ │ │ -@ RULE_DART │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H │ │ │ │ │ -@ RULE_SMOOTH │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E │ │ │ │ │ -@ RULE_CREASE │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N │ │ │ │ │ -@ RULE_UNKNOWN │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e │ │ │ │ │ -void GetSharpEdgePairOfCrease(float const *incidentEdgeSharpness, int │ │ │ │ │ -incidentEdgeCount, int sharpEdgePair[2]) const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_2_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e │ │ │ │ │ -Rule DetermineVertexVertexRule(float vertexSharpness, int incidentEdgeCount, │ │ │ │ │ -float const *incidentEdgeSharpness) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_U_n_i_f_o_r_m │ │ │ │ │ -bool IsUniform() const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_C_o_m_p_u_t_e_F_r_a_c_t_i_o_n_a_l_W_e_i_g_h_t_A_t_V_e_r_t_e_x │ │ │ │ │ -float ComputeFractionalWeightAtVertex(float vertexSharpness, float │ │ │ │ │ -childVertexSharpness, int incidentEdgeCount, float const │ │ │ │ │ -*incidentEdgeSharpness, float const *childEdgesSharpness) const │ │ │ │ │ -Transitional weighting: When the rules applicable to a parent vertex and its │ │ │ │ │ -child differ,... │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s │ │ │ │ │ All supported options applying to subdivision scheme. │ │ │ │ │ DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e │ │ │ │ │ -Scheme is a class template which provides all implementation for the │ │ │ │ │ -subdivision schemes supported by... │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_E_d_g_e │ │ │ │ │ -void assignSmoothMaskForEdge(EDGE const &edge, MASK &mask) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_T_o_p_o_l_o_g_i_c_a_l_S_p_l_i_t_T_y_p_e │ │ │ │ │ -static Split GetTopologicalSplitType() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ -void assignCreaseMaskForVertex(VERTEX const &edge, MASK &mask, int const │ │ │ │ │ -creaseEnds[2]) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k │ │ │ │ │ -void ComputeVertexVertexMask(VERTEX const &vertexNeighborhood, MASK │ │ │ │ │ -&vertexVertexMask, Crease::Rule parentRule=Crease::RULE_UNKNOWN, Crease::Rule │ │ │ │ │ -childRule=Crease::RULE_UNKNOWN) const │ │ │ │ │ -Vertex-vertex masks If known, a single Rule or pair of Rules can be specified │ │ │ │ │ -(indicating a crease tr... │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_5_1_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_C_o_m_p_u_t_e_V_e_r_t_e_x_L_i_m_i_t_M_a_s_k │ │ │ │ │ -void ComputeVertexLimitMask(VERTEX const &vertexNeighborhood, MASK │ │ │ │ │ -&positionMask, Crease::Rule vertexRule) const │ │ │ │ │ -Limit masks for vertices – position and tangents These presume that a vertex │ │ │ │ │ -is suitably isolated for... │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_6_0_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ -void assignCreaseLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ -&tan2, int const creaseEnds[2]) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_R_e_g_u_l_a_r_F_a_c_e_S_i_z_e │ │ │ │ │ -static int GetRegularFaceSize() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e │ │ │ │ │ -void assignCreaseMaskForEdge(EDGE const &edge, MASK &mask) const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_1_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_C_o_m_p_u_t_e_E_d_g_e_V_e_r_t_e_x_M_a_s_k │ │ │ │ │ -void ComputeEdgeVertexMask(EDGE const &edgeNeighborhood, MASK &edgeVertexMask, │ │ │ │ │ -Crease::Rule parentRule=Crease::RULE_UNKNOWN, Crease::Rule childRule=Crease:: │ │ │ │ │ -RULE_UNKNOWN) const │ │ │ │ │ -Edge-vertex masks If known, the Rule for the edge and/or the derived vertex can │ │ │ │ │ -be specified to accel... │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_9_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_S_c_h_e_m_e │ │ │ │ │ -Scheme() │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_7_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_M_a_s_k │ │ │ │ │ -void assignSmoothLimitMask(VERTEX const &vertex, MASK &pos) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_L_o_c_a_l_N_e_i_g_h_b_o_r_h_o_o_d_S_i_z_e │ │ │ │ │ -static int GetLocalNeighborhoodSize() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ -void assignCornerMaskForVertex(VERTEX const &edge, MASK &mask) const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_3_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_M_a_s_k │ │ │ │ │ -void assignCreaseLimitMask(VERTEX const &vertex, MASK &pos, int const │ │ │ │ │ -creaseEnds[2]) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ -void assignSmoothMaskForVertex(VERTEX const &edge, MASK &mask) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_R_e_g_u_l_a_r_V_e_r_t_e_x_V_a_l_e_n_c_e │ │ │ │ │ -static int GetRegularVertexValence() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_O_p_t_i_o_n_s │ │ │ │ │ -Options GetOptions() const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_7_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ -void assignSmoothLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ -&tan2) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_M_a_s_k │ │ │ │ │ -void assignCornerLimitMask(VERTEX const &vertex, MASK &pos) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_S_c_h_e_m_e │ │ │ │ │ -Scheme(Options const &options) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_C_o_m_p_u_t_e_F_a_c_e_V_e_r_t_e_x_M_a_s_k │ │ │ │ │ -void ComputeFaceVertexMask(FACE const &faceNeighborhood, MASK &faceVertexMask) │ │ │ │ │ -const │ │ │ │ │ -Face-vertex masks - trivial for all current schemes. │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ -void assignCornerLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ -&tan2) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_S_e_t_O_p_t_i_o_n_s │ │ │ │ │ -void SetOptions(const Options &newOptions) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_7_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_0_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_W_e_i_g_h_t │ │ │ │ │ -WEIGHT Weight │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_1_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_: │ │ │ │ │ -_A_r_e_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s │ │ │ │ │ -bool AreFaceWeightsForFaceCenters() const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_S_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s │ │ │ │ │ -void SetNumEdgeWeights(int count) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_E_d_g_e_W_e_i_g_h_t │ │ │ │ │ -Weight const & EdgeWeight(int index) const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_E_d_g_e_W_e_i_g_h_t │ │ │ │ │ -Weight & EdgeWeight(int index) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_: │ │ │ │ │ -_C_o_m_b_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_M_a_s_k_s │ │ │ │ │ -void CombineVertexVertexMasks(Weight thisCoeff, Weight dstCoeff, USER_MASK │ │ │ │ │ -&dst) const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_4_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_G_e_t_N_u_m_V_e_r_t_e_x_W_e_i_g_h_t_s │ │ │ │ │ -int GetNumVertexWeights() const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_S_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s │ │ │ │ │ -void SetNumFaceWeights(int count) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_F_a_c_e_W_e_i_g_h_t │ │ │ │ │ -Weight const & FaceWeight(int index) const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_G_e_t_N_u_m_E_d_g_e_W_e_i_g_h_t_s │ │ │ │ │ -int GetNumEdgeWeights() const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_V_e_r_t_e_x_W_e_i_g_h_t │ │ │ │ │ -Weight & VertexWeight(int index) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_G_e_t_N_u_m_F_a_c_e_W_e_i_g_h_t_s │ │ │ │ │ -int GetNumFaceWeights() const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_: │ │ │ │ │ -_S_e_t_F_a_c_e_W_e_i_g_h_t_s_F_o_r_F_a_c_e_C_e_n_t_e_r_s │ │ │ │ │ -void SetFaceWeightsForFaceCenters(bool on) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_S_e_t_N_u_m_V_e_r_t_e_x_W_e_i_g_h_t_s │ │ │ │ │ -void SetNumVertexWeights(int count) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_2_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_L_o_c_a_l_M_a_s_k │ │ │ │ │ -LocalMask(Weight *v, Weight *e, Weight *f) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_1_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_V_e_r_t_e_x_W_e_i_g_h_t │ │ │ │ │ -Weight const & VertexWeight(int index) const │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_F_a_c_e_W_e_i_g_h_t │ │ │ │ │ -Weight & FaceWeight(int index) │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_3_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_L_o_c_a_l_M_a_s_k_:_:_~_L_o_c_a_l_M_a_s_k │ │ │ │ │ -~LocalMask() │ │ │ │ │ -DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_2_1_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n │ │ │ │ │ +TriangleSubdivision │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_T_R_I___S_U_B___C_A_T_M_A_R_K │ │ │ │ │ +@ TRI_SUB_CATMARK │ │ │ │ │ +Catmark weights (Catmark scheme only) │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_T_R_I___S_U_B___S_M_O_O_T_H │ │ │ │ │ +@ TRI_SUB_SMOOTH │ │ │ │ │ +"smooth triangle" weights (Catmark scheme only) │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_C_r_e_a_s_i_n_g_M_e_t_h_o_d │ │ │ │ │ +CreasingMethod │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_C_R_E_A_S_E___U_N_I_F_O_R_M │ │ │ │ │ +@ CREASE_UNIFORM │ │ │ │ │ +Catmark rule. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_C_R_E_A_S_E___C_H_A_I_K_I_N │ │ │ │ │ +@ CREASE_CHAIKIN │ │ │ │ │ +Chaikin rule. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n │ │ │ │ │ +TriangleSubdivision GetTriangleSubdivision() const │ │ │ │ │ +Get triangle subdivision weights rule (Catmark scheme only !) │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_0_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d │ │ │ │ │ +CreasingMethod GetCreasingMethod() const │ │ │ │ │ +Get edge crease rule. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_0_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_O_p_t_i_o_n_s │ │ │ │ │ +Options() │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_S_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +void SetFVarLinearInterpolation(FVarLinearInterpolation b) │ │ │ │ │ +Set face-varying interpolation rule. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_S_e_t_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n │ │ │ │ │ +void SetTriangleSubdivision(TriangleSubdivision t) │ │ │ │ │ +Set triangle subdivision weights rule (Catmark scheme only !) │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_1_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +VtxBoundaryInterpolation GetVtxBoundaryInterpolation() const │ │ │ │ │ +Get vertex boundary interpolation rule. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_8_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +FVarLinearInterpolation │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___O_N_L_Y │ │ │ │ │ +@ FVAR_LINEAR_CORNERS_ONLY │ │ │ │ │ +sharpen corners only │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___B_O_U_N_D_A_R_I_E_S │ │ │ │ │ +@ FVAR_LINEAR_BOUNDARIES │ │ │ │ │ +sharpen all boundaries ("always sharp") │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___P_L_U_S_2 │ │ │ │ │ +@ FVAR_LINEAR_CORNERS_PLUS2 │ │ │ │ │ +("edge and corner + propagate corner") │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___P_L_U_S_1 │ │ │ │ │ +@ FVAR_LINEAR_CORNERS_PLUS1 │ │ │ │ │ +("edge corner") │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___A_L_L │ │ │ │ │ +@ FVAR_LINEAR_ALL │ │ │ │ │ +bilinear interpolation ("bilinear") │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___N_O_N_E │ │ │ │ │ +@ FVAR_LINEAR_NONE │ │ │ │ │ +smooth everywhere ("edge only") │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_S_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +void SetVtxBoundaryInterpolation(VtxBoundaryInterpolation b) │ │ │ │ │ +Set vertex boundary interpolation rule. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_9_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +FVarLinearInterpolation GetFVarLinearInterpolation() const │ │ │ │ │ +Get face-varying interpolation rule. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_9_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ +VtxBoundaryInterpolation │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_T_X___B_O_U_N_D_A_R_Y___N_O_N_E │ │ │ │ │ +@ VTX_BOUNDARY_NONE │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___O_N_L_Y │ │ │ │ │ +@ VTX_BOUNDARY_EDGE_ONLY │ │ │ │ │ +all boundary edges sharpened and interpolated │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___A_N_D___C_O_R_N_E_R │ │ │ │ │ +@ VTX_BOUNDARY_EDGE_AND_CORNER │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_S_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d │ │ │ │ │ +void SetCreasingMethod(CreasingMethod c) │ │ │ │ │ +Set edge crease rule. │ │ │ │ │ +DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_0_4 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _s_d_c │ │ │ │ │ - * _s_c_h_e_m_e_._h │ │ │ │ │ + * _o_p_t_i_o_n_s_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00776.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/sdc/crease.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/sdc/loopScheme.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -88,43 +88,38 @@ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ -Classes | │ │ │ │ Namespaces
│ │ │ │ -
crease.h File Reference
│ │ │ │ +
loopScheme.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/options.h"
│ │ │ │ +#include "../sdc/scheme.h"
│ │ │ │ +#include <cassert>
│ │ │ │ +#include <cmath>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -

│ │ │ │ -Classes

class  Crease
 Types, constants and utilities related to semi-sharp creasing – whose implementation is independent of the subdivision scheme. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Sdc
 
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,25 +1,22 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -crease.h File Reference │ │ │ │ │ +_N_a_m_e_s_p_a_c_e_s │ │ │ │ │ +loopScheme.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ +#include "_._._/_s_d_c_/_s_c_h_e_m_e_._h" │ │ │ │ │ +#include │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ -CCllaasssseess │ │ │ │ │ -class   _C_r_e_a_s_e │ │ │ │ │ -  Types, constants and utilities related to semi-sharp creasing – whose │ │ │ │ │ - implementation is independent of the subdivision scheme. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _s_d_c │ │ │ │ │ - * _c_r_e_a_s_e_._h │ │ │ │ │ + * _l_o_o_p_S_c_h_e_m_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00776_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/sdc/crease.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/sdc/loopScheme.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ -
crease.h
│ │ │ │ +
loopScheme.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2014 DreamWorks Animation LLC.
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -118,221 +118,618 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24#ifndef OPENSUBDIV3_SDC_CREASE_H
│ │ │ │ -
25#define OPENSUBDIV3_SDC_CREASE_H
│ │ │ │ +
24#ifndef OPENSUBDIV3_SDC_LOOP_SCHEME_H
│ │ │ │ +
25#define OPENSUBDIV3_SDC_LOOP_SCHEME_H
│ │ │ │
26
│ │ │ │
27#include "../version.h"
│ │ │ │
28
│ │ │ │ -
29#include "../sdc/options.h"
│ │ │ │ +
29#include "../sdc/scheme.h"
│ │ │ │
30
│ │ │ │ -
31namespace OpenSubdiv {
│ │ │ │ -
32namespace OPENSUBDIV_VERSION {
│ │ │ │ +
31#include <cassert>
│ │ │ │ +
32#include <cmath>
│ │ │ │
33
│ │ │ │ -
34namespace Sdc {
│ │ │ │ -
35
│ │ │ │ -
61
│ │ │ │ -
│ │ │ │ -
62class Crease {
│ │ │ │ -
63public:
│ │ │ │ -
65
│ │ │ │ -
67 static float const SHARPNESS_SMOOTH; // = 0.0f, do we really need this?
│ │ │ │ -
68 static float const SHARPNESS_INFINITE; // = 10.0f;
│ │ │ │ -
69
│ │ │ │ -
70 static bool IsSmooth(float sharpness) { return sharpness <= SHARPNESS_SMOOTH; }
│ │ │ │ -
71 static bool IsSharp(float sharpness) { return sharpness > SHARPNESS_SMOOTH; }
│ │ │ │ -
72 static bool IsInfinite(float sharpness) { return sharpness >= SHARPNESS_INFINITE; }
│ │ │ │ -
73 static bool IsSemiSharp(float sharpness) { return (SHARPNESS_SMOOTH < sharpness) && (sharpness < SHARPNESS_INFINITE); }
│ │ │ │ -
75
│ │ │ │ -
│ │ │ │ -
82 enum Rule {
│ │ │ │ - │ │ │ │ -
84 RULE_SMOOTH = (1 << 0),
│ │ │ │ -
85 RULE_DART = (1 << 1),
│ │ │ │ -
86 RULE_CREASE = (1 << 2),
│ │ │ │ -
87 RULE_CORNER = (1 << 3)
│ │ │ │ -
88 };
│ │ │ │ -
│ │ │ │ -
89
│ │ │ │ -
90public:
│ │ │ │ -
91 Crease() : _options() { }
│ │ │ │ -
92 Crease(Options const& options) : _options(options) { }
│ │ │ │ -
93 ~Crease() { }
│ │ │ │ -
94
│ │ │ │ -
95 bool IsUniform() const { return _options.GetCreasingMethod() == Options::CREASE_UNIFORM; }
│ │ │ │ -
96
│ │ │ │ -
98
│ │ │ │ -
104 float SharpenBoundaryEdge(float edgeSharpness) const;
│ │ │ │ -
105 float SharpenBoundaryVertex(float edgeSharpness) const;
│ │ │ │ -
106
│ │ │ │ -
107 // For future consideration
│ │ │ │ -
108 //float SharpenNonManifoldEdge(float edgeSharpness) const;
│ │ │ │ -
109 //float SharpenNonManifoldVertex(float edgeSharpness) const;
│ │ │ │ +
34namespace OpenSubdiv {
│ │ │ │ +
35namespace OPENSUBDIV_VERSION {
│ │ │ │ +
36namespace Sdc {
│ │ │ │ +
37
│ │ │ │ +
38
│ │ │ │ +
39//
│ │ │ │ +
40// Specializations for Sdc::Scheme<SCHEME_LOOP>:
│ │ │ │ +
41//
│ │ │ │ +
42//
│ │ │ │ +
43
│ │ │ │ +
44//
│ │ │ │ +
45// Loop traits:
│ │ │ │ +
46//
│ │ │ │ +
47template <>
│ │ │ │ + │ │ │ │ +
49
│ │ │ │ +
50template <>
│ │ │ │ + │ │ │ │ +
52
│ │ │ │ +
53template <>
│ │ │ │ + │ │ │ │ +
55
│ │ │ │ +
56template <>
│ │ │ │ + │ │ │ │ +
58
│ │ │ │ +
59
│ │ │ │ +
60//
│ │ │ │ +
61// Protected methods to assign the two types of masks for an edge-vertex --
│ │ │ │ +
62// Crease and Smooth.
│ │ │ │ +
63//
│ │ │ │ +
64// The Crease case does not really need to be specialized, though it may be
│ │ │ │ +
65// preferable to define all explicitly here.
│ │ │ │ +
66//
│ │ │ │ +
67template <>
│ │ │ │ +
68template <typename EDGE, typename MASK>
│ │ │ │ +
69inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
71{
│ │ │ │ +
72 mask.SetNumVertexWeights(2);
│ │ │ │ +
73 mask.SetNumEdgeWeights(0);
│ │ │ │ +
74 mask.SetNumFaceWeights(0);
│ │ │ │ +
75 mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
76
│ │ │ │ +
77 mask.VertexWeight(0) = 0.5f;
│ │ │ │ +
78 mask.VertexWeight(1) = 0.5f;
│ │ │ │ +
79}
│ │ │ │ +
│ │ │ │ +
80
│ │ │ │ +
81template <>
│ │ │ │ +
82template <typename EDGE, typename MASK>
│ │ │ │ +
83inline void
│ │ │ │ +
│ │ │ │ +
84Scheme<SCHEME_LOOP>::assignSmoothMaskForEdge(EDGE const& edge, MASK& mask) const
│ │ │ │ +
85{
│ │ │ │ +
86 int faceCount = edge.GetNumFaces();
│ │ │ │ +
87
│ │ │ │ +
88 mask.SetNumVertexWeights(2);
│ │ │ │ +
89 mask.SetNumEdgeWeights(0);
│ │ │ │ +
90 mask.SetNumFaceWeights(faceCount);
│ │ │ │ +
91 mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
92
│ │ │ │ +
93 //
│ │ │ │ +
94 // This is where we run into the issue of "face weights" -- we want to weight the
│ │ │ │ +
95 // face-centers for Catmark, but face-centers are not generated for Loop. So do
│ │ │ │ +
96 // we make assumptions on how the mask is used, assign some property to the mask
│ │ │ │ +
97 // to indicate how they were assigned, or take input from the mask itself?
│ │ │ │ +
98 //
│ │ │ │ +
99 // Regardless, we have two choices:
│ │ │ │ +
100 // - face-weights are for the vertices opposite the edge (as in Hbr):
│ │ │ │ +
101 // vertex weights = 0.375f;
│ │ │ │ +
102 // face weights = 0.125f;
│ │ │ │ +
103 //
│ │ │ │ +
104 // - face-weights are for the face centers:
│ │ │ │ +
105 // vertex weights = 0.125f;
│ │ │ │ +
106 // face weights = 0.375f;
│ │ │ │ +
107 //
│ │ │ │ +
108 // Coincidentally the coefficients are the same but reversed.
│ │ │ │ +
109 //
│ │ │ │ +
110 typedef typename MASK::Weight Weight;
│ │ │ │
111
│ │ │ │ -
113
│ │ │ │ -
124 float SubdivideUniformSharpness(float vertexOrEdgeSharpness) const;
│ │ │ │ -
125
│ │ │ │ -
126 float SubdivideVertexSharpness(float vertexSharpness) const;
│ │ │ │ -
127
│ │ │ │ -
128 float SubdivideEdgeSharpnessAtVertex(float edgeSharpness,
│ │ │ │ -
129 int incidentEdgeCountAtEndVertex,
│ │ │ │ -
130 float const* edgeSharpnessAroundEndVertex) const;
│ │ │ │ +
112 Weight vWeight = mask.AreFaceWeightsForFaceCenters() ? 0.125f : 0.375f;
│ │ │ │ +
113 Weight fWeight = mask.AreFaceWeightsForFaceCenters() ? 0.375f : 0.125f;
│ │ │ │ +
114
│ │ │ │ +
115 mask.VertexWeight(0) = vWeight;
│ │ │ │ +
116 mask.VertexWeight(1) = vWeight;
│ │ │ │ +
117
│ │ │ │ +
118 if (faceCount == 2) {
│ │ │ │ +
119 mask.FaceWeight(0) = fWeight;
│ │ │ │ +
120 mask.FaceWeight(1) = fWeight;
│ │ │ │ +
121 } else {
│ │ │ │ +
122 // The non-manifold case is not clearly defined -- we adjust the above
│ │ │ │ +
123 // face-weight to preserve the ratio of edge-center and face-centers:
│ │ │ │ +
124 fWeight *= 2.0f / (Weight) faceCount;
│ │ │ │ +
125 for (int i = 0; i < faceCount; ++i) {
│ │ │ │ +
126 mask.FaceWeight(i) = fWeight;
│ │ │ │ +
127 }
│ │ │ │ +
128 }
│ │ │ │ +
129}
│ │ │ │ +
│ │ │ │ +
130
│ │ │ │
131
│ │ │ │ -
132 void SubdivideEdgeSharpnessesAroundVertex(int incidentEdgeCountAtVertex,
│ │ │ │ -
133 float const* incidentEdgeSharpnessAroundVertex,
│ │ │ │ -
134 float* childEdgesSharpnessAroundVertex) const;
│ │ │ │ -
136
│ │ │ │ -
138
│ │ │ │ -
144 Rule DetermineVertexVertexRule(float vertexSharpness,
│ │ │ │ -
145 int incidentEdgeCount,
│ │ │ │ -
146 float const* incidentEdgeSharpness) const;
│ │ │ │ -
147 Rule DetermineVertexVertexRule(float vertexSharpness,
│ │ │ │ -
148 int sharpEdgeCount) const;
│ │ │ │ -
150
│ │ │ │ -
162 float ComputeFractionalWeightAtVertex(float vertexSharpness,
│ │ │ │ -
163 float childVertexSharpness,
│ │ │ │ -
164 int incidentEdgeCount,
│ │ │ │ -
165 float const* incidentEdgeSharpness,
│ │ │ │ -
166 float const* childEdgesSharpness) const;
│ │ │ │ -
167
│ │ │ │ -
168 void GetSharpEdgePairOfCrease(float const * incidentEdgeSharpness,
│ │ │ │ -
169 int incidentEdgeCount,
│ │ │ │ -
170 int sharpEdgePair[2]) const;
│ │ │ │ -
171
│ │ │ │ -
172 // Would these really help? Maybe only need Rules for the vertex-vertex case...
│ │ │ │ -
173 //
│ │ │ │ -
174 // Rule DetermineEdgeVertexRule(float parentEdgeSharpness) const;
│ │ │ │ -
175 // Rule DetermineEdgeVertexRule(float childEdge1Sharpness, float childEdge2Sharpness) const;
│ │ │ │ -
176
│ │ │ │ -
177protected:
│ │ │ │ -
178 float decrementSharpness(float sharpness) const;
│ │ │ │ -
179
│ │ │ │ -
180private:
│ │ │ │ -
181 Options _options;
│ │ │ │ -
182};
│ │ │ │ +
132//
│ │ │ │ +
133// Protected methods to assign the three types of masks for a vertex-vertex --
│ │ │ │ +
134// Corner, Crease and Smooth (Dart is the same as Smooth).
│ │ │ │ +
135//
│ │ │ │ +
136// Corner and Crease do not really need to be specialized, though it may be
│ │ │ │ +
137// preferable to define all explicitly here.
│ │ │ │ +
138//
│ │ │ │ +
139template <>
│ │ │ │ +
140template <typename VERTEX, typename MASK>
│ │ │ │ +
141inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
143{
│ │ │ │ +
144 mask.SetNumVertexWeights(1);
│ │ │ │ +
145 mask.SetNumEdgeWeights(0);
│ │ │ │ +
146 mask.SetNumFaceWeights(0);
│ │ │ │ +
147 mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
148
│ │ │ │ +
149 mask.VertexWeight(0) = 1.0f;
│ │ │ │ +
150}
│ │ │ │ +
│ │ │ │ +
151
│ │ │ │ +
152template <>
│ │ │ │ +
153template <typename VERTEX, typename MASK>
│ │ │ │ +
154inline void
│ │ │ │ +
│ │ │ │ +
155Scheme<SCHEME_LOOP>::assignCreaseMaskForVertex(VERTEX const& vertex, MASK& mask,
│ │ │ │ +
156 int const creaseEnds[2]) const {
│ │ │ │ +
157 typedef typename MASK::Weight Weight;
│ │ │ │ +
158
│ │ │ │ +
159 int valence = vertex.GetNumEdges();
│ │ │ │ +
160
│ │ │ │ +
161 mask.SetNumVertexWeights(1);
│ │ │ │ +
162 mask.SetNumEdgeWeights(valence);
│ │ │ │ +
163 mask.SetNumFaceWeights(0);
│ │ │ │ +
164 mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
165
│ │ │ │ +
166 Weight vWeight = 0.75f;
│ │ │ │ +
167 Weight eWeight = 0.125f;
│ │ │ │ +
168
│ │ │ │ +
169 mask.VertexWeight(0) = vWeight;
│ │ │ │ +
170 for (int i = 0; i < valence; ++i) {
│ │ │ │ +
171 mask.EdgeWeight(i) = 0.0f;
│ │ │ │ +
172 }
│ │ │ │ +
173 mask.EdgeWeight(creaseEnds[0]) = eWeight;
│ │ │ │ +
174 mask.EdgeWeight(creaseEnds[1]) = eWeight;
│ │ │ │ +
175}
│ │ │ │
│ │ │ │ +
176
│ │ │ │ +
177template <>
│ │ │ │ +
178template <typename VERTEX, typename MASK>
│ │ │ │ +
179inline void
│ │ │ │ +
│ │ │ │ +
180Scheme<SCHEME_LOOP>::assignSmoothMaskForVertex(VERTEX const& vertex, MASK& mask) const
│ │ │ │ +
181{
│ │ │ │ +
182 typedef typename MASK::Weight Weight;
│ │ │ │
183
│ │ │ │ -
184
│ │ │ │ -
185//
│ │ │ │ -
186// Inline declarations:
│ │ │ │ -
187//
│ │ │ │ -
188inline float
│ │ │ │ -
│ │ │ │ -
189Crease::SharpenBoundaryEdge(float /* edgeSharpness */) const {
│ │ │ │ +
184 int valence = vertex.GetNumFaces();
│ │ │ │ +
185
│ │ │ │ +
186 mask.SetNumVertexWeights(1);
│ │ │ │ +
187 mask.SetNumEdgeWeights(valence);
│ │ │ │ +
188 mask.SetNumFaceWeights(0);
│ │ │ │ +
189 mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │
190
│ │ │ │ -
191 //
│ │ │ │ -
192 // Despite the presence of the BOUNDARY_NONE option, boundary edges are always sharpened.
│ │ │ │ -
193 // Much of the code relies on sharpness to indicate boundaries to avoid the more complex
│ │ │ │ -
194 // topological inspection
│ │ │ │ -
195 //
│ │ │ │ -
196 return SHARPNESS_INFINITE;
│ │ │ │ -
197}
│ │ │ │ -
│ │ │ │ -
198
│ │ │ │ -
199inline float
│ │ │ │ -
│ │ │ │ -
200Crease::SharpenBoundaryVertex(float vertexSharpness) const {
│ │ │ │ -
201
│ │ │ │ - │ │ │ │ -
203 SHARPNESS_INFINITE : vertexSharpness;
│ │ │ │ -
204}
│ │ │ │ -
│ │ │ │ +
191 // Specialize for the regular case: 1/16 per edge-vert, 5/8 for the vert itself:
│ │ │ │ +
192 Weight eWeight = (Weight) 0.0625f;
│ │ │ │ +
193 Weight vWeight = (Weight) 0.625f;
│ │ │ │ +
194
│ │ │ │ +
195 if (valence != 6) {
│ │ │ │ +
196 // From HbrLoopSubdivision<T>::Subdivide(mesh, vertex):
│ │ │ │ +
197 // - could use some lookup tables here for common irregular valence (5, 7, 8)
│ │ │ │ +
198 // or all of these cosine calls will be adding up...
│ │ │ │ +
199
│ │ │ │ +
200 double dValence = (double) valence;
│ │ │ │ +
201 double invValence = 1.0f / dValence;
│ │ │ │ +
202 double cosTheta = std::cos(M_PI * 2.0f * invValence);
│ │ │ │ +
203
│ │ │ │ +
204 double beta = 0.25f * cosTheta + 0.375f;
│ │ │ │
205
│ │ │ │ -
206inline float
│ │ │ │ -
│ │ │ │ -
207Crease::decrementSharpness(float sharpness) const {
│ │ │ │ -
208
│ │ │ │ -
209 if (IsSmooth(sharpness)) return Crease::SHARPNESS_SMOOTH; // redundant but most common
│ │ │ │ -
210 if (IsInfinite(sharpness)) return Crease::SHARPNESS_INFINITE;
│ │ │ │ -
211 if (sharpness > 1.0f) return (sharpness - 1.0f);
│ │ │ │ - │ │ │ │ -
213}
│ │ │ │ -
│ │ │ │ -
214
│ │ │ │ -
215inline float
│ │ │ │ -
│ │ │ │ -
216Crease::SubdivideUniformSharpness(float vertexOrEdgeSharpness) const {
│ │ │ │ -
217
│ │ │ │ -
218 return decrementSharpness(vertexOrEdgeSharpness);
│ │ │ │ -
219}
│ │ │ │ -
│ │ │ │ -
220
│ │ │ │ -
221inline float
│ │ │ │ -
│ │ │ │ -
222Crease::SubdivideVertexSharpness(float vertexSharpness) const {
│ │ │ │ -
223
│ │ │ │ -
224 return decrementSharpness(vertexSharpness);
│ │ │ │ -
225}
│ │ │ │ -
│ │ │ │ -
226
│ │ │ │ -
227inline void
│ │ │ │ -
│ │ │ │ -
228Crease::GetSharpEdgePairOfCrease(float const * incidentEdgeSharpness, int incidentEdgeCount,
│ │ │ │ -
229 int sharpEdgePair[2]) const {
│ │ │ │ -
230
│ │ │ │ -
231 // Only to be called when a crease is present at a vertex -- exactly two sharp
│ │ │ │ -
232 // edges are expected here:
│ │ │ │ -
233 //
│ │ │ │ -
234 sharpEdgePair[0] = 0;
│ │ │ │ -
235 while (IsSmooth(incidentEdgeSharpness[sharpEdgePair[0]])) ++ sharpEdgePair[0];
│ │ │ │ -
236
│ │ │ │ -
237 sharpEdgePair[1] = incidentEdgeCount - 1;
│ │ │ │ -
238 while (IsSmooth(incidentEdgeSharpness[sharpEdgePair[1]])) -- sharpEdgePair[1];
│ │ │ │ -
239}
│ │ │ │ -
│ │ │ │ +
206 eWeight = (Weight) ((0.625f - (beta * beta)) * invValence);
│ │ │ │ +
207 vWeight = (Weight) (1.0f - (eWeight * dValence));
│ │ │ │ +
208 }
│ │ │ │ +
209
│ │ │ │ +
210 mask.VertexWeight(0) = vWeight;
│ │ │ │ +
211 for (int i = 0; i < valence; ++i) {
│ │ │ │ +
212 mask.EdgeWeight(i) = eWeight;
│ │ │ │ +
213 }
│ │ │ │ +
214}
│ │ │ │ +
│ │ │ │ +
215
│ │ │ │ +
216
│ │ │ │ +
217//
│ │ │ │ +
218// Limit masks for position:
│ │ │ │ +
219//
│ │ │ │ +
220template <>
│ │ │ │ +
221template <typename VERTEX, typename MASK>
│ │ │ │ +
222inline void
│ │ │ │ +
│ │ │ │ +
223Scheme<SCHEME_LOOP>::assignCornerLimitMask(VERTEX const& /* vertex */, MASK& posMask) const {
│ │ │ │ +
224
│ │ │ │ +
225 posMask.SetNumVertexWeights(1);
│ │ │ │ +
226 posMask.SetNumEdgeWeights(0);
│ │ │ │ +
227 posMask.SetNumFaceWeights(0);
│ │ │ │ +
228 posMask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
229
│ │ │ │ +
230 posMask.VertexWeight(0) = 1.0f;
│ │ │ │ +
231}
│ │ │ │ +
│ │ │ │ +
232
│ │ │ │ +
233template <>
│ │ │ │ +
234template <typename VERTEX, typename MASK>
│ │ │ │ +
235inline void
│ │ │ │ +
│ │ │ │ +
236Scheme<SCHEME_LOOP>::assignCreaseLimitMask(VERTEX const& vertex, MASK& posMask,
│ │ │ │ +
237 int const creaseEnds[2]) const {
│ │ │ │ +
238
│ │ │ │ +
239 typedef typename MASK::Weight Weight;
│ │ │ │
240
│ │ │ │ -
241} // end namespace sdc
│ │ │ │ +
241 int valence = vertex.GetNumEdges();
│ │ │ │
242
│ │ │ │ -
243} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
244using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
245} // end namespace OpenSubdiv
│ │ │ │ -
246
│ │ │ │ -
247#endif /* OPENSUBDIV3_SDC_CREASE_H */
│ │ │ │ - │ │ │ │ -
Types, constants and utilities related to semi-sharp creasing – whose implementation is independent o...
Definition crease.h:62
│ │ │ │ -
float SubdivideVertexSharpness(float vertexSharpness) const
Definition crease.h:222
│ │ │ │ -
static bool IsInfinite(float sharpness)
Definition crease.h:72
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
float SharpenBoundaryVertex(float edgeSharpness) const
Definition crease.h:200
│ │ │ │ - │ │ │ │ -
void GetSharpEdgePairOfCrease(float const *incidentEdgeSharpness, int incidentEdgeCount, int sharpEdgePair[2]) const
Definition crease.h:228
│ │ │ │ - │ │ │ │ -
Rule DetermineVertexVertexRule(float vertexSharpness, int incidentEdgeCount, float const *incidentEdgeSharpness) const
│ │ │ │ -
float decrementSharpness(float sharpness) const
Definition crease.h:207
│ │ │ │ -
static bool IsSmooth(float sharpness)
Definition crease.h:70
│ │ │ │ -
Rule DetermineVertexVertexRule(float vertexSharpness, int sharpEdgeCount) const
│ │ │ │ - │ │ │ │ -
static bool IsSemiSharp(float sharpness)
Definition crease.h:73
│ │ │ │ - │ │ │ │ -
void SubdivideEdgeSharpnessesAroundVertex(int incidentEdgeCountAtVertex, float const *incidentEdgeSharpnessAroundVertex, float *childEdgesSharpnessAroundVertex) const
│ │ │ │ -
float SubdivideUniformSharpness(float vertexOrEdgeSharpness) const
Definition crease.h:216
│ │ │ │ - │ │ │ │ -
float SharpenBoundaryEdge(float edgeSharpness) const
Definition crease.h:189
│ │ │ │ -
float ComputeFractionalWeightAtVertex(float vertexSharpness, float childVertexSharpness, int incidentEdgeCount, float const *incidentEdgeSharpness, float const *childEdgesSharpness) const
Transitional weighting: When the rules applicable to a parent vertex and its child differ,...
│ │ │ │ -
float SubdivideEdgeSharpnessAtVertex(float edgeSharpness, int incidentEdgeCountAtEndVertex, float const *edgeSharpnessAroundEndVertex) const
│ │ │ │ -
static bool IsSharp(float sharpness)
Definition crease.h:71
│ │ │ │ - │ │ │ │ -
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ - │ │ │ │ -
CreasingMethod GetCreasingMethod() const
Get edge crease rule.
Definition options.h:101
│ │ │ │ -
VtxBoundaryInterpolation GetVtxBoundaryInterpolation() const
Get vertex boundary interpolation rule.
Definition options.h:89
│ │ │ │ - │ │ │ │ +
243 posMask.SetNumVertexWeights(1);
│ │ │ │ +
244 posMask.SetNumEdgeWeights(valence);
│ │ │ │ +
245 posMask.SetNumFaceWeights(0);
│ │ │ │ +
246 posMask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
247
│ │ │ │ +
248 //
│ │ │ │ +
249 // The refinement mask for a crease vertex is (1/8, 3/4, 1/8) and for a crease
│ │ │ │ +
250 // edge is (1/2, 1/2) -- producing a uniform B-spline curve along the crease
│ │ │ │ +
251 // (boundary) whether the vertex or its crease is regular or not. The limit
│ │ │ │ +
252 // mask is therefore (1/6, 2/3, 1/6) for ALL cases.
│ │ │ │ +
253 //
│ │ │ │ +
254 // An alternative limit mask (1/5, 3/5, 1/5) is often published for use either
│ │ │ │ +
255 // for irregular crease vertices or for all crease/boundary vertices, but this
│ │ │ │ +
256 // is based on an alternate refinement mask for the edge -- (3/8, 5/8) versus
│ │ │ │ +
257 // the usual (1/2, 1/2) -- and will not produce the B-spline curve desired.
│ │ │ │ +
258 //
│ │ │ │ +
259 Weight vWeight = (Weight) (4.0 / 6.0);
│ │ │ │ +
260 Weight eWeight = (Weight) (1.0 / 6.0);
│ │ │ │ +
261
│ │ │ │ +
262 posMask.VertexWeight(0) = vWeight;
│ │ │ │ +
263 for (int i = 0; i < valence; ++i) {
│ │ │ │ +
264 posMask.EdgeWeight(i) = 0.0f;
│ │ │ │ +
265 }
│ │ │ │ +
266 posMask.EdgeWeight(creaseEnds[0]) = eWeight;
│ │ │ │ +
267 posMask.EdgeWeight(creaseEnds[1]) = eWeight;
│ │ │ │ +
268}
│ │ │ │ +
│ │ │ │ +
269
│ │ │ │ +
270template <>
│ │ │ │ +
271template <typename VERTEX, typename MASK>
│ │ │ │ +
272inline void
│ │ │ │ +
│ │ │ │ +
273Scheme<SCHEME_LOOP>::assignSmoothLimitMask(VERTEX const& vertex, MASK& posMask) const {
│ │ │ │ +
274
│ │ │ │ +
275 typedef typename MASK::Weight Weight;
│ │ │ │ +
276
│ │ │ │ +
277 int valence = vertex.GetNumFaces();
│ │ │ │ +
278
│ │ │ │ +
279 posMask.SetNumVertexWeights(1);
│ │ │ │ +
280 posMask.SetNumEdgeWeights(valence);
│ │ │ │ +
281 posMask.SetNumFaceWeights(0);
│ │ │ │ +
282 posMask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
283
│ │ │ │ +
284 // Specialize for the regular case: 1/12 per edge-vert, 1/2 for the vert itself:
│ │ │ │ +
285 if (valence == 6) {
│ │ │ │ +
286 Weight eWeight = (Weight) (1.0 / 12.0);
│ │ │ │ +
287 Weight vWeight = 0.5f;
│ │ │ │ +
288
│ │ │ │ +
289 posMask.VertexWeight(0) = vWeight;
│ │ │ │ +
290
│ │ │ │ +
291 posMask.EdgeWeight(0) = eWeight;
│ │ │ │ +
292 posMask.EdgeWeight(1) = eWeight;
│ │ │ │ +
293 posMask.EdgeWeight(2) = eWeight;
│ │ │ │ +
294 posMask.EdgeWeight(3) = eWeight;
│ │ │ │ +
295 posMask.EdgeWeight(4) = eWeight;
│ │ │ │ +
296 posMask.EdgeWeight(5) = eWeight;
│ │ │ │ +
297
│ │ │ │ +
298 } else {
│ │ │ │ +
299 double dValence = (double) valence;
│ │ │ │ +
300 double invValence = 1.0f / dValence;
│ │ │ │ +
301 double cosTheta = std::cos(M_PI * 2.0f * invValence);
│ │ │ │ +
302
│ │ │ │ +
303 double beta = 0.25f * cosTheta + 0.375f;
│ │ │ │ +
304 double gamma = (0.625f - (beta * beta)) * invValence;
│ │ │ │ +
305
│ │ │ │ +
306 Weight eWeight = (Weight) (1.0f / (dValence + 3.0f / (8.0f * gamma)));
│ │ │ │ +
307 Weight vWeight = (Weight) (1.0f - (eWeight * dValence));
│ │ │ │ +
308
│ │ │ │ +
309 posMask.VertexWeight(0) = vWeight;
│ │ │ │ +
310 for (int i = 0; i < valence; ++i) {
│ │ │ │ +
311 posMask.EdgeWeight(i) = eWeight;
│ │ │ │ +
312 }
│ │ │ │ +
313 }
│ │ │ │ +
314}
│ │ │ │ +
│ │ │ │ +
315
│ │ │ │ +
316/*
│ │ │ │ +
317// Limit masks for tangents:
│ │ │ │ +
318//
│ │ │ │ +
319// A note on tangent magnitudes:
│ │ │ │ +
320//
│ │ │ │ +
321// Several formulae exist for limit tangents at a vertex to accommodate the
│ │ │ │ +
322// different topological configurations around the vertex. While these produce
│ │ │ │ +
323// the desired direction, there is inconsistency in the resulting magnitudes.
│ │ │ │ +
324// Ideally a regular mesh of uniformly shaped triangles with similar edge lengths
│ │ │ │ +
325// should produce tangents of similar magnitudes throughout -- including corners
│ │ │ │ +
326// and boundaries. So some of the common formulae for these are adjusted with
│ │ │ │ +
327// scale factors.
│ │ │ │ +
328//
│ │ │ │ +
329// For uses where magnitude does not matter, this scaling should be irrelevant.
│ │ │ │ +
330// But just as with patches, where the magnitudes of partial derivatives are
│ │ │ │ +
331// consistent between similar patches, the magnitudes of limit tangents should
│ │ │ │ +
332// also be similar.
│ │ │ │ +
333//
│ │ │ │ +
334// The reference tangents, in terms of magnitudes, are those produced by the
│ │ │ │ +
335// limit tangent mask for smooth interior vertices, for which well established
│ │ │ │ +
336// sin/cos formulae apply -- these remain unscaled. Formulae for the other
│ │ │ │ +
337// crease/boundary, corner tangents and irregular cases are scaled to be more
│ │ │ │ +
338// consistent with these.
│ │ │ │ +
339//
│ │ │ │ +
340// The crease/boundary tangents for the regular case can be viewed as derived
│ │ │ │ +
341// from the smooth interior masks with two "phantom" points extrapolated across
│ │ │ │ +
342// the regular boundary:
│ │ │ │ +
343//
│ │ │ │ +
344// v3 v2
│ │ │ │ +
345// X - - - - - X
│ │ │ │ +
346// / \ / \
│ │ │ │ +
347// / \ / \
│ │ │ │ +
348// v4 X - - - - - X - - - - - X v1
│ │ │ │ +
349// . . 0 . .
│ │ │ │ +
350// . . . .
│ │ │ │ +
351// . . . .
│ │ │ │ +
352// (v5) (v6)
│ │ │ │ +
353//
│ │ │ │ +
354// where v5 = v0 + (v4 - v3) and v6 = v0 + v1 - v2.
│ │ │ │ +
355//
│ │ │ │ +
356// When the standard limit tangent mask is applied, the cosines of increments
│ │ │ │ +
357// of pi/3 give us coefficients that are multiples of 1/2, leading to the first
│ │ │ │ +
358// tangent T1 = 3/2 * (v1 - v4), rather than the widely used T1 = v1 - v4. So
│ │ │ │ +
359// this scale factor of 3/2 is applied to ensure tangents along the boundaries
│ │ │ │ +
360// are of similar magnitude as tangents in the immediate interior (which may be
│ │ │ │ +
361// parallel).
│ │ │ │ +
362//
│ │ │ │ +
363// Tangents at corners are essentially a form of boundary tangent, and so its
│ │ │ │ +
364// simple difference formula is scaled to be consistent with adjoining boundary
│ │ │ │ +
365// tangents -- not just with the 3/2 factor from above, but with an additional
│ │ │ │ +
366// 2.0 to compensate for the fact that the difference of only side of the vertex
│ │ │ │ +
367// is considered here. The resulting scale factor of 3.0 for the regular corner
│ │ │ │ +
368// is what similarly arises by extrapolating an interior region around the
│ │ │ │ +
369// vertex and using the interior mask for the first tangent.
│ │ │ │ +
370//
│ │ │ │ +
371// The cross-tangent formula for the regular crease/boundary is similarly found
│ │ │ │ +
372// from the above construction of the boundary, but the commonly used weights of
│ │ │ │ +
373// +/- 1 and 2 result from omitting the common factor of sqrt(3)/2 (arising from
│ │ │ │ +
374// the sines of increments of pi/3). With that scale factor close to one, it has
│ │ │ │ +
375// less impact than the irregular cases, which are analogous to corner tangents
│ │ │ │ +
376// in that differences on only one side of the vertex are considered. While a
│ │ │ │ +
377// scaling of 3.0 is similarly understandable for the valence 2 and 3 cases, it is
│ │ │ │ +
378// less obvious in the irregular formula for valence > 4, but similarly effective.
│ │ │ │ +
379//
│ │ │ │ +
380// The end result of these adjustments should be a set of limit tangents that are
│ │ │ │ +
381// of similar magnitude over a regular mesh including boundaries and corners.
│ │ │ │ +
382*/
│ │ │ │ +
383template <>
│ │ │ │ +
384template <typename VERTEX, typename MASK>
│ │ │ │ +
385inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
387 MASK& tan1Mask, MASK& tan2Mask) const {
│ │ │ │ +
388
│ │ │ │ +
389 int valence = vertex.GetNumEdges();
│ │ │ │ +
390
│ │ │ │ +
391 tan1Mask.SetNumVertexWeights(1);
│ │ │ │ +
392 tan1Mask.SetNumEdgeWeights(valence);
│ │ │ │ +
393 tan1Mask.SetNumFaceWeights(0);
│ │ │ │ +
394 tan1Mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
395
│ │ │ │ +
396 tan2Mask.SetNumVertexWeights(1);
│ │ │ │ +
397 tan2Mask.SetNumEdgeWeights(valence);
│ │ │ │ +
398 tan2Mask.SetNumFaceWeights(0);
│ │ │ │ +
399 tan2Mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
400
│ │ │ │ +
401 // See note above regarding scale factor of 3.0:
│ │ │ │ +
402 tan1Mask.VertexWeight(0) = -3.0f;
│ │ │ │ +
403 tan1Mask.EdgeWeight(0) = 3.0f;
│ │ │ │ +
404 tan1Mask.EdgeWeight(1) = 0.0f;
│ │ │ │ +
405
│ │ │ │ +
406 tan2Mask.VertexWeight(0) = -3.0f;
│ │ │ │ +
407 tan2Mask.EdgeWeight(0) = 0.0f;
│ │ │ │ +
408 tan2Mask.EdgeWeight(1) = 3.0f;
│ │ │ │ +
409
│ │ │ │ +
410 // Should be at least 2 edges -- be sure to clear weights for any more:
│ │ │ │ +
411 for (int i = 2; i < valence; ++i) {
│ │ │ │ +
412 tan1Mask.EdgeWeight(i) = 0.0f;
│ │ │ │ +
413 tan2Mask.EdgeWeight(i) = 0.0f;
│ │ │ │ +
414 }
│ │ │ │ +
415}
│ │ │ │ +
│ │ │ │ +
416
│ │ │ │ +
417template <>
│ │ │ │ +
418template <typename VERTEX, typename MASK>
│ │ │ │ +
419inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
421 MASK& tan1Mask, MASK& tan2Mask, int const creaseEnds[2]) const {
│ │ │ │ +
422
│ │ │ │ +
423 typedef typename MASK::Weight Weight;
│ │ │ │ +
424
│ │ │ │ +
425 //
│ │ │ │ +
426 // First, the tangent along the crease:
│ │ │ │ +
427 // The first crease edge is considered the "leading" edge of the span
│ │ │ │ +
428 // of surface for which we are evaluating tangents and the second edge the
│ │ │ │ +
429 // "trailing edge". By convention, the tangent along the crease is oriented
│ │ │ │ +
430 // in the direction of the leading edge.
│ │ │ │ +
431 //
│ │ │ │ +
432 int valence = vertex.GetNumEdges();
│ │ │ │ +
433
│ │ │ │ +
434 tan1Mask.SetNumVertexWeights(1);
│ │ │ │ +
435 tan1Mask.SetNumEdgeWeights(valence);
│ │ │ │ +
436 tan1Mask.SetNumFaceWeights(0);
│ │ │ │ +
437 tan1Mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
438
│ │ │ │ +
439 tan1Mask.VertexWeight(0) = 0.0f;
│ │ │ │ +
440 for (int i = 0; i < valence; ++i) {
│ │ │ │ +
441 tan1Mask.EdgeWeight(i) = 0.0f;
│ │ │ │ +
442 }
│ │ │ │ +
443
│ │ │ │ +
444 // See the note above regarding scale factor of 1.5:
│ │ │ │ +
445 tan1Mask.EdgeWeight(creaseEnds[0]) = 1.5f;
│ │ │ │ +
446 tan1Mask.EdgeWeight(creaseEnds[1]) = -1.5f;
│ │ │ │ +
447
│ │ │ │ +
448 //
│ │ │ │ +
449 // Second, the tangent across the interior faces:
│ │ │ │ +
450 // Note this is ambiguous for an interior vertex. We currently return
│ │ │ │ +
451 // the tangent for the surface in the counter-clockwise span between the
│ │ │ │ +
452 // leading and trailing edges that form the crease. Given the expected
│ │ │ │ +
453 // computation of a surface normal as Tan1 X Tan2, this tangent should be
│ │ │ │ +
454 // oriented "inward" from the crease/boundary -- across the surface rather
│ │ │ │ +
455 // than outward and away from it.
│ │ │ │ +
456 //
│ │ │ │ +
457 // There is inconsistency in the orientation of this tangent in commonly
│ │ │ │ +
458 // published results: the general formula provided for arbitrary valence
│ │ │ │ +
459 // has the tangent pointing across the crease and "outward" from the surface,
│ │ │ │ +
460 // while the special cases for regular valence and lower have the tangent
│ │ │ │ +
461 // pointing across the surface and "inward" from the crease. So if we are
│ │ │ │ +
462 // to consistently orient the first tangent along the crease, regardless of
│ │ │ │ +
463 // the interior topology, we have to correct this. With the first tangent
│ │ │ │ +
464 // following the direction of the leading crease edge, we want the second
│ │ │ │ +
465 // tangent pointing inward/across the surface -- so we flip the result of
│ │ │ │ +
466 // the general formula.
│ │ │ │ +
467 //
│ │ │ │ +
468 tan2Mask.SetNumVertexWeights(1);
│ │ │ │ +
469 tan2Mask.SetNumEdgeWeights(valence);
│ │ │ │ +
470 tan2Mask.SetNumFaceWeights(0);
│ │ │ │ +
471 tan2Mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
472
│ │ │ │ +
473 for (int i = 0; i < creaseEnds[0]; ++i) {
│ │ │ │ +
474 tan2Mask.EdgeWeight(i) = 0.0f;
│ │ │ │ +
475 }
│ │ │ │ +
476 int interiorEdgeCount = creaseEnds[1] - creaseEnds[0] - 1;
│ │ │ │ +
477 if (interiorEdgeCount == 2) {
│ │ │ │ +
478 // See note above regarding scale factor of (sin(60 degs) == sqrt(3)/2:
│ │ │ │ +
479
│ │ │ │ +
480 static Weight const Root3 = (Weight) 1.73205080756887729352;
│ │ │ │ +
481 static Weight const Root3by2 = (Weight) (Root3 * 0.5);
│ │ │ │ +
482
│ │ │ │ +
483 tan2Mask.VertexWeight(0) = -Root3;
│ │ │ │ +
484
│ │ │ │ +
485 tan2Mask.EdgeWeight(creaseEnds[0]) = -Root3by2;
│ │ │ │ +
486 tan2Mask.EdgeWeight(creaseEnds[1]) = -Root3by2;
│ │ │ │ +
487
│ │ │ │ +
488 tan2Mask.EdgeWeight(creaseEnds[0] + 1) = Root3;
│ │ │ │ +
489 tan2Mask.EdgeWeight(creaseEnds[0] + 2) = Root3;
│ │ │ │ +
490 } else if (interiorEdgeCount > 2) {
│ │ │ │ +
491 // See notes above regarding scale factor of -3.0 (-1 for orientation,
│ │ │ │ +
492 // 2.0 for considering the region as a half-disk, and 1.5 in keeping
│ │ │ │ +
493 // with the crease tangent):
│ │ │ │ +
494
│ │ │ │ +
495 double theta = M_PI / (interiorEdgeCount + 1);
│ │ │ │ +
496
│ │ │ │ +
497 tan2Mask.VertexWeight(0) = 0.0f;
│ │ │ │ +
498
│ │ │ │ +
499 Weight cWeight = (Weight) (-3.0f * std::sin(theta));
│ │ │ │ +
500 tan2Mask.EdgeWeight(creaseEnds[0]) = cWeight;
│ │ │ │ +
501 tan2Mask.EdgeWeight(creaseEnds[1]) = cWeight;
│ │ │ │ +
502
│ │ │ │ +
503 double eCoeff = -3.0f * 2.0f * (std::cos(theta) - 1.0f);
│ │ │ │ +
504 for (int i = 1; i <= interiorEdgeCount; ++i) {
│ │ │ │ +
505 tan2Mask.EdgeWeight(creaseEnds[0] + i) = (Weight) (eCoeff * std::sin(i * theta));
│ │ │ │ +
506 }
│ │ │ │ +
507 } else if (interiorEdgeCount == 1) {
│ │ │ │ +
508 // See notes above regarding scale factor of 3.0:
│ │ │ │ +
509
│ │ │ │ +
510 tan2Mask.VertexWeight(0) = -3.0f;
│ │ │ │ +
511
│ │ │ │ +
512 tan2Mask.EdgeWeight(creaseEnds[0]) = 0.0f;
│ │ │ │ +
513 tan2Mask.EdgeWeight(creaseEnds[1]) = 0.0f;
│ │ │ │ +
514
│ │ │ │ +
515 tan2Mask.EdgeWeight(creaseEnds[0] + 1) = 3.0f;
│ │ │ │ +
516 } else {
│ │ │ │ +
517 // See notes above regarding scale factor of 3.0:
│ │ │ │ +
518
│ │ │ │ +
519 tan2Mask.VertexWeight(0) = -6.0f;
│ │ │ │ +
520
│ │ │ │ +
521 tan2Mask.EdgeWeight(creaseEnds[0]) = 3.0f;
│ │ │ │ +
522 tan2Mask.EdgeWeight(creaseEnds[1]) = 3.0f;
│ │ │ │ +
523 }
│ │ │ │ +
524 for (int i = creaseEnds[1] + 1; i < valence; ++i) {
│ │ │ │ +
525 tan2Mask.EdgeWeight(i) = 0.0f;
│ │ │ │ +
526 }
│ │ │ │ +
527}
│ │ │ │ +
│ │ │ │ +
528
│ │ │ │ +
529template <>
│ │ │ │ +
530template <typename VERTEX, typename MASK>
│ │ │ │ +
531inline void
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
533 MASK& tan1Mask, MASK& tan2Mask) const {
│ │ │ │ +
534
│ │ │ │ +
535 typedef typename MASK::Weight Weight;
│ │ │ │ +
536
│ │ │ │ +
537 int valence = vertex.GetNumFaces();
│ │ │ │ +
538
│ │ │ │ +
539 tan1Mask.SetNumVertexWeights(1);
│ │ │ │ +
540 tan1Mask.SetNumEdgeWeights(valence);
│ │ │ │ +
541 tan1Mask.SetNumFaceWeights(0);
│ │ │ │ +
542 tan1Mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
543
│ │ │ │ +
544 tan2Mask.SetNumVertexWeights(1);
│ │ │ │ +
545 tan2Mask.SetNumEdgeWeights(valence);
│ │ │ │ +
546 tan2Mask.SetNumFaceWeights(0);
│ │ │ │ +
547 tan2Mask.SetFaceWeightsForFaceCenters(false);
│ │ │ │ +
548
│ │ │ │ +
549 tan1Mask.VertexWeight(0) = 0.0f;
│ │ │ │ +
550 tan2Mask.VertexWeight(0) = 0.0f;
│ │ │ │ +
551
│ │ │ │ +
552 if (valence == 6) {
│ │ │ │ +
553 static Weight const Root3by2 = (Weight)(0.5 * 1.73205080756887729352);
│ │ │ │ +
554
│ │ │ │ +
555 tan1Mask.EdgeWeight(0) = 1.0f;
│ │ │ │ +
556 tan1Mask.EdgeWeight(1) = 0.5f;
│ │ │ │ +
557 tan1Mask.EdgeWeight(2) = -0.5f;
│ │ │ │ +
558 tan1Mask.EdgeWeight(3) = -1.0f;
│ │ │ │ +
559 tan1Mask.EdgeWeight(4) = -0.5f;
│ │ │ │ +
560 tan1Mask.EdgeWeight(5) = 0.5f;
│ │ │ │ +
561
│ │ │ │ +
562 tan2Mask.EdgeWeight(0) = 0.0f;
│ │ │ │ +
563 tan2Mask.EdgeWeight(1) = Root3by2;
│ │ │ │ +
564 tan2Mask.EdgeWeight(2) = Root3by2;
│ │ │ │ +
565 tan2Mask.EdgeWeight(3) = 0.0f;
│ │ │ │ +
566 tan2Mask.EdgeWeight(4) = -Root3by2;
│ │ │ │ +
567 tan2Mask.EdgeWeight(5) = -Root3by2;
│ │ │ │ +
568 } else {
│ │ │ │ +
569 double alpha = 2.0f * M_PI / valence;
│ │ │ │ +
570 for (int i = 0; i < valence; ++i) {
│ │ │ │ +
571 double alphaI = alpha * i;
│ │ │ │ +
572 tan1Mask.EdgeWeight(i) = (Weight) std::cos(alphaI);
│ │ │ │ +
573 tan2Mask.EdgeWeight(i) = (Weight) std::sin(alphaI);
│ │ │ │ +
574 }
│ │ │ │ +
575 }
│ │ │ │ +
576}
│ │ │ │ +
│ │ │ │ +
577
│ │ │ │ +
578} // end namespace Sdc
│ │ │ │ +
579} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
580using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
581} // end namespace OpenSubdiv
│ │ │ │ +
582
│ │ │ │ +
583#endif /* OPENSUBDIV3_SDC_LOOP_SCHEME_H */
│ │ │ │ + │ │ │ │ +
Split
Enumerated type for all face splitting schemes.
Definition types.h:47
│ │ │ │ + │ │ │ │ +
void assignSmoothMaskForEdge(EDGE const &edge, MASK &mask) const
│ │ │ │ + │ │ │ │ +
void assignCreaseMaskForVertex(VERTEX const &edge, MASK &mask, int const creaseEnds[2]) const
│ │ │ │ +
void assignCreaseLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK &tan2, int const creaseEnds[2]) const
│ │ │ │ + │ │ │ │ +
void assignCreaseMaskForEdge(EDGE const &edge, MASK &mask) const
Definition scheme.h:317
│ │ │ │ +
void assignSmoothLimitMask(VERTEX const &vertex, MASK &pos) const
│ │ │ │ + │ │ │ │ +
void assignCornerMaskForVertex(VERTEX const &edge, MASK &mask) const
Definition scheme.h:331
│ │ │ │ +
void assignCreaseLimitMask(VERTEX const &vertex, MASK &pos, int const creaseEnds[2]) const
│ │ │ │ +
void assignSmoothMaskForVertex(VERTEX const &edge, MASK &mask) const
│ │ │ │ + │ │ │ │ +
void assignSmoothLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK &tan2) const
│ │ │ │ +
void assignCornerLimitMask(VERTEX const &vertex, MASK &pos) const
│ │ │ │ +
void assignCornerLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK &tan2) const
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── encoding │ │ │ │ │ @@ -1 +1 @@ │ │ │ │ │ -utf-8 │ │ │ │ │ +us-ascii │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -crease.h │ │ │ │ │ +loopScheme.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -23,289 +23,671 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_SDC_CREASE_H │ │ │ │ │ -25#define OPENSUBDIV3_SDC_CREASE_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_SDC_LOOP_SCHEME_H │ │ │ │ │ +25#define OPENSUBDIV3_SDC_LOOP_SCHEME_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ -29#include "../sdc/options.h" │ │ │ │ │ +29#include "../sdc/scheme.h" │ │ │ │ │ 30 │ │ │ │ │ -31namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -32namespace OPENSUBDIV_VERSION { │ │ │ │ │ +31#include │ │ │ │ │ +32#include │ │ │ │ │ 33 │ │ │ │ │ -34namespace Sdc { │ │ │ │ │ -35 │ │ │ │ │ -61 │ │ │ │ │ -_6_2class _C_r_e_a_s_e { │ │ │ │ │ -63public: │ │ │ │ │ -65 │ │ │ │ │ -_6_7 static float const _S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; // = 0.0f, do we really need this? │ │ │ │ │ -_6_8 static float const _S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E; // = 10.0f; │ │ │ │ │ -69 │ │ │ │ │ -_7_0 static bool _I_s_S_m_o_o_t_h(float sharpness) { return sharpness <= │ │ │ │ │ -_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; } │ │ │ │ │ -_7_1 static bool _I_s_S_h_a_r_p(float sharpness) { return sharpness > _S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; │ │ │ │ │ -} │ │ │ │ │ -_7_2 static bool _I_s_I_n_f_i_n_i_t_e(float sharpness) { return sharpness >= │ │ │ │ │ -_S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E; } │ │ │ │ │ -_7_3 static bool _I_s_S_e_m_i_S_h_a_r_p(float sharpness) { return (_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H < │ │ │ │ │ -sharpness) && (sharpness < _S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E); } │ │ │ │ │ -75 │ │ │ │ │ -_8_2 enum _R_u_l_e { │ │ │ │ │ -_8_3 _R_U_L_E___U_N_K_N_O_W_N = 0, │ │ │ │ │ -_8_4 _R_U_L_E___S_M_O_O_T_H = (1 << 0), │ │ │ │ │ -_8_5 _R_U_L_E___D_A_R_T = (1 << 1), │ │ │ │ │ -_8_6 _R_U_L_E___C_R_E_A_S_E = (1 << 2), │ │ │ │ │ -87 _R_U_L_E___C_O_R_N_E_R = (1 << 3) │ │ │ │ │ -_8_8 }; │ │ │ │ │ -89 │ │ │ │ │ -90public: │ │ │ │ │ -_9_1 _C_r_e_a_s_e() : _options() { } │ │ │ │ │ -_9_2 _C_r_e_a_s_e(_O_p_t_i_o_n_s const& options) : _options(options) { } │ │ │ │ │ -_9_3 _~_C_r_e_a_s_e() { } │ │ │ │ │ -94 │ │ │ │ │ -_9_5 bool _I_s_U_n_i_f_o_r_m() const { return _options._G_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d() == _O_p_t_i_o_n_s_:_: │ │ │ │ │ -_C_R_E_A_S_E___U_N_I_F_O_R_M; } │ │ │ │ │ -96 │ │ │ │ │ -98 │ │ │ │ │ -104 float _S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_E_d_g_e(float edgeSharpness) const; │ │ │ │ │ -105 float _S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_V_e_r_t_e_x(float edgeSharpness) const; │ │ │ │ │ -106 │ │ │ │ │ -107 // For future consideration │ │ │ │ │ -108 //float SharpenNonManifoldEdge(float edgeSharpness) const; │ │ │ │ │ -109 //float SharpenNonManifoldVertex(float edgeSharpness) const; │ │ │ │ │ +34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +35namespace OPENSUBDIV_VERSION { │ │ │ │ │ +36namespace Sdc { │ │ │ │ │ +37 │ │ │ │ │ +38 │ │ │ │ │ +39// │ │ │ │ │ +40// Specializations for Sdc::Scheme: │ │ │ │ │ +41// │ │ │ │ │ +42// │ │ │ │ │ +43 │ │ │ │ │ +44// │ │ │ │ │ +45// Loop traits: │ │ │ │ │ +46// │ │ │ │ │ +47template <> │ │ │ │ │ +_4_8inline _S_p_l_i_t _S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_G_e_t_T_o_p_o_l_o_g_i_c_a_l_S_p_l_i_t_T_y_p_e() { return │ │ │ │ │ +_S_P_L_I_T___T_O___T_R_I_S; } │ │ │ │ │ +49 │ │ │ │ │ +50template <> │ │ │ │ │ +_5_1inline int _S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_G_e_t_R_e_g_u_l_a_r_F_a_c_e_S_i_z_e() { return 3; } │ │ │ │ │ +52 │ │ │ │ │ +53template <> │ │ │ │ │ +_5_4inline int _S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_G_e_t_R_e_g_u_l_a_r_V_e_r_t_e_x_V_a_l_e_n_c_e() { return 6; } │ │ │ │ │ +55 │ │ │ │ │ +56template <> │ │ │ │ │ +_5_7inline int _S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_G_e_t_L_o_c_a_l_N_e_i_g_h_b_o_r_h_o_o_d_S_i_z_e() { return 1; } │ │ │ │ │ +58 │ │ │ │ │ +59 │ │ │ │ │ +60// │ │ │ │ │ +61// Protected methods to assign the two types of masks for an edge-vertex -- │ │ │ │ │ +62// Crease and Smooth. │ │ │ │ │ +63// │ │ │ │ │ +64// The Crease case does not really need to be specialized, though it may be │ │ │ │ │ +65// preferable to define all explicitly here. │ │ │ │ │ +66// │ │ │ │ │ +67template <> │ │ │ │ │ +68template │ │ │ │ │ +69inline void │ │ │ │ │ +_7_0_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e(EDGE const&, MASK& mask) const │ │ │ │ │ +71{ │ │ │ │ │ +72 mask.SetNumVertexWeights(2); │ │ │ │ │ +73 mask.SetNumEdgeWeights(0); │ │ │ │ │ +74 mask.SetNumFaceWeights(0); │ │ │ │ │ +75 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +76 │ │ │ │ │ +77 mask.VertexWeight(0) = 0.5f; │ │ │ │ │ +78 mask.VertexWeight(1) = 0.5f; │ │ │ │ │ +79} │ │ │ │ │ +80 │ │ │ │ │ +81template <> │ │ │ │ │ +82template │ │ │ │ │ +83inline void │ │ │ │ │ +_8_4_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_E_d_g_e(EDGE const& edge, MASK& mask) │ │ │ │ │ +const │ │ │ │ │ +85{ │ │ │ │ │ +86 int faceCount = edge.GetNumFaces(); │ │ │ │ │ +87 │ │ │ │ │ +88 mask.SetNumVertexWeights(2); │ │ │ │ │ +89 mask.SetNumEdgeWeights(0); │ │ │ │ │ +90 mask.SetNumFaceWeights(faceCount); │ │ │ │ │ +91 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +92 │ │ │ │ │ +93 // │ │ │ │ │ +94 // This is where we run into the issue of "face weights" -- we want to │ │ │ │ │ +weight the │ │ │ │ │ +95 // face-centers for Catmark, but face-centers are not generated for Loop. So │ │ │ │ │ +do │ │ │ │ │ +96 // we make assumptions on how the mask is used, assign some property to the │ │ │ │ │ +mask │ │ │ │ │ +97 // to indicate how they were assigned, or take input from the mask itself? │ │ │ │ │ +98 // │ │ │ │ │ +99 // Regardless, we have two choices: │ │ │ │ │ +100 // - face-weights are for the vertices opposite the edge (as in Hbr): │ │ │ │ │ +101 // vertex weights = 0.375f; │ │ │ │ │ +102 // face weights = 0.125f; │ │ │ │ │ +103 // │ │ │ │ │ +104 // - face-weights are for the face centers: │ │ │ │ │ +105 // vertex weights = 0.125f; │ │ │ │ │ +106 // face weights = 0.375f; │ │ │ │ │ +107 // │ │ │ │ │ +108 // Coincidentally the coefficients are the same but reversed. │ │ │ │ │ +109 // │ │ │ │ │ +110 typedef typename MASK::Weight Weight; │ │ │ │ │ 111 │ │ │ │ │ -113 │ │ │ │ │ -124 float _S_u_b_d_i_v_i_d_e_U_n_i_f_o_r_m_S_h_a_r_p_n_e_s_s(float vertexOrEdgeSharpness) const; │ │ │ │ │ -125 │ │ │ │ │ -126 float _S_u_b_d_i_v_i_d_e_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s(float vertexSharpness) const; │ │ │ │ │ -127 │ │ │ │ │ -_1_2_8 float _S_u_b_d_i_v_i_d_e_E_d_g_e_S_h_a_r_p_n_e_s_s_A_t_V_e_r_t_e_x(float edgeSharpness, │ │ │ │ │ -129 int incidentEdgeCountAtEndVertex, │ │ │ │ │ -130 float const* edgeSharpnessAroundEndVertex) const; │ │ │ │ │ +112 Weight vWeight = mask.AreFaceWeightsForFaceCenters() ? 0.125f : 0.375f; │ │ │ │ │ +113 Weight fWeight = mask.AreFaceWeightsForFaceCenters() ? 0.375f : 0.125f; │ │ │ │ │ +114 │ │ │ │ │ +115 mask.VertexWeight(0) = vWeight; │ │ │ │ │ +116 mask.VertexWeight(1) = vWeight; │ │ │ │ │ +117 │ │ │ │ │ +118 if (faceCount == 2) { │ │ │ │ │ +119 mask.FaceWeight(0) = fWeight; │ │ │ │ │ +120 mask.FaceWeight(1) = fWeight; │ │ │ │ │ +121 } else { │ │ │ │ │ +122 // The non-manifold case is not clearly defined -- we adjust the above │ │ │ │ │ +123 // face-weight to preserve the ratio of edge-center and face-centers: │ │ │ │ │ +124 fWeight *= 2.0f / (Weight) faceCount; │ │ │ │ │ +125 for (int i = 0; i < faceCount; ++i) { │ │ │ │ │ +126 mask.FaceWeight(i) = fWeight; │ │ │ │ │ +127 } │ │ │ │ │ +128 } │ │ │ │ │ +129} │ │ │ │ │ +130 │ │ │ │ │ 131 │ │ │ │ │ -_1_3_2 void _S_u_b_d_i_v_i_d_e_E_d_g_e_S_h_a_r_p_n_e_s_s_e_s_A_r_o_u_n_d_V_e_r_t_e_x(int incidentEdgeCountAtVertex, │ │ │ │ │ -133 float const* incidentEdgeSharpnessAroundVertex, │ │ │ │ │ -134 float* childEdgesSharpnessAroundVertex) const; │ │ │ │ │ -136 │ │ │ │ │ -138 │ │ │ │ │ -_1_4_4 _R_u_l_e _D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e(float vertexSharpness, │ │ │ │ │ -145 int incidentEdgeCount, │ │ │ │ │ -146 float const* incidentEdgeSharpness) const; │ │ │ │ │ -_1_4_7 _R_u_l_e _D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e(float vertexSharpness, │ │ │ │ │ -148 int sharpEdgeCount) const; │ │ │ │ │ -150 │ │ │ │ │ -_1_6_2 float _C_o_m_p_u_t_e_F_r_a_c_t_i_o_n_a_l_W_e_i_g_h_t_A_t_V_e_r_t_e_x(float vertexSharpness, │ │ │ │ │ -163 float childVertexSharpness, │ │ │ │ │ -164 int incidentEdgeCount, │ │ │ │ │ -165 float const* incidentEdgeSharpness, │ │ │ │ │ -166 float const* childEdgesSharpness) const; │ │ │ │ │ -167 │ │ │ │ │ -168 void _G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(float const * incidentEdgeSharpness, │ │ │ │ │ -169 int incidentEdgeCount, │ │ │ │ │ -170 int sharpEdgePair[2]) const; │ │ │ │ │ -171 │ │ │ │ │ -172 // Would these really help? Maybe only need Rules for the vertex-vertex │ │ │ │ │ -case... │ │ │ │ │ -173 // │ │ │ │ │ -174 // Rule DetermineEdgeVertexRule(float parentEdgeSharpness) const; │ │ │ │ │ -175 // Rule DetermineEdgeVertexRule(float childEdge1Sharpness, float │ │ │ │ │ -childEdge2Sharpness) const; │ │ │ │ │ +132// │ │ │ │ │ +133// Protected methods to assign the three types of masks for a vertex-vertex │ │ │ │ │ +-- │ │ │ │ │ +134// Corner, Crease and Smooth (Dart is the same as Smooth). │ │ │ │ │ +135// │ │ │ │ │ +136// Corner and Crease do not really need to be specialized, though it may be │ │ │ │ │ +137// preferable to define all explicitly here. │ │ │ │ │ +138// │ │ │ │ │ +139template <> │ │ │ │ │ +140template │ │ │ │ │ +141inline void │ │ │ │ │ +_1_4_2_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const&, MASK& mask) │ │ │ │ │ +const │ │ │ │ │ +143{ │ │ │ │ │ +144 mask.SetNumVertexWeights(1); │ │ │ │ │ +145 mask.SetNumEdgeWeights(0); │ │ │ │ │ +146 mask.SetNumFaceWeights(0); │ │ │ │ │ +147 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +148 │ │ │ │ │ +149 mask.VertexWeight(0) = 1.0f; │ │ │ │ │ +150} │ │ │ │ │ +151 │ │ │ │ │ +152template <> │ │ │ │ │ +153template │ │ │ │ │ +154inline void │ │ │ │ │ +_1_5_5_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& vertex, MASK& │ │ │ │ │ +mask, │ │ │ │ │ +156 int const creaseEnds[2]) const { │ │ │ │ │ +157 typedef typename MASK::Weight Weight; │ │ │ │ │ +158 │ │ │ │ │ +159 int valence = vertex.GetNumEdges(); │ │ │ │ │ +160 │ │ │ │ │ +161 mask.SetNumVertexWeights(1); │ │ │ │ │ +162 mask.SetNumEdgeWeights(valence); │ │ │ │ │ +163 mask.SetNumFaceWeights(0); │ │ │ │ │ +164 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +165 │ │ │ │ │ +166 Weight vWeight = 0.75f; │ │ │ │ │ +167 Weight eWeight = 0.125f; │ │ │ │ │ +168 │ │ │ │ │ +169 mask.VertexWeight(0) = vWeight; │ │ │ │ │ +170 for (int i = 0; i < valence; ++i) { │ │ │ │ │ +171 mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ +172 } │ │ │ │ │ +173 mask.EdgeWeight(creaseEnds[0]) = eWeight; │ │ │ │ │ +174 mask.EdgeWeight(creaseEnds[1]) = eWeight; │ │ │ │ │ +175} │ │ │ │ │ 176 │ │ │ │ │ -177protected: │ │ │ │ │ -178 float _d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s(float sharpness) const; │ │ │ │ │ -179 │ │ │ │ │ -180private: │ │ │ │ │ -181 _O_p_t_i_o_n_s _options; │ │ │ │ │ -182}; │ │ │ │ │ +177template <> │ │ │ │ │ +178template │ │ │ │ │ +179inline void │ │ │ │ │ +_1_8_0_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_V_e_r_t_e_x(VERTEX const& vertex, MASK& │ │ │ │ │ +mask) const │ │ │ │ │ +181{ │ │ │ │ │ +182 typedef typename MASK::Weight Weight; │ │ │ │ │ 183 │ │ │ │ │ -184 │ │ │ │ │ -185// │ │ │ │ │ -186// Inline declarations: │ │ │ │ │ -187// │ │ │ │ │ -188inline float │ │ │ │ │ -_1_8_9_C_r_e_a_s_e_:_:_S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_E_d_g_e(float /* edgeSharpness */) const { │ │ │ │ │ +184 int valence = vertex.GetNumFaces(); │ │ │ │ │ +185 │ │ │ │ │ +186 mask.SetNumVertexWeights(1); │ │ │ │ │ +187 mask.SetNumEdgeWeights(valence); │ │ │ │ │ +188 mask.SetNumFaceWeights(0); │ │ │ │ │ +189 mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ 190 │ │ │ │ │ -191 // │ │ │ │ │ -192 // Despite the presence of the BOUNDARY_NONE option, boundary edges are │ │ │ │ │ -always sharpened. │ │ │ │ │ -193 // Much of the code relies on sharpness to indicate boundaries to avoid the │ │ │ │ │ -more complex │ │ │ │ │ -194 // topological inspection │ │ │ │ │ -195 // │ │ │ │ │ -196 return _S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E; │ │ │ │ │ -197} │ │ │ │ │ -198 │ │ │ │ │ -199inline float │ │ │ │ │ -_2_0_0_C_r_e_a_s_e_:_:_S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_V_e_r_t_e_x(float vertexSharpness) const { │ │ │ │ │ -201 │ │ │ │ │ -202 return (_options._G_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n() == _O_p_t_i_o_n_s_:_: │ │ │ │ │ -_V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___A_N_D___C_O_R_N_E_R) ? │ │ │ │ │ -203 _S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E : vertexSharpness; │ │ │ │ │ -204} │ │ │ │ │ +191 // Specialize for the regular case: 1/16 per edge-vert, 5/8 for the vert │ │ │ │ │ +itself: │ │ │ │ │ +192 Weight eWeight = (Weight) 0.0625f; │ │ │ │ │ +193 Weight vWeight = (Weight) 0.625f; │ │ │ │ │ +194 │ │ │ │ │ +195 if (valence != 6) { │ │ │ │ │ +196 // From HbrLoopSubdivision::Subdivide(mesh, vertex): │ │ │ │ │ +197 // - could use some lookup tables here for common irregular valence (5, 7, │ │ │ │ │ +8) │ │ │ │ │ +198 // or all of these cosine calls will be adding up... │ │ │ │ │ +199 │ │ │ │ │ +200 double dValence = (double) valence; │ │ │ │ │ +201 double invValence = 1.0f / dValence; │ │ │ │ │ +202 double cosTheta = std::cos(M_PI * 2.0f * invValence); │ │ │ │ │ +203 │ │ │ │ │ +204 double beta = 0.25f * cosTheta + 0.375f; │ │ │ │ │ 205 │ │ │ │ │ -206inline float │ │ │ │ │ -_2_0_7_C_r_e_a_s_e_:_:_d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s(float sharpness) const { │ │ │ │ │ -208 │ │ │ │ │ -209 if (_I_s_S_m_o_o_t_h(sharpness)) return _C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; // redundant but │ │ │ │ │ -most common │ │ │ │ │ -210 if (_I_s_I_n_f_i_n_i_t_e(sharpness)) return _C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E; │ │ │ │ │ -211 if (sharpness > 1.0f) return (sharpness - 1.0f); │ │ │ │ │ -212 return _C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; │ │ │ │ │ -213} │ │ │ │ │ -214 │ │ │ │ │ -215inline float │ │ │ │ │ -_2_1_6_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_U_n_i_f_o_r_m_S_h_a_r_p_n_e_s_s(float vertexOrEdgeSharpness) const { │ │ │ │ │ -217 │ │ │ │ │ -218 return _d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s(vertexOrEdgeSharpness); │ │ │ │ │ -219} │ │ │ │ │ -220 │ │ │ │ │ -221inline float │ │ │ │ │ -_2_2_2_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s(float vertexSharpness) const { │ │ │ │ │ -223 │ │ │ │ │ -224 return _d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s(vertexSharpness); │ │ │ │ │ -225} │ │ │ │ │ -226 │ │ │ │ │ -227inline void │ │ │ │ │ -_2_2_8_C_r_e_a_s_e_:_:_G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(float const * incidentEdgeSharpness, int │ │ │ │ │ -incidentEdgeCount, │ │ │ │ │ -229 int sharpEdgePair[2]) const { │ │ │ │ │ -230 │ │ │ │ │ -231 // Only to be called when a crease is present at a vertex -- exactly two │ │ │ │ │ -sharp │ │ │ │ │ -232 // edges are expected here: │ │ │ │ │ -233 // │ │ │ │ │ -234 sharpEdgePair[0] = 0; │ │ │ │ │ -235 while (_I_s_S_m_o_o_t_h(incidentEdgeSharpness[sharpEdgePair[0]])) ++ sharpEdgePair │ │ │ │ │ -[0]; │ │ │ │ │ -236 │ │ │ │ │ -237 sharpEdgePair[1] = incidentEdgeCount - 1; │ │ │ │ │ -238 while (_I_s_S_m_o_o_t_h(incidentEdgeSharpness[sharpEdgePair[1]])) -- sharpEdgePair │ │ │ │ │ -[1]; │ │ │ │ │ -239} │ │ │ │ │ +206 eWeight = (Weight) ((0.625f - (beta * beta)) * invValence); │ │ │ │ │ +207 vWeight = (Weight) (1.0f - (eWeight * dValence)); │ │ │ │ │ +208 } │ │ │ │ │ +209 │ │ │ │ │ +210 mask.VertexWeight(0) = vWeight; │ │ │ │ │ +211 for (int i = 0; i < valence; ++i) { │ │ │ │ │ +212 mask.EdgeWeight(i) = eWeight; │ │ │ │ │ +213 } │ │ │ │ │ +214} │ │ │ │ │ +215 │ │ │ │ │ +216 │ │ │ │ │ +217// │ │ │ │ │ +218// Limit masks for position: │ │ │ │ │ +219// │ │ │ │ │ +220template <> │ │ │ │ │ +221template │ │ │ │ │ +222inline void │ │ │ │ │ +_2_2_3_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_M_a_s_k(VERTEX const& /* vertex */, MASK& │ │ │ │ │ +posMask) const { │ │ │ │ │ +224 │ │ │ │ │ +225 posMask.SetNumVertexWeights(1); │ │ │ │ │ +226 posMask.SetNumEdgeWeights(0); │ │ │ │ │ +227 posMask.SetNumFaceWeights(0); │ │ │ │ │ +228 posMask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +229 │ │ │ │ │ +230 posMask.VertexWeight(0) = 1.0f; │ │ │ │ │ +231} │ │ │ │ │ +232 │ │ │ │ │ +233template <> │ │ │ │ │ +234template │ │ │ │ │ +235inline void │ │ │ │ │ +_2_3_6_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& │ │ │ │ │ +posMask, │ │ │ │ │ +237 int const creaseEnds[2]) const { │ │ │ │ │ +238 │ │ │ │ │ +239 typedef typename MASK::Weight Weight; │ │ │ │ │ 240 │ │ │ │ │ -241} // end namespace sdc │ │ │ │ │ +241 int valence = vertex.GetNumEdges(); │ │ │ │ │ 242 │ │ │ │ │ -243} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -244using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -245} // end namespace OpenSubdiv │ │ │ │ │ -246 │ │ │ │ │ -247#endif /* OPENSUBDIV3_SDC_CREASE_H */ │ │ │ │ │ +243 posMask.SetNumVertexWeights(1); │ │ │ │ │ +244 posMask.SetNumEdgeWeights(valence); │ │ │ │ │ +245 posMask.SetNumFaceWeights(0); │ │ │ │ │ +246 posMask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +247 │ │ │ │ │ +248 // │ │ │ │ │ +249 // The refinement mask for a crease vertex is (1/8, 3/4, 1/8) and for a │ │ │ │ │ +crease │ │ │ │ │ +250 // edge is (1/2, 1/2) -- producing a uniform B-spline curve along the │ │ │ │ │ +crease │ │ │ │ │ +251 // (boundary) whether the vertex or its crease is regular or not. The limit │ │ │ │ │ +252 // mask is therefore (1/6, 2/3, 1/6) for ALL cases. │ │ │ │ │ +253 // │ │ │ │ │ +254 // An alternative limit mask (1/5, 3/5, 1/5) is often published for use │ │ │ │ │ +either │ │ │ │ │ +255 // for irregular crease vertices or for all crease/boundary vertices, but │ │ │ │ │ +this │ │ │ │ │ +256 // is based on an alternate refinement mask for the edge -- (3/8, 5/8) │ │ │ │ │ +versus │ │ │ │ │ +257 // the usual (1/2, 1/2) -- and will not produce the B-spline curve desired. │ │ │ │ │ +258 // │ │ │ │ │ +259 Weight vWeight = (Weight) (4.0 / 6.0); │ │ │ │ │ +260 Weight eWeight = (Weight) (1.0 / 6.0); │ │ │ │ │ +261 │ │ │ │ │ +262 posMask.VertexWeight(0) = vWeight; │ │ │ │ │ +263 for (int i = 0; i < valence; ++i) { │ │ │ │ │ +264 posMask.EdgeWeight(i) = 0.0f; │ │ │ │ │ +265 } │ │ │ │ │ +266 posMask.EdgeWeight(creaseEnds[0]) = eWeight; │ │ │ │ │ +267 posMask.EdgeWeight(creaseEnds[1]) = eWeight; │ │ │ │ │ +268} │ │ │ │ │ +269 │ │ │ │ │ +270template <> │ │ │ │ │ +271template │ │ │ │ │ +272inline void │ │ │ │ │ +_2_7_3_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_M_a_s_k(VERTEX const& vertex, MASK& │ │ │ │ │ +posMask) const { │ │ │ │ │ +274 │ │ │ │ │ +275 typedef typename MASK::Weight Weight; │ │ │ │ │ +276 │ │ │ │ │ +277 int valence = vertex.GetNumFaces(); │ │ │ │ │ +278 │ │ │ │ │ +279 posMask.SetNumVertexWeights(1); │ │ │ │ │ +280 posMask.SetNumEdgeWeights(valence); │ │ │ │ │ +281 posMask.SetNumFaceWeights(0); │ │ │ │ │ +282 posMask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +283 │ │ │ │ │ +284 // Specialize for the regular case: 1/12 per edge-vert, 1/2 for the vert │ │ │ │ │ +itself: │ │ │ │ │ +285 if (valence == 6) { │ │ │ │ │ +286 Weight eWeight = (Weight) (1.0 / 12.0); │ │ │ │ │ +287 Weight vWeight = 0.5f; │ │ │ │ │ +288 │ │ │ │ │ +289 posMask.VertexWeight(0) = vWeight; │ │ │ │ │ +290 │ │ │ │ │ +291 posMask.EdgeWeight(0) = eWeight; │ │ │ │ │ +292 posMask.EdgeWeight(1) = eWeight; │ │ │ │ │ +293 posMask.EdgeWeight(2) = eWeight; │ │ │ │ │ +294 posMask.EdgeWeight(3) = eWeight; │ │ │ │ │ +295 posMask.EdgeWeight(4) = eWeight; │ │ │ │ │ +296 posMask.EdgeWeight(5) = eWeight; │ │ │ │ │ +297 │ │ │ │ │ +298 } else { │ │ │ │ │ +299 double dValence = (double) valence; │ │ │ │ │ +300 double invValence = 1.0f / dValence; │ │ │ │ │ +301 double cosTheta = std::cos(M_PI * 2.0f * invValence); │ │ │ │ │ +302 │ │ │ │ │ +303 double beta = 0.25f * cosTheta + 0.375f; │ │ │ │ │ +304 double gamma = (0.625f - (beta * beta)) * invValence; │ │ │ │ │ +305 │ │ │ │ │ +306 Weight eWeight = (Weight) (1.0f / (dValence + 3.0f / (8.0f * gamma))); │ │ │ │ │ +307 Weight vWeight = (Weight) (1.0f - (eWeight * dValence)); │ │ │ │ │ +308 │ │ │ │ │ +309 posMask.VertexWeight(0) = vWeight; │ │ │ │ │ +310 for (int i = 0; i < valence; ++i) { │ │ │ │ │ +311 posMask.EdgeWeight(i) = eWeight; │ │ │ │ │ +312 } │ │ │ │ │ +313 } │ │ │ │ │ +314} │ │ │ │ │ +315 │ │ │ │ │ +316/* │ │ │ │ │ +317// Limit masks for tangents: │ │ │ │ │ +318// │ │ │ │ │ +319// A note on tangent magnitudes: │ │ │ │ │ +320// │ │ │ │ │ +321// Several formulae exist for limit tangents at a vertex to accommodate the │ │ │ │ │ +322// different topological configurations around the vertex. While these │ │ │ │ │ +produce │ │ │ │ │ +323// the desired direction, there is inconsistency in the resulting │ │ │ │ │ +magnitudes. │ │ │ │ │ +324// Ideally a regular mesh of uniformly shaped triangles with similar edge │ │ │ │ │ +lengths │ │ │ │ │ +325// should produce tangents of similar magnitudes throughout -- including │ │ │ │ │ +corners │ │ │ │ │ +326// and boundaries. So some of the common formulae for these are adjusted │ │ │ │ │ +with │ │ │ │ │ +327// scale factors. │ │ │ │ │ +328// │ │ │ │ │ +329// For uses where magnitude does not matter, this scaling should be │ │ │ │ │ +irrelevant. │ │ │ │ │ +330// But just as with patches, where the magnitudes of partial derivatives are │ │ │ │ │ +331// consistent between similar patches, the magnitudes of limit tangents │ │ │ │ │ +should │ │ │ │ │ +332// also be similar. │ │ │ │ │ +333// │ │ │ │ │ +334// The reference tangents, in terms of magnitudes, are those produced by the │ │ │ │ │ +335// limit tangent mask for smooth interior vertices, for which well │ │ │ │ │ +established │ │ │ │ │ +336// sin/cos formulae apply -- these remain unscaled. Formulae for the other │ │ │ │ │ +337// crease/boundary, corner tangents and irregular cases are scaled to be │ │ │ │ │ +more │ │ │ │ │ +338// consistent with these. │ │ │ │ │ +339// │ │ │ │ │ +340// The crease/boundary tangents for the regular case can be viewed as │ │ │ │ │ +derived │ │ │ │ │ +341// from the smooth interior masks with two "phantom" points extrapolated │ │ │ │ │ +across │ │ │ │ │ +342// the regular boundary: │ │ │ │ │ +343// │ │ │ │ │ +344// v3 v2 │ │ │ │ │ +345// X - - - - - X │ │ │ │ │ +346// / \ / \ │ │ │ │ │ +347// / \ / \ │ │ │ │ │ +348// v4 X - - - - - X - - - - - X v1 │ │ │ │ │ +349// . . 0 . . │ │ │ │ │ +350// . . . . │ │ │ │ │ +351// . . . . │ │ │ │ │ +352// (v5) (v6) │ │ │ │ │ +353// │ │ │ │ │ +354// where v5 = v0 + (v4 - v3) and v6 = v0 + v1 - v2. │ │ │ │ │ +355// │ │ │ │ │ +356// When the standard limit tangent mask is applied, the cosines of │ │ │ │ │ +increments │ │ │ │ │ +357// of pi/3 give us coefficients that are multiples of 1/2, leading to the │ │ │ │ │ +first │ │ │ │ │ +358// tangent T1 = 3/2 * (v1 - v4), rather than the widely used T1 = v1 - v4. │ │ │ │ │ +So │ │ │ │ │ +359// this scale factor of 3/2 is applied to ensure tangents along the │ │ │ │ │ +boundaries │ │ │ │ │ +360// are of similar magnitude as tangents in the immediate interior (which may │ │ │ │ │ +be │ │ │ │ │ +361// parallel). │ │ │ │ │ +362// │ │ │ │ │ +363// Tangents at corners are essentially a form of boundary tangent, and so │ │ │ │ │ +its │ │ │ │ │ +364// simple difference formula is scaled to be consistent with adjoining │ │ │ │ │ +boundary │ │ │ │ │ +365// tangents -- not just with the 3/2 factor from above, but with an │ │ │ │ │ +additional │ │ │ │ │ +366// 2.0 to compensate for the fact that the difference of only side of the │ │ │ │ │ +vertex │ │ │ │ │ +367// is considered here. The resulting scale factor of 3.0 for the regular │ │ │ │ │ +corner │ │ │ │ │ +368// is what similarly arises by extrapolating an interior region around the │ │ │ │ │ +369// vertex and using the interior mask for the first tangent. │ │ │ │ │ +370// │ │ │ │ │ +371// The cross-tangent formula for the regular crease/boundary is similarly │ │ │ │ │ +found │ │ │ │ │ +372// from the above construction of the boundary, but the commonly used │ │ │ │ │ +weights of │ │ │ │ │ +373// +/- 1 and 2 result from omitting the common factor of sqrt(3)/2 (arising │ │ │ │ │ +from │ │ │ │ │ +374// the sines of increments of pi/3). With that scale factor close to one, it │ │ │ │ │ +has │ │ │ │ │ +375// less impact than the irregular cases, which are analogous to corner │ │ │ │ │ +tangents │ │ │ │ │ +376// in that differences on only one side of the vertex are considered. While │ │ │ │ │ +a │ │ │ │ │ +377// scaling of 3.0 is similarly understandable for the valence 2 and 3 cases, │ │ │ │ │ +it is │ │ │ │ │ +378// less obvious in the irregular formula for valence > 4, but similarly │ │ │ │ │ +effective. │ │ │ │ │ +379// │ │ │ │ │ +380// The end result of these adjustments should be a set of limit tangents │ │ │ │ │ +that are │ │ │ │ │ +381// of similar magnitude over a regular mesh including boundaries and │ │ │ │ │ +corners. │ │ │ │ │ +382*/ │ │ │ │ │ +383template <> │ │ │ │ │ +384template │ │ │ │ │ +385inline void │ │ │ │ │ +_3_8_6_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, │ │ │ │ │ +387 MASK& tan1Mask, MASK& tan2Mask) const { │ │ │ │ │ +388 │ │ │ │ │ +389 int valence = vertex.GetNumEdges(); │ │ │ │ │ +390 │ │ │ │ │ +391 tan1Mask.SetNumVertexWeights(1); │ │ │ │ │ +392 tan1Mask.SetNumEdgeWeights(valence); │ │ │ │ │ +393 tan1Mask.SetNumFaceWeights(0); │ │ │ │ │ +394 tan1Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +395 │ │ │ │ │ +396 tan2Mask.SetNumVertexWeights(1); │ │ │ │ │ +397 tan2Mask.SetNumEdgeWeights(valence); │ │ │ │ │ +398 tan2Mask.SetNumFaceWeights(0); │ │ │ │ │ +399 tan2Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +400 │ │ │ │ │ +401 // See note above regarding scale factor of 3.0: │ │ │ │ │ +402 tan1Mask.VertexWeight(0) = -3.0f; │ │ │ │ │ +403 tan1Mask.EdgeWeight(0) = 3.0f; │ │ │ │ │ +404 tan1Mask.EdgeWeight(1) = 0.0f; │ │ │ │ │ +405 │ │ │ │ │ +406 tan2Mask.VertexWeight(0) = -3.0f; │ │ │ │ │ +407 tan2Mask.EdgeWeight(0) = 0.0f; │ │ │ │ │ +408 tan2Mask.EdgeWeight(1) = 3.0f; │ │ │ │ │ +409 │ │ │ │ │ +410 // Should be at least 2 edges -- be sure to clear weights for any more: │ │ │ │ │ +411 for (int i = 2; i < valence; ++i) { │ │ │ │ │ +412 tan1Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ +413 tan2Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ +414 } │ │ │ │ │ +415} │ │ │ │ │ +416 │ │ │ │ │ +417template <> │ │ │ │ │ +418template │ │ │ │ │ +419inline void │ │ │ │ │ +_4_2_0_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, │ │ │ │ │ +421 MASK& tan1Mask, MASK& tan2Mask, int const creaseEnds[2]) const { │ │ │ │ │ +422 │ │ │ │ │ +423 typedef typename MASK::Weight Weight; │ │ │ │ │ +424 │ │ │ │ │ +425 // │ │ │ │ │ +426 // First, the tangent along the crease: │ │ │ │ │ +427 // The first crease edge is considered the "leading" edge of the span │ │ │ │ │ +428 // of surface for which we are evaluating tangents and the second edge the │ │ │ │ │ +429 // "trailing edge". By convention, the tangent along the crease is oriented │ │ │ │ │ +430 // in the direction of the leading edge. │ │ │ │ │ +431 // │ │ │ │ │ +432 int valence = vertex.GetNumEdges(); │ │ │ │ │ +433 │ │ │ │ │ +434 tan1Mask.SetNumVertexWeights(1); │ │ │ │ │ +435 tan1Mask.SetNumEdgeWeights(valence); │ │ │ │ │ +436 tan1Mask.SetNumFaceWeights(0); │ │ │ │ │ +437 tan1Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +438 │ │ │ │ │ +439 tan1Mask.VertexWeight(0) = 0.0f; │ │ │ │ │ +440 for (int i = 0; i < valence; ++i) { │ │ │ │ │ +441 tan1Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ +442 } │ │ │ │ │ +443 │ │ │ │ │ +444 // See the note above regarding scale factor of 1.5: │ │ │ │ │ +445 tan1Mask.EdgeWeight(creaseEnds[0]) = 1.5f; │ │ │ │ │ +446 tan1Mask.EdgeWeight(creaseEnds[1]) = -1.5f; │ │ │ │ │ +447 │ │ │ │ │ +448 // │ │ │ │ │ +449 // Second, the tangent across the interior faces: │ │ │ │ │ +450 // Note this is ambiguous for an interior vertex. We currently return │ │ │ │ │ +451 // the tangent for the surface in the counter-clockwise span between the │ │ │ │ │ +452 // leading and trailing edges that form the crease. Given the expected │ │ │ │ │ +453 // computation of a surface normal as Tan1 X Tan2, this tangent should be │ │ │ │ │ +454 // oriented "inward" from the crease/boundary -- across the surface rather │ │ │ │ │ +455 // than outward and away from it. │ │ │ │ │ +456 // │ │ │ │ │ +457 // There is inconsistency in the orientation of this tangent in commonly │ │ │ │ │ +458 // published results: the general formula provided for arbitrary valence │ │ │ │ │ +459 // has the tangent pointing across the crease and "outward" from the │ │ │ │ │ +surface, │ │ │ │ │ +460 // while the special cases for regular valence and lower have the tangent │ │ │ │ │ +461 // pointing across the surface and "inward" from the crease. So if we are │ │ │ │ │ +462 // to consistently orient the first tangent along the crease, regardless of │ │ │ │ │ +463 // the interior topology, we have to correct this. With the first tangent │ │ │ │ │ +464 // following the direction of the leading crease edge, we want the second │ │ │ │ │ +465 // tangent pointing inward/across the surface -- so we flip the result of │ │ │ │ │ +466 // the general formula. │ │ │ │ │ +467 // │ │ │ │ │ +468 tan2Mask.SetNumVertexWeights(1); │ │ │ │ │ +469 tan2Mask.SetNumEdgeWeights(valence); │ │ │ │ │ +470 tan2Mask.SetNumFaceWeights(0); │ │ │ │ │ +471 tan2Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +472 │ │ │ │ │ +473 for (int i = 0; i < creaseEnds[0]; ++i) { │ │ │ │ │ +474 tan2Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ +475 } │ │ │ │ │ +476 int interiorEdgeCount = creaseEnds[1] - creaseEnds[0] - 1; │ │ │ │ │ +477 if (interiorEdgeCount == 2) { │ │ │ │ │ +478 // See note above regarding scale factor of (sin(60 degs) == sqrt(3)/2: │ │ │ │ │ +479 │ │ │ │ │ +480 static Weight const Root3 = (Weight) 1.73205080756887729352; │ │ │ │ │ +481 static Weight const Root3by2 = (Weight) (Root3 * 0.5); │ │ │ │ │ +482 │ │ │ │ │ +483 tan2Mask.VertexWeight(0) = -Root3; │ │ │ │ │ +484 │ │ │ │ │ +485 tan2Mask.EdgeWeight(creaseEnds[0]) = -Root3by2; │ │ │ │ │ +486 tan2Mask.EdgeWeight(creaseEnds[1]) = -Root3by2; │ │ │ │ │ +487 │ │ │ │ │ +488 tan2Mask.EdgeWeight(creaseEnds[0] + 1) = Root3; │ │ │ │ │ +489 tan2Mask.EdgeWeight(creaseEnds[0] + 2) = Root3; │ │ │ │ │ +490 } else if (interiorEdgeCount > 2) { │ │ │ │ │ +491 // See notes above regarding scale factor of -3.0 (-1 for orientation, │ │ │ │ │ +492 // 2.0 for considering the region as a half-disk, and 1.5 in keeping │ │ │ │ │ +493 // with the crease tangent): │ │ │ │ │ +494 │ │ │ │ │ +495 double theta = M_PI / (interiorEdgeCount + 1); │ │ │ │ │ +496 │ │ │ │ │ +497 tan2Mask.VertexWeight(0) = 0.0f; │ │ │ │ │ +498 │ │ │ │ │ +499 Weight cWeight = (Weight) (-3.0f * std::sin(theta)); │ │ │ │ │ +500 tan2Mask.EdgeWeight(creaseEnds[0]) = cWeight; │ │ │ │ │ +501 tan2Mask.EdgeWeight(creaseEnds[1]) = cWeight; │ │ │ │ │ +502 │ │ │ │ │ +503 double eCoeff = -3.0f * 2.0f * (std::cos(theta) - 1.0f); │ │ │ │ │ +504 for (int i = 1; i <= interiorEdgeCount; ++i) { │ │ │ │ │ +505 tan2Mask.EdgeWeight(creaseEnds[0] + i) = (Weight) (eCoeff * std::sin(i * │ │ │ │ │ +theta)); │ │ │ │ │ +506 } │ │ │ │ │ +507 } else if (interiorEdgeCount == 1) { │ │ │ │ │ +508 // See notes above regarding scale factor of 3.0: │ │ │ │ │ +509 │ │ │ │ │ +510 tan2Mask.VertexWeight(0) = -3.0f; │ │ │ │ │ +511 │ │ │ │ │ +512 tan2Mask.EdgeWeight(creaseEnds[0]) = 0.0f; │ │ │ │ │ +513 tan2Mask.EdgeWeight(creaseEnds[1]) = 0.0f; │ │ │ │ │ +514 │ │ │ │ │ +515 tan2Mask.EdgeWeight(creaseEnds[0] + 1) = 3.0f; │ │ │ │ │ +516 } else { │ │ │ │ │ +517 // See notes above regarding scale factor of 3.0: │ │ │ │ │ +518 │ │ │ │ │ +519 tan2Mask.VertexWeight(0) = -6.0f; │ │ │ │ │ +520 │ │ │ │ │ +521 tan2Mask.EdgeWeight(creaseEnds[0]) = 3.0f; │ │ │ │ │ +522 tan2Mask.EdgeWeight(creaseEnds[1]) = 3.0f; │ │ │ │ │ +523 } │ │ │ │ │ +524 for (int i = creaseEnds[1] + 1; i < valence; ++i) { │ │ │ │ │ +525 tan2Mask.EdgeWeight(i) = 0.0f; │ │ │ │ │ +526 } │ │ │ │ │ +527} │ │ │ │ │ +528 │ │ │ │ │ +529template <> │ │ │ │ │ +530template │ │ │ │ │ +531inline void │ │ │ │ │ +_5_3_2_S_c_h_e_m_e_<_S_C_H_E_M_E___L_O_O_P_>_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s(VERTEX const& vertex, │ │ │ │ │ +533 MASK& tan1Mask, MASK& tan2Mask) const { │ │ │ │ │ +534 │ │ │ │ │ +535 typedef typename MASK::Weight Weight; │ │ │ │ │ +536 │ │ │ │ │ +537 int valence = vertex.GetNumFaces(); │ │ │ │ │ +538 │ │ │ │ │ +539 tan1Mask.SetNumVertexWeights(1); │ │ │ │ │ +540 tan1Mask.SetNumEdgeWeights(valence); │ │ │ │ │ +541 tan1Mask.SetNumFaceWeights(0); │ │ │ │ │ +542 tan1Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +543 │ │ │ │ │ +544 tan2Mask.SetNumVertexWeights(1); │ │ │ │ │ +545 tan2Mask.SetNumEdgeWeights(valence); │ │ │ │ │ +546 tan2Mask.SetNumFaceWeights(0); │ │ │ │ │ +547 tan2Mask.SetFaceWeightsForFaceCenters(false); │ │ │ │ │ +548 │ │ │ │ │ +549 tan1Mask.VertexWeight(0) = 0.0f; │ │ │ │ │ +550 tan2Mask.VertexWeight(0) = 0.0f; │ │ │ │ │ +551 │ │ │ │ │ +552 if (valence == 6) { │ │ │ │ │ +553 static Weight const Root3by2 = (Weight)(0.5 * 1.73205080756887729352); │ │ │ │ │ +554 │ │ │ │ │ +555 tan1Mask.EdgeWeight(0) = 1.0f; │ │ │ │ │ +556 tan1Mask.EdgeWeight(1) = 0.5f; │ │ │ │ │ +557 tan1Mask.EdgeWeight(2) = -0.5f; │ │ │ │ │ +558 tan1Mask.EdgeWeight(3) = -1.0f; │ │ │ │ │ +559 tan1Mask.EdgeWeight(4) = -0.5f; │ │ │ │ │ +560 tan1Mask.EdgeWeight(5) = 0.5f; │ │ │ │ │ +561 │ │ │ │ │ +562 tan2Mask.EdgeWeight(0) = 0.0f; │ │ │ │ │ +563 tan2Mask.EdgeWeight(1) = Root3by2; │ │ │ │ │ +564 tan2Mask.EdgeWeight(2) = Root3by2; │ │ │ │ │ +565 tan2Mask.EdgeWeight(3) = 0.0f; │ │ │ │ │ +566 tan2Mask.EdgeWeight(4) = -Root3by2; │ │ │ │ │ +567 tan2Mask.EdgeWeight(5) = -Root3by2; │ │ │ │ │ +568 } else { │ │ │ │ │ +569 double alpha = 2.0f * M_PI / valence; │ │ │ │ │ +570 for (int i = 0; i < valence; ++i) { │ │ │ │ │ +571 double alphaI = alpha * i; │ │ │ │ │ +572 tan1Mask.EdgeWeight(i) = (Weight) std::cos(alphaI); │ │ │ │ │ +573 tan2Mask.EdgeWeight(i) = (Weight) std::sin(alphaI); │ │ │ │ │ +574 } │ │ │ │ │ +575 } │ │ │ │ │ +576} │ │ │ │ │ +577 │ │ │ │ │ +578} // end namespace Sdc │ │ │ │ │ +579} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +580using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +581} // end namespace OpenSubdiv │ │ │ │ │ +582 │ │ │ │ │ +583#endif /* OPENSUBDIV3_SDC_LOOP_SCHEME_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e │ │ │ │ │ -Types, constants and utilities related to semi-sharp creasing – whose │ │ │ │ │ -implementation is independent o... │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s │ │ │ │ │ -float SubdivideVertexSharpness(float vertexSharpness) const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_2_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_I_n_f_i_n_i_t_e │ │ │ │ │ -static bool IsInfinite(float sharpness) │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ -Rule │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_O_R_N_E_R │ │ │ │ │ -@ RULE_CORNER │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T │ │ │ │ │ -@ RULE_DART │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H │ │ │ │ │ -@ RULE_SMOOTH │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E │ │ │ │ │ -@ RULE_CREASE │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N │ │ │ │ │ -@ RULE_UNKNOWN │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_V_e_r_t_e_x │ │ │ │ │ -float SharpenBoundaryVertex(float edgeSharpness) const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H │ │ │ │ │ -static float const SHARPNESS_SMOOTH │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_6_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e │ │ │ │ │ -void GetSharpEdgePairOfCrease(float const *incidentEdgeSharpness, int │ │ │ │ │ -incidentEdgeCount, int sharpEdgePair[2]) const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_2_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E │ │ │ │ │ -static float const SHARPNESS_INFINITE │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e │ │ │ │ │ -Rule DetermineVertexVertexRule(float vertexSharpness, int incidentEdgeCount, │ │ │ │ │ -float const *incidentEdgeSharpness) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s │ │ │ │ │ -float decrementSharpness(float sharpness) const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_0_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_S_m_o_o_t_h │ │ │ │ │ -static bool IsSmooth(float sharpness) │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_7_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e │ │ │ │ │ -Rule DetermineVertexVertexRule(float vertexSharpness, int sharpEdgeCount) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_U_n_i_f_o_r_m │ │ │ │ │ -bool IsUniform() const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_S_e_m_i_S_h_a_r_p │ │ │ │ │ -static bool IsSemiSharp(float sharpness) │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_C_r_e_a_s_e │ │ │ │ │ -Crease(Options const &options) │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_: │ │ │ │ │ -_S_u_b_d_i_v_i_d_e_E_d_g_e_S_h_a_r_p_n_e_s_s_e_s_A_r_o_u_n_d_V_e_r_t_e_x │ │ │ │ │ -void SubdivideEdgeSharpnessesAroundVertex(int incidentEdgeCountAtVertex, float │ │ │ │ │ -const *incidentEdgeSharpnessAroundVertex, float │ │ │ │ │ -*childEdgesSharpnessAroundVertex) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_U_n_i_f_o_r_m_S_h_a_r_p_n_e_s_s │ │ │ │ │ -float SubdivideUniformSharpness(float vertexOrEdgeSharpness) const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_1_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_C_r_e_a_s_e │ │ │ │ │ -Crease() │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_E_d_g_e │ │ │ │ │ -float SharpenBoundaryEdge(float edgeSharpness) const │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_1_8_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_C_o_m_p_u_t_e_F_r_a_c_t_i_o_n_a_l_W_e_i_g_h_t_A_t_V_e_r_t_e_x │ │ │ │ │ -float ComputeFractionalWeightAtVertex(float vertexSharpness, float │ │ │ │ │ -childVertexSharpness, int incidentEdgeCount, float const │ │ │ │ │ -*incidentEdgeSharpness, float const *childEdgesSharpness) const │ │ │ │ │ -Transitional weighting: When the rules applicable to a parent vertex and its │ │ │ │ │ -child differ,... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_E_d_g_e_S_h_a_r_p_n_e_s_s_A_t_V_e_r_t_e_x │ │ │ │ │ -float SubdivideEdgeSharpnessAtVertex(float edgeSharpness, int │ │ │ │ │ -incidentEdgeCountAtEndVertex, float const *edgeSharpnessAroundEndVertex) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_S_h_a_r_p │ │ │ │ │ -static bool IsSharp(float sharpness) │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_~_C_r_e_a_s_e │ │ │ │ │ -~Crease() │ │ │ │ │ -DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s │ │ │ │ │ -All supported options applying to subdivision scheme. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_C_R_E_A_S_E___U_N_I_F_O_R_M │ │ │ │ │ -@ CREASE_UNIFORM │ │ │ │ │ -Catmark rule. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d │ │ │ │ │ -CreasingMethod GetCreasingMethod() const │ │ │ │ │ -Get edge crease rule. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_0_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -VtxBoundaryInterpolation GetVtxBoundaryInterpolation() const │ │ │ │ │ -Get vertex boundary interpolation rule. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_8_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___A_N_D___C_O_R_N_E_R │ │ │ │ │ -@ VTX_BOUNDARY_EDGE_AND_CORNER │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_p_l_i_t │ │ │ │ │ +Split │ │ │ │ │ +Enumerated type for all face splitting schemes. │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_P_L_I_T___T_O___T_R_I_S │ │ │ │ │ +@ SPLIT_TO_TRIS │ │ │ │ │ +Used by Loop. │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_E_d_g_e │ │ │ │ │ +void assignSmoothMaskForEdge(EDGE const &edge, MASK &mask) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_T_o_p_o_l_o_g_i_c_a_l_S_p_l_i_t_T_y_p_e │ │ │ │ │ +static Split GetTopologicalSplitType() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ +void assignCreaseMaskForVertex(VERTEX const &edge, MASK &mask, int const │ │ │ │ │ +creaseEnds[2]) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ +void assignCreaseLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ +&tan2, int const creaseEnds[2]) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_R_e_g_u_l_a_r_F_a_c_e_S_i_z_e │ │ │ │ │ +static int GetRegularFaceSize() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_M_a_s_k_F_o_r_E_d_g_e │ │ │ │ │ +void assignCreaseMaskForEdge(EDGE const &edge, MASK &mask) const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_1_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_M_a_s_k │ │ │ │ │ +void assignSmoothLimitMask(VERTEX const &vertex, MASK &pos) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_L_o_c_a_l_N_e_i_g_h_b_o_r_h_o_o_d_S_i_z_e │ │ │ │ │ +static int GetLocalNeighborhoodSize() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ +void assignCornerMaskForVertex(VERTEX const &edge, MASK &mask) const │ │ │ │ │ +DDeeffiinniittiioonn _s_c_h_e_m_e_._h_:_3_3_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_r_e_a_s_e_L_i_m_i_t_M_a_s_k │ │ │ │ │ +void assignCreaseLimitMask(VERTEX const &vertex, MASK &pos, int const │ │ │ │ │ +creaseEnds[2]) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_M_a_s_k_F_o_r_V_e_r_t_e_x │ │ │ │ │ +void assignSmoothMaskForVertex(VERTEX const &edge, MASK &mask) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_G_e_t_R_e_g_u_l_a_r_V_e_r_t_e_x_V_a_l_e_n_c_e │ │ │ │ │ +static int GetRegularVertexValence() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_S_m_o_o_t_h_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ +void assignSmoothLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ +&tan2) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_M_a_s_k │ │ │ │ │ +void assignCornerLimitMask(VERTEX const &vertex, MASK &pos) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_S_c_h_e_m_e_:_:_a_s_s_i_g_n_C_o_r_n_e_r_L_i_m_i_t_T_a_n_g_e_n_t_M_a_s_k_s │ │ │ │ │ +void assignCornerLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK │ │ │ │ │ +&tan2) const │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _s_d_c │ │ │ │ │ - * _c_r_e_a_s_e_._h │ │ │ │ │ + * _l_o_o_p_S_c_h_e_m_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00779.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/sdc/options.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/sdc/crease.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,25 +90,26 @@ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
options.h File Reference
│ │ │ │ +
crease.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ +#include "../sdc/options.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  Options
 All supported options applying to subdivision scheme. More...
class  Crease
 Types, constants and utilities related to semi-sharp creasing – whose implementation is independent of the subdivision scheme. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -117,13 +118,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,23 +1,25 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -options.h File Reference │ │ │ │ │ +crease.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ +#include "_._._/_s_d_c_/_o_p_t_i_o_n_s_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _O_p_t_i_o_n_s │ │ │ │ │ -  All supported options applying to subdivision scheme. _M_o_r_e_._._. │ │ │ │ │ +class   _C_r_e_a_s_e │ │ │ │ │ +  Types, constants and utilities related to semi-sharp creasing – whose │ │ │ │ │ + implementation is independent of the subdivision scheme. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _s_d_c │ │ │ │ │ - * _o_p_t_i_o_n_s_._h │ │ │ │ │ + * _c_r_e_a_s_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00779.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,3 @@ │ │ │ │ │ var a00779 = [ │ │ │ │ │ - ["Options", "a01337.html", "a01337"] │ │ │ │ │ + ["Crease", "a01333.html", "a01333"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00779_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/sdc/options.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/sdc/crease.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ -
options.h
│ │ │ │ +
crease.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2014 DreamWorks Animation LLC.
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -118,137 +118,221 @@ │ │ │ │
17//
│ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │ -
24#ifndef OPENSUBDIV3_SDC_OPTIONS_H
│ │ │ │ -
25#define OPENSUBDIV3_SDC_OPTIONS_H
│ │ │ │ +
24#ifndef OPENSUBDIV3_SDC_CREASE_H
│ │ │ │ +
25#define OPENSUBDIV3_SDC_CREASE_H
│ │ │ │
26
│ │ │ │
27#include "../version.h"
│ │ │ │
28
│ │ │ │ -
29namespace OpenSubdiv {
│ │ │ │ -
30namespace OPENSUBDIV_VERSION {
│ │ │ │ -
31
│ │ │ │ -
32namespace Sdc {
│ │ │ │ +
29#include "../sdc/options.h"
│ │ │ │ +
30
│ │ │ │ +
31namespace OpenSubdiv {
│ │ │ │ +
32namespace OPENSUBDIV_VERSION {
│ │ │ │
33
│ │ │ │ -
50
│ │ │ │ -
│ │ │ │ -
51class Options {
│ │ │ │ -
52public:
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
59 };
│ │ │ │ -
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
67 };
│ │ │ │ -
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
71 };
│ │ │ │ -
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
75 };
│ │ │ │ -
│ │ │ │ -
76
│ │ │ │ -
77public:
│ │ │ │ -
78
│ │ │ │ -
│ │ │ │ -
79 Options() : _vtxBoundInterp(VTX_BOUNDARY_NONE),
│ │ │ │ -
80 _fvarLinInterp(FVAR_LINEAR_ALL),
│ │ │ │ -
81 _creasingMethod(CREASE_UNIFORM),
│ │ │ │ -
82 _triangleSub(TRI_SUB_CATMARK) { }
│ │ │ │ -
│ │ │ │ -
83
│ │ │ │ -
84 //
│ │ │ │ -
85 // Trivial get/set methods:
│ │ │ │ -
86 //
│ │ │ │ -
87
│ │ │ │ - │ │ │ │ -
90
│ │ │ │ -
92 void SetVtxBoundaryInterpolation(VtxBoundaryInterpolation b) { _vtxBoundInterp = (EnumIntType) b; }
│ │ │ │ -
93
│ │ │ │ - │ │ │ │ +
34namespace Sdc {
│ │ │ │ +
35
│ │ │ │ +
61
│ │ │ │ +
│ │ │ │ +
62class Crease {
│ │ │ │ +
63public:
│ │ │ │ +
65
│ │ │ │ +
67 static float const SHARPNESS_SMOOTH; // = 0.0f, do we really need this?
│ │ │ │ +
68 static float const SHARPNESS_INFINITE; // = 10.0f;
│ │ │ │ +
69
│ │ │ │ +
70 static bool IsSmooth(float sharpness) { return sharpness <= SHARPNESS_SMOOTH; }
│ │ │ │ +
71 static bool IsSharp(float sharpness) { return sharpness > SHARPNESS_SMOOTH; }
│ │ │ │ +
72 static bool IsInfinite(float sharpness) { return sharpness >= SHARPNESS_INFINITE; }
│ │ │ │ +
73 static bool IsSemiSharp(float sharpness) { return (SHARPNESS_SMOOTH < sharpness) && (sharpness < SHARPNESS_INFINITE); }
│ │ │ │ +
75
│ │ │ │ +
│ │ │ │ +
82 enum Rule {
│ │ │ │ + │ │ │ │ +
84 RULE_SMOOTH = (1 << 0),
│ │ │ │ +
85 RULE_DART = (1 << 1),
│ │ │ │ +
86 RULE_CREASE = (1 << 2),
│ │ │ │ +
87 RULE_CORNER = (1 << 3)
│ │ │ │ +
88 };
│ │ │ │ +
│ │ │ │ +
89
│ │ │ │ +
90public:
│ │ │ │ +
91 Crease() : _options() { }
│ │ │ │ +
92 Crease(Options const& options) : _options(options) { }
│ │ │ │ +
93 ~Crease() { }
│ │ │ │ +
94
│ │ │ │ +
95 bool IsUniform() const { return _options.GetCreasingMethod() == Options::CREASE_UNIFORM; }
│ │ │ │
96
│ │ │ │ -
98 void SetFVarLinearInterpolation(FVarLinearInterpolation b) { _fvarLinInterp = (EnumIntType) b; }
│ │ │ │ -
99
│ │ │ │ -
101 CreasingMethod GetCreasingMethod() const { return (CreasingMethod) _creasingMethod; }
│ │ │ │ -
102
│ │ │ │ -
104 void SetCreasingMethod(CreasingMethod c) { _creasingMethod = (EnumIntType) c; }
│ │ │ │ -
105
│ │ │ │ - │ │ │ │ -
108
│ │ │ │ -
110 void SetTriangleSubdivision(TriangleSubdivision t) { _triangleSub = (EnumIntType) t; }
│ │ │ │ +
98
│ │ │ │ +
104 float SharpenBoundaryEdge(float edgeSharpness) const;
│ │ │ │ +
105 float SharpenBoundaryVertex(float edgeSharpness) const;
│ │ │ │ +
106
│ │ │ │ +
107 // For future consideration
│ │ │ │ +
108 //float SharpenNonManifoldEdge(float edgeSharpness) const;
│ │ │ │ +
109 //float SharpenNonManifoldVertex(float edgeSharpness) const;
│ │ │ │
111
│ │ │ │ -
112private:
│ │ │ │ -
113 // Use a small integer type to pack these rather than bitfields:
│ │ │ │ -
114 typedef unsigned char EnumIntType;
│ │ │ │ -
115
│ │ │ │ -
116 EnumIntType _vtxBoundInterp;
│ │ │ │ -
117 EnumIntType _fvarLinInterp;
│ │ │ │ -
118 EnumIntType _creasingMethod;
│ │ │ │ -
119 EnumIntType _triangleSub;
│ │ │ │ -
120};
│ │ │ │ -
│ │ │ │ -
121
│ │ │ │ -
122} // end namespace sdc
│ │ │ │ -
123
│ │ │ │ -
124} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
125using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
126} // end namespace OpenSubdiv
│ │ │ │ +
113
│ │ │ │ +
124 float SubdivideUniformSharpness(float vertexOrEdgeSharpness) const;
│ │ │ │ +
125
│ │ │ │ +
126 float SubdivideVertexSharpness(float vertexSharpness) const;
│ │ │ │
127
│ │ │ │ -
128#endif /* OPENSUBDIV3_SDC_OPTIONS_H */
│ │ │ │ - │ │ │ │ -
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ - │ │ │ │ -
@ TRI_SUB_CATMARK
Catmark weights (Catmark scheme only)
Definition options.h:73
│ │ │ │ -
@ TRI_SUB_SMOOTH
"smooth triangle" weights (Catmark scheme only)
Definition options.h:74
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
TriangleSubdivision GetTriangleSubdivision() const
Get triangle subdivision weights rule (Catmark scheme only !)
Definition options.h:107
│ │ │ │ -
CreasingMethod GetCreasingMethod() const
Get edge crease rule.
Definition options.h:101
│ │ │ │ - │ │ │ │ -
void SetFVarLinearInterpolation(FVarLinearInterpolation b)
Set face-varying interpolation rule.
Definition options.h:98
│ │ │ │ -
void SetTriangleSubdivision(TriangleSubdivision t)
Set triangle subdivision weights rule (Catmark scheme only !)
Definition options.h:110
│ │ │ │ -
VtxBoundaryInterpolation GetVtxBoundaryInterpolation() const
Get vertex boundary interpolation rule.
Definition options.h:89
│ │ │ │ - │ │ │ │ -
@ FVAR_LINEAR_CORNERS_ONLY
sharpen corners only
Definition options.h:62
│ │ │ │ -
@ FVAR_LINEAR_BOUNDARIES
sharpen all boundaries ("always sharp")
Definition options.h:65
│ │ │ │ -
@ FVAR_LINEAR_CORNERS_PLUS2
("edge and corner + propagate corner")
Definition options.h:64
│ │ │ │ - │ │ │ │ -
@ FVAR_LINEAR_ALL
bilinear interpolation ("bilinear")
Definition options.h:66
│ │ │ │ -
@ FVAR_LINEAR_NONE
smooth everywhere ("edge only")
Definition options.h:61
│ │ │ │ -
void SetVtxBoundaryInterpolation(VtxBoundaryInterpolation b)
Set vertex boundary interpolation rule.
Definition options.h:92
│ │ │ │ -
FVarLinearInterpolation GetFVarLinearInterpolation() const
Get face-varying interpolation rule.
Definition options.h:95
│ │ │ │ - │ │ │ │ - │ │ │ │ -
@ VTX_BOUNDARY_EDGE_ONLY
all boundary edges sharpened and interpolated
Definition options.h:56
│ │ │ │ - │ │ │ │ -
void SetCreasingMethod(CreasingMethod c)
Set edge crease rule.
Definition options.h:104
│ │ │ │ +
128 float SubdivideEdgeSharpnessAtVertex(float edgeSharpness,
│ │ │ │ +
129 int incidentEdgeCountAtEndVertex,
│ │ │ │ +
130 float const* edgeSharpnessAroundEndVertex) const;
│ │ │ │ +
131
│ │ │ │ +
132 void SubdivideEdgeSharpnessesAroundVertex(int incidentEdgeCountAtVertex,
│ │ │ │ +
133 float const* incidentEdgeSharpnessAroundVertex,
│ │ │ │ +
134 float* childEdgesSharpnessAroundVertex) const;
│ │ │ │ +
136
│ │ │ │ +
138
│ │ │ │ +
144 Rule DetermineVertexVertexRule(float vertexSharpness,
│ │ │ │ +
145 int incidentEdgeCount,
│ │ │ │ +
146 float const* incidentEdgeSharpness) const;
│ │ │ │ +
147 Rule DetermineVertexVertexRule(float vertexSharpness,
│ │ │ │ +
148 int sharpEdgeCount) const;
│ │ │ │ +
150
│ │ │ │ +
162 float ComputeFractionalWeightAtVertex(float vertexSharpness,
│ │ │ │ +
163 float childVertexSharpness,
│ │ │ │ +
164 int incidentEdgeCount,
│ │ │ │ +
165 float const* incidentEdgeSharpness,
│ │ │ │ +
166 float const* childEdgesSharpness) const;
│ │ │ │ +
167
│ │ │ │ +
168 void GetSharpEdgePairOfCrease(float const * incidentEdgeSharpness,
│ │ │ │ +
169 int incidentEdgeCount,
│ │ │ │ +
170 int sharpEdgePair[2]) const;
│ │ │ │ +
171
│ │ │ │ +
172 // Would these really help? Maybe only need Rules for the vertex-vertex case...
│ │ │ │ +
173 //
│ │ │ │ +
174 // Rule DetermineEdgeVertexRule(float parentEdgeSharpness) const;
│ │ │ │ +
175 // Rule DetermineEdgeVertexRule(float childEdge1Sharpness, float childEdge2Sharpness) const;
│ │ │ │ +
176
│ │ │ │ +
177protected:
│ │ │ │ +
178 float decrementSharpness(float sharpness) const;
│ │ │ │ +
179
│ │ │ │ +
180private:
│ │ │ │ +
181 Options _options;
│ │ │ │ +
182};
│ │ │ │ +
│ │ │ │ +
183
│ │ │ │ +
184
│ │ │ │ +
185//
│ │ │ │ +
186// Inline declarations:
│ │ │ │ +
187//
│ │ │ │ +
188inline float
│ │ │ │ +
│ │ │ │ +
189Crease::SharpenBoundaryEdge(float /* edgeSharpness */) const {
│ │ │ │ +
190
│ │ │ │ +
191 //
│ │ │ │ +
192 // Despite the presence of the BOUNDARY_NONE option, boundary edges are always sharpened.
│ │ │ │ +
193 // Much of the code relies on sharpness to indicate boundaries to avoid the more complex
│ │ │ │ +
194 // topological inspection
│ │ │ │ +
195 //
│ │ │ │ +
196 return SHARPNESS_INFINITE;
│ │ │ │ +
197}
│ │ │ │ +
│ │ │ │ +
198
│ │ │ │ +
199inline float
│ │ │ │ +
│ │ │ │ +
200Crease::SharpenBoundaryVertex(float vertexSharpness) const {
│ │ │ │ +
201
│ │ │ │ + │ │ │ │ +
203 SHARPNESS_INFINITE : vertexSharpness;
│ │ │ │ +
204}
│ │ │ │ +
│ │ │ │ +
205
│ │ │ │ +
206inline float
│ │ │ │ +
│ │ │ │ +
207Crease::decrementSharpness(float sharpness) const {
│ │ │ │ +
208
│ │ │ │ +
209 if (IsSmooth(sharpness)) return Crease::SHARPNESS_SMOOTH; // redundant but most common
│ │ │ │ +
210 if (IsInfinite(sharpness)) return Crease::SHARPNESS_INFINITE;
│ │ │ │ +
211 if (sharpness > 1.0f) return (sharpness - 1.0f);
│ │ │ │ + │ │ │ │ +
213}
│ │ │ │ +
│ │ │ │ +
214
│ │ │ │ +
215inline float
│ │ │ │ +
│ │ │ │ +
216Crease::SubdivideUniformSharpness(float vertexOrEdgeSharpness) const {
│ │ │ │ +
217
│ │ │ │ +
218 return decrementSharpness(vertexOrEdgeSharpness);
│ │ │ │ +
219}
│ │ │ │ +
│ │ │ │ +
220
│ │ │ │ +
221inline float
│ │ │ │ +
│ │ │ │ +
222Crease::SubdivideVertexSharpness(float vertexSharpness) const {
│ │ │ │ +
223
│ │ │ │ +
224 return decrementSharpness(vertexSharpness);
│ │ │ │ +
225}
│ │ │ │ +
│ │ │ │ +
226
│ │ │ │ +
227inline void
│ │ │ │ +
│ │ │ │ +
228Crease::GetSharpEdgePairOfCrease(float const * incidentEdgeSharpness, int incidentEdgeCount,
│ │ │ │ +
229 int sharpEdgePair[2]) const {
│ │ │ │ +
230
│ │ │ │ +
231 // Only to be called when a crease is present at a vertex -- exactly two sharp
│ │ │ │ +
232 // edges are expected here:
│ │ │ │ +
233 //
│ │ │ │ +
234 sharpEdgePair[0] = 0;
│ │ │ │ +
235 while (IsSmooth(incidentEdgeSharpness[sharpEdgePair[0]])) ++ sharpEdgePair[0];
│ │ │ │ +
236
│ │ │ │ +
237 sharpEdgePair[1] = incidentEdgeCount - 1;
│ │ │ │ +
238 while (IsSmooth(incidentEdgeSharpness[sharpEdgePair[1]])) -- sharpEdgePair[1];
│ │ │ │ +
239}
│ │ │ │ +
│ │ │ │ +
240
│ │ │ │ +
241} // end namespace sdc
│ │ │ │ +
242
│ │ │ │ +
243} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
244using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
245} // end namespace OpenSubdiv
│ │ │ │ +
246
│ │ │ │ +
247#endif /* OPENSUBDIV3_SDC_CREASE_H */
│ │ │ │ + │ │ │ │ +
Types, constants and utilities related to semi-sharp creasing – whose implementation is independent o...
Definition crease.h:62
│ │ │ │ +
float SubdivideVertexSharpness(float vertexSharpness) const
Definition crease.h:222
│ │ │ │ +
static bool IsInfinite(float sharpness)
Definition crease.h:72
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
float SharpenBoundaryVertex(float edgeSharpness) const
Definition crease.h:200
│ │ │ │ + │ │ │ │ +
void GetSharpEdgePairOfCrease(float const *incidentEdgeSharpness, int incidentEdgeCount, int sharpEdgePair[2]) const
Definition crease.h:228
│ │ │ │ + │ │ │ │ +
Rule DetermineVertexVertexRule(float vertexSharpness, int incidentEdgeCount, float const *incidentEdgeSharpness) const
│ │ │ │ +
float decrementSharpness(float sharpness) const
Definition crease.h:207
│ │ │ │ +
static bool IsSmooth(float sharpness)
Definition crease.h:70
│ │ │ │ +
Rule DetermineVertexVertexRule(float vertexSharpness, int sharpEdgeCount) const
│ │ │ │ + │ │ │ │ +
static bool IsSemiSharp(float sharpness)
Definition crease.h:73
│ │ │ │ + │ │ │ │ +
void SubdivideEdgeSharpnessesAroundVertex(int incidentEdgeCountAtVertex, float const *incidentEdgeSharpnessAroundVertex, float *childEdgesSharpnessAroundVertex) const
│ │ │ │ +
float SubdivideUniformSharpness(float vertexOrEdgeSharpness) const
Definition crease.h:216
│ │ │ │ + │ │ │ │ +
float SharpenBoundaryEdge(float edgeSharpness) const
Definition crease.h:189
│ │ │ │ +
float ComputeFractionalWeightAtVertex(float vertexSharpness, float childVertexSharpness, int incidentEdgeCount, float const *incidentEdgeSharpness, float const *childEdgesSharpness) const
Transitional weighting: When the rules applicable to a parent vertex and its child differ,...
│ │ │ │ +
float SubdivideEdgeSharpnessAtVertex(float edgeSharpness, int incidentEdgeCountAtEndVertex, float const *edgeSharpnessAroundEndVertex) const
│ │ │ │ +
static bool IsSharp(float sharpness)
Definition crease.h:71
│ │ │ │ + │ │ │ │ +
All supported options applying to subdivision scheme.
Definition options.h:51
│ │ │ │ + │ │ │ │ +
CreasingMethod GetCreasingMethod() const
Get edge crease rule.
Definition options.h:101
│ │ │ │ +
VtxBoundaryInterpolation GetVtxBoundaryInterpolation() const
Get vertex boundary interpolation rule.
Definition options.h:89
│ │ │ │ + │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── encoding │ │ │ │ │ @@ -1 +1 @@ │ │ │ │ │ -us-ascii │ │ │ │ │ +utf-8 │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -options.h │ │ │ │ │ +crease.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2014 DreamWorks Animation LLC. │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -23,200 +23,289 @@ │ │ │ │ │ 17// │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ -24#ifndef OPENSUBDIV3_SDC_OPTIONS_H │ │ │ │ │ -25#define OPENSUBDIV3_SDC_OPTIONS_H │ │ │ │ │ +24#ifndef OPENSUBDIV3_SDC_CREASE_H │ │ │ │ │ +25#define OPENSUBDIV3_SDC_CREASE_H │ │ │ │ │ 26 │ │ │ │ │ 27#include "../version.h" │ │ │ │ │ 28 │ │ │ │ │ -29namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -30namespace OPENSUBDIV_VERSION { │ │ │ │ │ -31 │ │ │ │ │ -32namespace Sdc { │ │ │ │ │ +29#include "../sdc/options.h" │ │ │ │ │ +30 │ │ │ │ │ +31namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +32namespace OPENSUBDIV_VERSION { │ │ │ │ │ 33 │ │ │ │ │ -50 │ │ │ │ │ -_5_1class _O_p_t_i_o_n_s { │ │ │ │ │ -52public: │ │ │ │ │ -_5_3 enum _V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n { │ │ │ │ │ -54 _V_T_X___B_O_U_N_D_A_R_Y___N_O_N_E = 0, │ │ │ │ │ -_5_6 _V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___O_N_L_Y, │ │ │ │ │ -57 _V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___A_N_D___C_O_R_N_E_R │ │ │ │ │ -_5_9 }; │ │ │ │ │ -_6_0 enum _F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n { │ │ │ │ │ -_6_1 _F_V_A_R___L_I_N_E_A_R___N_O_N_E = 0, │ │ │ │ │ -_6_2 _F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___O_N_L_Y, │ │ │ │ │ -_6_3 _F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___P_L_U_S_1, │ │ │ │ │ -_6_4 _F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___P_L_U_S_2, │ │ │ │ │ -_6_5 _F_V_A_R___L_I_N_E_A_R___B_O_U_N_D_A_R_I_E_S, │ │ │ │ │ -66 _F_V_A_R___L_I_N_E_A_R___A_L_L │ │ │ │ │ -_6_7 }; │ │ │ │ │ -_6_8 enum _C_r_e_a_s_i_n_g_M_e_t_h_o_d { │ │ │ │ │ -_6_9 _C_R_E_A_S_E___U_N_I_F_O_R_M = 0, │ │ │ │ │ -70 _C_R_E_A_S_E___C_H_A_I_K_I_N │ │ │ │ │ -_7_1 }; │ │ │ │ │ -_7_2 enum _T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n { │ │ │ │ │ -_7_3 _T_R_I___S_U_B___C_A_T_M_A_R_K = 0, │ │ │ │ │ -74 _T_R_I___S_U_B___S_M_O_O_T_H │ │ │ │ │ -_7_5 }; │ │ │ │ │ -76 │ │ │ │ │ -77public: │ │ │ │ │ -78 │ │ │ │ │ -_7_9 _O_p_t_i_o_n_s() : _vtxBoundInterp(_V_T_X___B_O_U_N_D_A_R_Y___N_O_N_E), │ │ │ │ │ -80 _fvarLinInterp(_F_V_A_R___L_I_N_E_A_R___A_L_L), │ │ │ │ │ -81 _creasingMethod(_C_R_E_A_S_E___U_N_I_F_O_R_M), │ │ │ │ │ -82 _triangleSub(_T_R_I___S_U_B___C_A_T_M_A_R_K) { } │ │ │ │ │ -83 │ │ │ │ │ -84 // │ │ │ │ │ -85 // Trivial get/set methods: │ │ │ │ │ -86 // │ │ │ │ │ -87 │ │ │ │ │ -_8_9 _V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n _G_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n() const { return │ │ │ │ │ -(_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n) _vtxBoundInterp; } │ │ │ │ │ -90 │ │ │ │ │ -_9_2 void _S_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n(_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n b) │ │ │ │ │ -{ _vtxBoundInterp = (EnumIntType) b; } │ │ │ │ │ -93 │ │ │ │ │ -_9_5 _F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n _G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n() const { return │ │ │ │ │ -(_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n) _fvarLinInterp; } │ │ │ │ │ +34namespace Sdc { │ │ │ │ │ +35 │ │ │ │ │ +61 │ │ │ │ │ +_6_2class _C_r_e_a_s_e { │ │ │ │ │ +63public: │ │ │ │ │ +65 │ │ │ │ │ +_6_7 static float const _S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; // = 0.0f, do we really need this? │ │ │ │ │ +_6_8 static float const _S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E; // = 10.0f; │ │ │ │ │ +69 │ │ │ │ │ +_7_0 static bool _I_s_S_m_o_o_t_h(float sharpness) { return sharpness <= │ │ │ │ │ +_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; } │ │ │ │ │ +_7_1 static bool _I_s_S_h_a_r_p(float sharpness) { return sharpness > _S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; │ │ │ │ │ +} │ │ │ │ │ +_7_2 static bool _I_s_I_n_f_i_n_i_t_e(float sharpness) { return sharpness >= │ │ │ │ │ +_S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E; } │ │ │ │ │ +_7_3 static bool _I_s_S_e_m_i_S_h_a_r_p(float sharpness) { return (_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H < │ │ │ │ │ +sharpness) && (sharpness < _S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E); } │ │ │ │ │ +75 │ │ │ │ │ +_8_2 enum _R_u_l_e { │ │ │ │ │ +_8_3 _R_U_L_E___U_N_K_N_O_W_N = 0, │ │ │ │ │ +_8_4 _R_U_L_E___S_M_O_O_T_H = (1 << 0), │ │ │ │ │ +_8_5 _R_U_L_E___D_A_R_T = (1 << 1), │ │ │ │ │ +_8_6 _R_U_L_E___C_R_E_A_S_E = (1 << 2), │ │ │ │ │ +87 _R_U_L_E___C_O_R_N_E_R = (1 << 3) │ │ │ │ │ +_8_8 }; │ │ │ │ │ +89 │ │ │ │ │ +90public: │ │ │ │ │ +_9_1 _C_r_e_a_s_e() : _options() { } │ │ │ │ │ +_9_2 _C_r_e_a_s_e(_O_p_t_i_o_n_s const& options) : _options(options) { } │ │ │ │ │ +_9_3 _~_C_r_e_a_s_e() { } │ │ │ │ │ +94 │ │ │ │ │ +_9_5 bool _I_s_U_n_i_f_o_r_m() const { return _options._G_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d() == _O_p_t_i_o_n_s_:_: │ │ │ │ │ +_C_R_E_A_S_E___U_N_I_F_O_R_M; } │ │ │ │ │ 96 │ │ │ │ │ -_9_8 void _S_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n(_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n b) { _fvarLinInterp │ │ │ │ │ -= (EnumIntType) b; } │ │ │ │ │ -99 │ │ │ │ │ -_1_0_1 _C_r_e_a_s_i_n_g_M_e_t_h_o_d _G_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d() const { return (_C_r_e_a_s_i_n_g_M_e_t_h_o_d) │ │ │ │ │ -_creasingMethod; } │ │ │ │ │ -102 │ │ │ │ │ -_1_0_4 void _S_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d(_C_r_e_a_s_i_n_g_M_e_t_h_o_d c) { _creasingMethod = (EnumIntType) │ │ │ │ │ -c; } │ │ │ │ │ -105 │ │ │ │ │ -_1_0_7 _T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n _G_e_t_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n() const { return │ │ │ │ │ -(_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n) _triangleSub; } │ │ │ │ │ -108 │ │ │ │ │ -_1_1_0 void _S_e_t_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n(_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n t) { _triangleSub = │ │ │ │ │ -(EnumIntType) t; } │ │ │ │ │ +98 │ │ │ │ │ +104 float _S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_E_d_g_e(float edgeSharpness) const; │ │ │ │ │ +105 float _S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_V_e_r_t_e_x(float edgeSharpness) const; │ │ │ │ │ +106 │ │ │ │ │ +107 // For future consideration │ │ │ │ │ +108 //float SharpenNonManifoldEdge(float edgeSharpness) const; │ │ │ │ │ +109 //float SharpenNonManifoldVertex(float edgeSharpness) const; │ │ │ │ │ 111 │ │ │ │ │ -112private: │ │ │ │ │ -113 // Use a small integer type to pack these rather than bitfields: │ │ │ │ │ -114 typedef unsigned char EnumIntType; │ │ │ │ │ -115 │ │ │ │ │ -116 EnumIntType _vtxBoundInterp; │ │ │ │ │ -117 EnumIntType _fvarLinInterp; │ │ │ │ │ -118 EnumIntType _creasingMethod; │ │ │ │ │ -119 EnumIntType _triangleSub; │ │ │ │ │ -120}; │ │ │ │ │ -121 │ │ │ │ │ -122} // end namespace sdc │ │ │ │ │ -123 │ │ │ │ │ -124} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -125using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -126} // end namespace OpenSubdiv │ │ │ │ │ +113 │ │ │ │ │ +124 float _S_u_b_d_i_v_i_d_e_U_n_i_f_o_r_m_S_h_a_r_p_n_e_s_s(float vertexOrEdgeSharpness) const; │ │ │ │ │ +125 │ │ │ │ │ +126 float _S_u_b_d_i_v_i_d_e_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s(float vertexSharpness) const; │ │ │ │ │ 127 │ │ │ │ │ -128#endif /* OPENSUBDIV3_SDC_OPTIONS_H */ │ │ │ │ │ +_1_2_8 float _S_u_b_d_i_v_i_d_e_E_d_g_e_S_h_a_r_p_n_e_s_s_A_t_V_e_r_t_e_x(float edgeSharpness, │ │ │ │ │ +129 int incidentEdgeCountAtEndVertex, │ │ │ │ │ +130 float const* edgeSharpnessAroundEndVertex) const; │ │ │ │ │ +131 │ │ │ │ │ +_1_3_2 void _S_u_b_d_i_v_i_d_e_E_d_g_e_S_h_a_r_p_n_e_s_s_e_s_A_r_o_u_n_d_V_e_r_t_e_x(int incidentEdgeCountAtVertex, │ │ │ │ │ +133 float const* incidentEdgeSharpnessAroundVertex, │ │ │ │ │ +134 float* childEdgesSharpnessAroundVertex) const; │ │ │ │ │ +136 │ │ │ │ │ +138 │ │ │ │ │ +_1_4_4 _R_u_l_e _D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e(float vertexSharpness, │ │ │ │ │ +145 int incidentEdgeCount, │ │ │ │ │ +146 float const* incidentEdgeSharpness) const; │ │ │ │ │ +_1_4_7 _R_u_l_e _D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e(float vertexSharpness, │ │ │ │ │ +148 int sharpEdgeCount) const; │ │ │ │ │ +150 │ │ │ │ │ +_1_6_2 float _C_o_m_p_u_t_e_F_r_a_c_t_i_o_n_a_l_W_e_i_g_h_t_A_t_V_e_r_t_e_x(float vertexSharpness, │ │ │ │ │ +163 float childVertexSharpness, │ │ │ │ │ +164 int incidentEdgeCount, │ │ │ │ │ +165 float const* incidentEdgeSharpness, │ │ │ │ │ +166 float const* childEdgesSharpness) const; │ │ │ │ │ +167 │ │ │ │ │ +168 void _G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(float const * incidentEdgeSharpness, │ │ │ │ │ +169 int incidentEdgeCount, │ │ │ │ │ +170 int sharpEdgePair[2]) const; │ │ │ │ │ +171 │ │ │ │ │ +172 // Would these really help? Maybe only need Rules for the vertex-vertex │ │ │ │ │ +case... │ │ │ │ │ +173 // │ │ │ │ │ +174 // Rule DetermineEdgeVertexRule(float parentEdgeSharpness) const; │ │ │ │ │ +175 // Rule DetermineEdgeVertexRule(float childEdge1Sharpness, float │ │ │ │ │ +childEdge2Sharpness) const; │ │ │ │ │ +176 │ │ │ │ │ +177protected: │ │ │ │ │ +178 float _d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s(float sharpness) const; │ │ │ │ │ +179 │ │ │ │ │ +180private: │ │ │ │ │ +181 _O_p_t_i_o_n_s _options; │ │ │ │ │ +182}; │ │ │ │ │ +183 │ │ │ │ │ +184 │ │ │ │ │ +185// │ │ │ │ │ +186// Inline declarations: │ │ │ │ │ +187// │ │ │ │ │ +188inline float │ │ │ │ │ +_1_8_9_C_r_e_a_s_e_:_:_S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_E_d_g_e(float /* edgeSharpness */) const { │ │ │ │ │ +190 │ │ │ │ │ +191 // │ │ │ │ │ +192 // Despite the presence of the BOUNDARY_NONE option, boundary edges are │ │ │ │ │ +always sharpened. │ │ │ │ │ +193 // Much of the code relies on sharpness to indicate boundaries to avoid the │ │ │ │ │ +more complex │ │ │ │ │ +194 // topological inspection │ │ │ │ │ +195 // │ │ │ │ │ +196 return _S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E; │ │ │ │ │ +197} │ │ │ │ │ +198 │ │ │ │ │ +199inline float │ │ │ │ │ +_2_0_0_C_r_e_a_s_e_:_:_S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_V_e_r_t_e_x(float vertexSharpness) const { │ │ │ │ │ +201 │ │ │ │ │ +202 return (_options._G_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n() == _O_p_t_i_o_n_s_:_: │ │ │ │ │ +_V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___A_N_D___C_O_R_N_E_R) ? │ │ │ │ │ +203 _S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E : vertexSharpness; │ │ │ │ │ +204} │ │ │ │ │ +205 │ │ │ │ │ +206inline float │ │ │ │ │ +_2_0_7_C_r_e_a_s_e_:_:_d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s(float sharpness) const { │ │ │ │ │ +208 │ │ │ │ │ +209 if (_I_s_S_m_o_o_t_h(sharpness)) return _C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; // redundant but │ │ │ │ │ +most common │ │ │ │ │ +210 if (_I_s_I_n_f_i_n_i_t_e(sharpness)) return _C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E; │ │ │ │ │ +211 if (sharpness > 1.0f) return (sharpness - 1.0f); │ │ │ │ │ +212 return _C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H; │ │ │ │ │ +213} │ │ │ │ │ +214 │ │ │ │ │ +215inline float │ │ │ │ │ +_2_1_6_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_U_n_i_f_o_r_m_S_h_a_r_p_n_e_s_s(float vertexOrEdgeSharpness) const { │ │ │ │ │ +217 │ │ │ │ │ +218 return _d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s(vertexOrEdgeSharpness); │ │ │ │ │ +219} │ │ │ │ │ +220 │ │ │ │ │ +221inline float │ │ │ │ │ +_2_2_2_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s(float vertexSharpness) const { │ │ │ │ │ +223 │ │ │ │ │ +224 return _d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s(vertexSharpness); │ │ │ │ │ +225} │ │ │ │ │ +226 │ │ │ │ │ +227inline void │ │ │ │ │ +_2_2_8_C_r_e_a_s_e_:_:_G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e(float const * incidentEdgeSharpness, int │ │ │ │ │ +incidentEdgeCount, │ │ │ │ │ +229 int sharpEdgePair[2]) const { │ │ │ │ │ +230 │ │ │ │ │ +231 // Only to be called when a crease is present at a vertex -- exactly two │ │ │ │ │ +sharp │ │ │ │ │ +232 // edges are expected here: │ │ │ │ │ +233 // │ │ │ │ │ +234 sharpEdgePair[0] = 0; │ │ │ │ │ +235 while (_I_s_S_m_o_o_t_h(incidentEdgeSharpness[sharpEdgePair[0]])) ++ sharpEdgePair │ │ │ │ │ +[0]; │ │ │ │ │ +236 │ │ │ │ │ +237 sharpEdgePair[1] = incidentEdgeCount - 1; │ │ │ │ │ +238 while (_I_s_S_m_o_o_t_h(incidentEdgeSharpness[sharpEdgePair[1]])) -- sharpEdgePair │ │ │ │ │ +[1]; │ │ │ │ │ +239} │ │ │ │ │ +240 │ │ │ │ │ +241} // end namespace sdc │ │ │ │ │ +242 │ │ │ │ │ +243} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +244using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +245} // end namespace OpenSubdiv │ │ │ │ │ +246 │ │ │ │ │ +247#endif /* OPENSUBDIV3_SDC_CREASE_H */ │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e │ │ │ │ │ +Types, constants and utilities related to semi-sharp creasing – whose │ │ │ │ │ +implementation is independent o... │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_6_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_V_e_r_t_e_x_S_h_a_r_p_n_e_s_s │ │ │ │ │ +float SubdivideVertexSharpness(float vertexSharpness) const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_2_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_I_n_f_i_n_i_t_e │ │ │ │ │ +static bool IsInfinite(float sharpness) │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_u_l_e │ │ │ │ │ +Rule │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_O_R_N_E_R │ │ │ │ │ +@ RULE_CORNER │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___D_A_R_T │ │ │ │ │ +@ RULE_DART │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___S_M_O_O_T_H │ │ │ │ │ +@ RULE_SMOOTH │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___C_R_E_A_S_E │ │ │ │ │ +@ RULE_CREASE │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_R_U_L_E___U_N_K_N_O_W_N │ │ │ │ │ +@ RULE_UNKNOWN │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_8_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_V_e_r_t_e_x │ │ │ │ │ +float SharpenBoundaryVertex(float edgeSharpness) const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___S_M_O_O_T_H │ │ │ │ │ +static float const SHARPNESS_SMOOTH │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_6_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_G_e_t_S_h_a_r_p_E_d_g_e_P_a_i_r_O_f_C_r_e_a_s_e │ │ │ │ │ +void GetSharpEdgePairOfCrease(float const *incidentEdgeSharpness, int │ │ │ │ │ +incidentEdgeCount, int sharpEdgePair[2]) const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_2_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_H_A_R_P_N_E_S_S___I_N_F_I_N_I_T_E │ │ │ │ │ +static float const SHARPNESS_INFINITE │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e │ │ │ │ │ +Rule DetermineVertexVertexRule(float vertexSharpness, int incidentEdgeCount, │ │ │ │ │ +float const *incidentEdgeSharpness) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_d_e_c_r_e_m_e_n_t_S_h_a_r_p_n_e_s_s │ │ │ │ │ +float decrementSharpness(float sharpness) const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_0_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_S_m_o_o_t_h │ │ │ │ │ +static bool IsSmooth(float sharpness) │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_7_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_D_e_t_e_r_m_i_n_e_V_e_r_t_e_x_V_e_r_t_e_x_R_u_l_e │ │ │ │ │ +Rule DetermineVertexVertexRule(float vertexSharpness, int sharpEdgeCount) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_U_n_i_f_o_r_m │ │ │ │ │ +bool IsUniform() const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_S_e_m_i_S_h_a_r_p │ │ │ │ │ +static bool IsSemiSharp(float sharpness) │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_C_r_e_a_s_e │ │ │ │ │ +Crease(Options const &options) │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_: │ │ │ │ │ +_S_u_b_d_i_v_i_d_e_E_d_g_e_S_h_a_r_p_n_e_s_s_e_s_A_r_o_u_n_d_V_e_r_t_e_x │ │ │ │ │ +void SubdivideEdgeSharpnessesAroundVertex(int incidentEdgeCountAtVertex, float │ │ │ │ │ +const *incidentEdgeSharpnessAroundVertex, float │ │ │ │ │ +*childEdgesSharpnessAroundVertex) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_U_n_i_f_o_r_m_S_h_a_r_p_n_e_s_s │ │ │ │ │ +float SubdivideUniformSharpness(float vertexOrEdgeSharpness) const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_2_1_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_C_r_e_a_s_e │ │ │ │ │ +Crease() │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_h_a_r_p_e_n_B_o_u_n_d_a_r_y_E_d_g_e │ │ │ │ │ +float SharpenBoundaryEdge(float edgeSharpness) const │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_1_8_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_C_o_m_p_u_t_e_F_r_a_c_t_i_o_n_a_l_W_e_i_g_h_t_A_t_V_e_r_t_e_x │ │ │ │ │ +float ComputeFractionalWeightAtVertex(float vertexSharpness, float │ │ │ │ │ +childVertexSharpness, int incidentEdgeCount, float const │ │ │ │ │ +*incidentEdgeSharpness, float const *childEdgesSharpness) const │ │ │ │ │ +Transitional weighting: When the rules applicable to a parent vertex and its │ │ │ │ │ +child differ,... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_S_u_b_d_i_v_i_d_e_E_d_g_e_S_h_a_r_p_n_e_s_s_A_t_V_e_r_t_e_x │ │ │ │ │ +float SubdivideEdgeSharpnessAtVertex(float edgeSharpness, int │ │ │ │ │ +incidentEdgeCountAtEndVertex, float const *edgeSharpnessAroundEndVertex) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_I_s_S_h_a_r_p │ │ │ │ │ +static bool IsSharp(float sharpness) │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_C_r_e_a_s_e_:_:_~_C_r_e_a_s_e │ │ │ │ │ +~Crease() │ │ │ │ │ +DDeeffiinniittiioonn _c_r_e_a_s_e_._h_:_9_3 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s │ │ │ │ │ All supported options applying to subdivision scheme. │ │ │ │ │ DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n │ │ │ │ │ -TriangleSubdivision │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_T_R_I___S_U_B___C_A_T_M_A_R_K │ │ │ │ │ -@ TRI_SUB_CATMARK │ │ │ │ │ -Catmark weights (Catmark scheme only) │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_T_R_I___S_U_B___S_M_O_O_T_H │ │ │ │ │ -@ TRI_SUB_SMOOTH │ │ │ │ │ -"smooth triangle" weights (Catmark scheme only) │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_C_r_e_a_s_i_n_g_M_e_t_h_o_d │ │ │ │ │ -CreasingMethod │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_8 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_C_R_E_A_S_E___U_N_I_F_O_R_M │ │ │ │ │ @ CREASE_UNIFORM │ │ │ │ │ Catmark rule. │ │ │ │ │ DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_C_R_E_A_S_E___C_H_A_I_K_I_N │ │ │ │ │ -@ CREASE_CHAIKIN │ │ │ │ │ -Chaikin rule. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n │ │ │ │ │ -TriangleSubdivision GetTriangleSubdivision() const │ │ │ │ │ -Get triangle subdivision weights rule (Catmark scheme only !) │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_0_7 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d │ │ │ │ │ CreasingMethod GetCreasingMethod() const │ │ │ │ │ Get edge crease rule. │ │ │ │ │ DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_0_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_O_p_t_i_o_n_s │ │ │ │ │ -Options() │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_7_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_S_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -void SetFVarLinearInterpolation(FVarLinearInterpolation b) │ │ │ │ │ -Set face-varying interpolation rule. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_9_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_S_e_t_T_r_i_a_n_g_l_e_S_u_b_d_i_v_i_s_i_o_n │ │ │ │ │ -void SetTriangleSubdivision(TriangleSubdivision t) │ │ │ │ │ -Set triangle subdivision weights rule (Catmark scheme only !) │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_1_0 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ VtxBoundaryInterpolation GetVtxBoundaryInterpolation() const │ │ │ │ │ Get vertex boundary interpolation rule. │ │ │ │ │ DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_8_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -FVarLinearInterpolation │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___O_N_L_Y │ │ │ │ │ -@ FVAR_LINEAR_CORNERS_ONLY │ │ │ │ │ -sharpen corners only │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___B_O_U_N_D_A_R_I_E_S │ │ │ │ │ -@ FVAR_LINEAR_BOUNDARIES │ │ │ │ │ -sharpen all boundaries ("always sharp") │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___P_L_U_S_2 │ │ │ │ │ -@ FVAR_LINEAR_CORNERS_PLUS2 │ │ │ │ │ -("edge and corner + propagate corner") │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___C_O_R_N_E_R_S___P_L_U_S_1 │ │ │ │ │ -@ FVAR_LINEAR_CORNERS_PLUS1 │ │ │ │ │ -("edge corner") │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___A_L_L │ │ │ │ │ -@ FVAR_LINEAR_ALL │ │ │ │ │ -bilinear interpolation ("bilinear") │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_F_V_A_R___L_I_N_E_A_R___N_O_N_E │ │ │ │ │ -@ FVAR_LINEAR_NONE │ │ │ │ │ -smooth everywhere ("edge only") │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_S_e_t_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -void SetVtxBoundaryInterpolation(VtxBoundaryInterpolation b) │ │ │ │ │ -Set vertex boundary interpolation rule. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_9_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_G_e_t_F_V_a_r_L_i_n_e_a_r_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -FVarLinearInterpolation GetFVarLinearInterpolation() const │ │ │ │ │ -Get face-varying interpolation rule. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_9_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_t_x_B_o_u_n_d_a_r_y_I_n_t_e_r_p_o_l_a_t_i_o_n │ │ │ │ │ -VtxBoundaryInterpolation │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_T_X___B_O_U_N_D_A_R_Y___N_O_N_E │ │ │ │ │ -@ VTX_BOUNDARY_NONE │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___O_N_L_Y │ │ │ │ │ -@ VTX_BOUNDARY_EDGE_ONLY │ │ │ │ │ -all boundary edges sharpened and interpolated │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_6 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_V_T_X___B_O_U_N_D_A_R_Y___E_D_G_E___A_N_D___C_O_R_N_E_R │ │ │ │ │ @ VTX_BOUNDARY_EDGE_AND_CORNER │ │ │ │ │ DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_5_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_S_d_c_:_:_O_p_t_i_o_n_s_:_:_S_e_t_C_r_e_a_s_i_n_g_M_e_t_h_o_d │ │ │ │ │ -void SetCreasingMethod(CreasingMethod c) │ │ │ │ │ -Set edge crease rule. │ │ │ │ │ -DDeeffiinniittiioonn _o_p_t_i_o_n_s_._h_:_1_0_4 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _s_d_c │ │ │ │ │ - * _o_p_t_i_o_n_s_._h │ │ │ │ │ + * _c_r_e_a_s_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00782.html │ │ │ │ @@ -93,15 +93,15 @@ │ │ │ │
│ │ │ │
│ │ │ │ Namespaces
│ │ │ │
catmarkScheme.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/scheme.h"
│ │ │ │ +#include "../sdc/scheme.h"
│ │ │ │ #include <cassert>
│ │ │ │ #include <cmath>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00782_source.html │ │ │ │ @@ -649,18 +649,18 @@ │ │ │ │
530} // end namespace sdc
│ │ │ │
531
│ │ │ │
532} // end namespace OPENSUBDIV_VERSION
│ │ │ │
533using namespace OPENSUBDIV_VERSION;
│ │ │ │
534} // end namespace OpenSubdiv
│ │ │ │
535
│ │ │ │
536#endif /* OPENSUBDIV3_SDC_CATMARK_SCHEME_H */
│ │ │ │ - │ │ │ │ + │ │ │ │
Split
Enumerated type for all face splitting schemes.
Definition types.h:47
│ │ │ │
@ SPLIT_TO_QUADS
Used by Catmark and Bilinear.
Definition types.h:48
│ │ │ │ -
@ TRI_SUB_SMOOTH
"smooth triangle" weights (Catmark scheme only)
Definition options.h:74
│ │ │ │ +
@ TRI_SUB_SMOOTH
"smooth triangle" weights (Catmark scheme only)
Definition options.h:74
│ │ │ │
void assignSmoothMaskForEdge(EDGE const &edge, MASK &mask) const
│ │ │ │ │ │ │ │
void assignCreaseMaskForVertex(VERTEX const &edge, MASK &mask, int const creaseEnds[2]) const
│ │ │ │
void assignCreaseLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK &tan2, int const creaseEnds[2]) const
│ │ │ │ │ │ │ │
void assignSmoothLimitMask(VERTEX const &vertex, MASK &pos) const
│ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00785.html │ │ │ │ @@ -93,15 +93,15 @@ │ │ │ │
│ │ │ │
│ │ │ │ Namespaces
│ │ │ │
bilinearScheme.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../sdc/scheme.h"
│ │ │ │ +#include "../sdc/scheme.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Namespaces

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00785_source.html │ │ │ │ @@ -277,23 +277,23 @@ │ │ │ │ │ │ │ │
159
│ │ │ │
160} // end namespace OPENSUBDIV_VERSION
│ │ │ │
161using namespace OPENSUBDIV_VERSION;
│ │ │ │
162} // end namespace OpenSubdiv
│ │ │ │
163
│ │ │ │
164#endif /* OPENSUBDIV3_SDC_BILINEAR_SCHEME_H */
│ │ │ │ - │ │ │ │ + │ │ │ │
Split
Enumerated type for all face splitting schemes.
Definition types.h:47
│ │ │ │
@ SPLIT_TO_QUADS
Used by Catmark and Bilinear.
Definition types.h:48
│ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ -
void ComputeVertexVertexMask(VERTEX const &vertexNeighborhood, MASK &vertexVertexMask, Crease::Rule parentRule=Crease::RULE_UNKNOWN, Crease::Rule childRule=Crease::RULE_UNKNOWN) const
Vertex-vertex masks If known, a single Rule or pair of Rules can be specified (indicating a crease tr...
Definition scheme.h:512
│ │ │ │ +
void ComputeVertexVertexMask(VERTEX const &vertexNeighborhood, MASK &vertexVertexMask, Crease::Rule parentRule=Crease::RULE_UNKNOWN, Crease::Rule childRule=Crease::RULE_UNKNOWN) const
Vertex-vertex masks If known, a single Rule or pair of Rules can be specified (indicating a crease tr...
Definition scheme.h:512
│ │ │ │
void assignCreaseLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK &tan2, int const creaseEnds[2]) const
│ │ │ │ │ │ │ │ -
void ComputeEdgeVertexMask(EDGE const &edgeNeighborhood, MASK &edgeVertexMask, Crease::Rule parentRule=Crease::RULE_UNKNOWN, Crease::Rule childRule=Crease::RULE_UNKNOWN) const
Edge-vertex masks If known, the Rule for the edge and/or the derived vertex can be specified to accel...
Definition scheme.h:392
│ │ │ │ +
void ComputeEdgeVertexMask(EDGE const &edgeNeighborhood, MASK &edgeVertexMask, Crease::Rule parentRule=Crease::RULE_UNKNOWN, Crease::Rule childRule=Crease::RULE_UNKNOWN) const
Edge-vertex masks If known, the Rule for the edge and/or the derived vertex can be specified to accel...
Definition scheme.h:392
│ │ │ │
void assignSmoothLimitMask(VERTEX const &vertex, MASK &pos) const
│ │ │ │ │ │ │ │
void assignCreaseLimitMask(VERTEX const &vertex, MASK &pos, int const creaseEnds[2]) const
│ │ │ │ │ │ │ │
void assignSmoothLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK &tan2) const
│ │ │ │
void assignCornerLimitMask(VERTEX const &vertex, MASK &pos) const
│ │ │ │
void assignCornerLimitTangentMasks(VERTEX const &vertex, MASK &tan1, MASK &tan2) const
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00788.html │ │ │ │ @@ -95,15 +95,15 @@ │ │ │ │ Classes | │ │ │ │ Namespaces │ │ │ │
cudaEvaluator.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include <vector>
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │ #include "../osd/types.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00788_source.html │ │ │ │ @@ -640,18 +640,18 @@ │ │ │ │
1267} // end namespace OPENSUBDIV_VERSION
│ │ │ │
1268using namespace OPENSUBDIV_VERSION;
│ │ │ │
1269
│ │ │ │
1270} // end namespace OpenSubdiv
│ │ │ │
1271
│ │ │ │
1272
│ │ │ │
1273#endif // OPENSUBDIV3_OSD_CUDA_EVALUATOR_H
│ │ │ │ - │ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ -
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ + │ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ +
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
CudaStencilTable(Far::LimitStencilTable const *limitStencilTable)
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00791.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/opencl.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/cudaPatchTable.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -87,24 +87,48 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
opencl.h File Reference
│ │ │ │ +
│ │ │ │ +Classes | │ │ │ │ +Namespaces
│ │ │ │ +
cudaPatchTable.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │ -
#include <CL/opencl.h>
│ │ │ │ +
#include "../version.h"
│ │ │ │ +#include "../osd/nonCopyable.h"
│ │ │ │ +#include "../osd/types.h"
│ │ │ │ +#include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ +

│ │ │ │ Classes

class  CudaStencilTable
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +

│ │ │ │ +Classes

class  CudaPatchTable
 CUDA patch table. More...
 
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +

│ │ │ │ +Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,11 +1,28 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -opencl.h File Reference │ │ │ │ │ -#include │ │ │ │ │ +_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ +cudaPatchTable.h File Reference │ │ │ │ │ +#include "../version.h" │ │ │ │ │ +#include "../osd/nonCopyable.h" │ │ │ │ │ +#include "_._._/_o_s_d_/_t_y_p_e_s_._h" │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ +CCllaasssseess │ │ │ │ │ +class   _C_u_d_a_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +  CUDA patch table. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +NNaammeessppaacceess │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ +  │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │ +  │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │ +  │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │ +  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _o_p_e_n_c_l_._h │ │ │ │ │ + * _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00791_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/opencl.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/cudaPatchTable.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ -
opencl.h
│ │ │ │ +
cudaPatchTable.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2014 Pixar
│ │ │ │ +
2// Copyright 2015 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -119,32 +119,131 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_OPENCL_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_OPENCL_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H
│ │ │ │
27
│ │ │ │ -
28#if defined(OPENSUBDIV_HAS_CLEW)
│ │ │ │ -
29# include <clew.h>
│ │ │ │ -
30#else
│ │ │ │ -
31# if defined(__APPLE__)
│ │ │ │ -
32# include <OpenCL/opencl.h>
│ │ │ │ -
33# else
│ │ │ │ -
34# include <CL/opencl.h>
│ │ │ │ -
35# endif
│ │ │ │ -
36#endif
│ │ │ │ +
28#include "../version.h"
│ │ │ │ +
29
│ │ │ │ +
30#include "../osd/nonCopyable.h"
│ │ │ │ +
31#include "../osd/types.h"
│ │ │ │ +
32
│ │ │ │ +
33#include <vector>
│ │ │ │ +
34
│ │ │ │ +
35namespace OpenSubdiv {
│ │ │ │ +
36namespace OPENSUBDIV_VERSION {
│ │ │ │
37
│ │ │ │ -
38#endif // OPENSUBDIV3_OSD_CL_UTIL_H
│ │ │ │ +
38namespace Far{
│ │ │ │ +
39 class PatchTable;
│ │ │ │ +
40};
│ │ │ │ +
41
│ │ │ │ +
42namespace Osd {
│ │ │ │ +
43
│ │ │ │ +
│ │ │ │ +
51class CudaPatchTable : private NonCopyable<CudaPatchTable> {
│ │ │ │ +
52public:
│ │ │ │ +
54 static CudaPatchTable *Create(Far::PatchTable const *patchTable,
│ │ │ │ +
55 void *deviceContext = NULL);
│ │ │ │ + │ │ │ │ +
58
│ │ │ │ +
60 void *GetPatchArrayBuffer() const { return _patchArrays; }
│ │ │ │ +
61
│ │ │ │ +
63 void *GetPatchIndexBuffer() const { return _indexBuffer; }
│ │ │ │ +
64
│ │ │ │ +
66 void *GetPatchParamBuffer() const { return _patchParamBuffer; }
│ │ │ │ +
67
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ +
71 }
│ │ │ │ +
│ │ │ │ +
│ │ │ │ + │ │ │ │ + │ │ │ │ +
75 }
│ │ │ │ +
│ │ │ │ +
76
│ │ │ │ +
78 int GetNumFVarChannels() const { return (int)_fvarPatchArrays.size(); }
│ │ │ │ +
79
│ │ │ │ +
│ │ │ │ +
81 void *GetFVarPatchArrayBuffer(int fvarChannel) const {
│ │ │ │ +
82 return _fvarPatchArrays[fvarChannel];
│ │ │ │ +
83 }
│ │ │ │ +
│ │ │ │ +
84
│ │ │ │ +
│ │ │ │ +
86 void *GetFVarPatchIndexBuffer(int fvarChannel = 0) const {
│ │ │ │ +
87 return _fvarIndexBuffers[fvarChannel];
│ │ │ │ +
88 }
│ │ │ │ +
│ │ │ │ +
89
│ │ │ │ +
│ │ │ │ +
91 void *GetFVarPatchParamBuffer(int fvarChannel = 0) const {
│ │ │ │ +
92 return _fvarParamBuffers[fvarChannel];
│ │ │ │ +
93 }
│ │ │ │ +
│ │ │ │ +
94
│ │ │ │ +
95protected:
│ │ │ │ + │ │ │ │ +
97
│ │ │ │ +
98 bool allocate(Far::PatchTable const *patchTable);
│ │ │ │ +
99
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
103
│ │ │ │ + │ │ │ │ + │ │ │ │ +
106
│ │ │ │ +
107 std::vector<void *> _fvarPatchArrays;
│ │ │ │ +
108 std::vector<void *> _fvarIndexBuffers;
│ │ │ │ +
109 std::vector<void *> _fvarParamBuffers;
│ │ │ │ +
110};
│ │ │ │ +
│ │ │ │ +
111
│ │ │ │ +
112} // end namespace Osd
│ │ │ │ +
113
│ │ │ │ +
114} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
115using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
116
│ │ │ │ +
117} // end namespace OpenSubdiv
│ │ │ │ +
118
│ │ │ │ +
119#endif // OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H
│ │ │ │ + │ │ │ │ +
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ + │ │ │ │ +
void * GetFVarPatchArrayBuffer(int fvarChannel) const
Returns the cuda memory of the array of Osd::PatchArray buffer.
│ │ │ │ + │ │ │ │ +
static CudaPatchTable * Create(Far::PatchTable const *patchTable, void *deviceContext=NULL)
Creator. Returns NULL if error.
│ │ │ │ + │ │ │ │ +
void * GetVaryingPatchIndexBuffer() const
Returns the cuda memory of the array of varying control vertices.
│ │ │ │ + │ │ │ │ +
void * GetVaryingPatchArrayBuffer() const
Returns the cuda memory of the array of Osd::PatchArray buffer.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
void * GetPatchArrayBuffer() const
Returns the cuda memory of the array of Osd::PatchArray buffer.
│ │ │ │ + │ │ │ │ +
bool allocate(Far::PatchTable const *patchTable)
│ │ │ │ +
void * GetPatchIndexBuffer() const
Returns the cuda memory of the patch control vertices.
│ │ │ │ +
int GetNumFVarChannels() const
Returns the number of face-varying channels buffers.
│ │ │ │ + │ │ │ │ +
void * GetPatchParamBuffer() const
Returns the cuda memory of the array of Osd::PatchParam buffer.
│ │ │ │ +
void * GetFVarPatchIndexBuffer(int fvarChannel=0) const
Returns the cuda memory of the array of face-varying control vertices.
│ │ │ │ +
void * GetFVarPatchParamBuffer(int fvarChannel=0) const
Returns the cuda memory of the array of face-varying param.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -opencl.h │ │ │ │ │ +cudaPatchTable.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2014 Pixar │ │ │ │ │ +2// Copyright 2015 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -24,25 +24,167 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_OPENCL_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_OPENCL_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H │ │ │ │ │ 27 │ │ │ │ │ -28#if defined(OPENSUBDIV_HAS_CLEW) │ │ │ │ │ -29# include │ │ │ │ │ -30#else │ │ │ │ │ -31# if defined(__APPLE__) │ │ │ │ │ -32# include │ │ │ │ │ -33# else │ │ │ │ │ -34# include │ │ │ │ │ -35# endif │ │ │ │ │ -36#endif │ │ │ │ │ +28#include "../version.h" │ │ │ │ │ +29 │ │ │ │ │ +30#include "../osd/nonCopyable.h" │ │ │ │ │ +31#include "../osd/types.h" │ │ │ │ │ +32 │ │ │ │ │ +33#include │ │ │ │ │ +34 │ │ │ │ │ +35namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +36namespace OPENSUBDIV_VERSION { │ │ │ │ │ 37 │ │ │ │ │ -38#endif // OPENSUBDIV3_OSD_CL_UTIL_H │ │ │ │ │ +38namespace Far{ │ │ │ │ │ +39 class PatchTable; │ │ │ │ │ +40}; │ │ │ │ │ +41 │ │ │ │ │ +42namespace Osd { │ │ │ │ │ +43 │ │ │ │ │ +_5_1class _C_u_d_a_P_a_t_c_h_T_a_b_l_e : private NonCopyable { │ │ │ │ │ +52public: │ │ │ │ │ +_5_4 static _C_u_d_a_P_a_t_c_h_T_a_b_l_e *_C_r_e_a_t_e(_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e const *patchTable, │ │ │ │ │ +55 void *deviceContext = NULL); │ │ │ │ │ +_5_7 _~_C_u_d_a_P_a_t_c_h_T_a_b_l_e(); │ │ │ │ │ +58 │ │ │ │ │ +_6_0 void *_G_e_t_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r() const { return ___p_a_t_c_h_A_r_r_a_y_s; } │ │ │ │ │ +61 │ │ │ │ │ +_6_3 void *_G_e_t_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r() const { return ___i_n_d_e_x_B_u_f_f_e_r; } │ │ │ │ │ +64 │ │ │ │ │ +_6_6 void *_G_e_t_P_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r() const { return ___p_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r; } │ │ │ │ │ +67 │ │ │ │ │ +_6_9 void *_G_e_t_V_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r() const { │ │ │ │ │ +70 return ___v_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_s; │ │ │ │ │ +71 } │ │ │ │ │ +_7_3 void *_G_e_t_V_a_r_y_i_n_g_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r() const { │ │ │ │ │ +74 return ___v_a_r_y_i_n_g_I_n_d_e_x_B_u_f_f_e_r; │ │ │ │ │ +75 } │ │ │ │ │ +76 │ │ │ │ │ +_7_8 int _G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const { return (int)___f_v_a_r_P_a_t_c_h_A_r_r_a_y_s.size(); } │ │ │ │ │ +79 │ │ │ │ │ +_8_1 void *_G_e_t_F_V_a_r_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r(int fvarChannel) const { │ │ │ │ │ +82 return ___f_v_a_r_P_a_t_c_h_A_r_r_a_y_s[fvarChannel]; │ │ │ │ │ +83 } │ │ │ │ │ +84 │ │ │ │ │ +_8_6 void *_G_e_t_F_V_a_r_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r(int fvarChannel = 0) const { │ │ │ │ │ +87 return ___f_v_a_r_I_n_d_e_x_B_u_f_f_e_r_s[fvarChannel]; │ │ │ │ │ +88 } │ │ │ │ │ +89 │ │ │ │ │ +_9_1 void *_G_e_t_F_V_a_r_P_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r(int fvarChannel = 0) const { │ │ │ │ │ +92 return ___f_v_a_r_P_a_r_a_m_B_u_f_f_e_r_s[fvarChannel]; │ │ │ │ │ +93 } │ │ │ │ │ +94 │ │ │ │ │ +95protected: │ │ │ │ │ +_9_6 _C_u_d_a_P_a_t_c_h_T_a_b_l_e(); │ │ │ │ │ +97 │ │ │ │ │ +_9_8 bool _a_l_l_o_c_a_t_e(_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e const *patchTable); │ │ │ │ │ +99 │ │ │ │ │ +_1_0_0 void *___p_a_t_c_h_A_r_r_a_y_s; │ │ │ │ │ +_1_0_1 void *___i_n_d_e_x_B_u_f_f_e_r; │ │ │ │ │ +_1_0_2 void *___p_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r; │ │ │ │ │ +103 │ │ │ │ │ +_1_0_4 void *___v_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_s; │ │ │ │ │ +_1_0_5 void *___v_a_r_y_i_n_g_I_n_d_e_x_B_u_f_f_e_r; │ │ │ │ │ +106 │ │ │ │ │ +_1_0_7 std::vector ___f_v_a_r_P_a_t_c_h_A_r_r_a_y_s; │ │ │ │ │ +_1_0_8 std::vector ___f_v_a_r_I_n_d_e_x_B_u_f_f_e_r_s; │ │ │ │ │ +_1_0_9 std::vector ___f_v_a_r_P_a_r_a_m_B_u_f_f_e_r_s; │ │ │ │ │ +110}; │ │ │ │ │ +111 │ │ │ │ │ +112} // end namespace Osd │ │ │ │ │ +113 │ │ │ │ │ +114} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +115using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +116 │ │ │ │ │ +117} // end namespace OpenSubdiv │ │ │ │ │ +118 │ │ │ │ │ +119#endif // OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v │ │ │ │ │ +DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +Container for arrays of parametric patches. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_._h_:_5_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +CUDA patch table. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_F_V_a_r_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r │ │ │ │ │ +void * GetFVarPatchArrayBuffer(int fvarChannel) const │ │ │ │ │ +Returns the cuda memory of the array of Osd::PatchArray buffer. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_8_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___f_v_a_r_P_a_r_a_m_B_u_f_f_e_r_s │ │ │ │ │ +std::vector< void * > _fvarParamBuffers │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ +static CudaPatchTable * Create(Far::PatchTable const *patchTable, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +Creator. Returns NULL if error. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___v_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_s │ │ │ │ │ +void * _varyingPatchArrays │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_V_a_r_y_i_n_g_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ +void * GetVaryingPatchIndexBuffer() const │ │ │ │ │ +Returns the cuda memory of the array of varying control vertices. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___f_v_a_r_I_n_d_e_x_B_u_f_f_e_r_s │ │ │ │ │ +std::vector< void * > _fvarIndexBuffers │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_V_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r │ │ │ │ │ +void * GetVaryingPatchArrayBuffer() const │ │ │ │ │ +Returns the cuda memory of the array of Osd::PatchArray buffer. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_6_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___v_a_r_y_i_n_g_I_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ +void * _varyingIndexBuffer │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_~_C_u_d_a_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +~CudaPatchTable() │ │ │ │ │ +Destructor. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r │ │ │ │ │ +void * GetPatchArrayBuffer() const │ │ │ │ │ +Returns the cuda memory of the array of Osd::PatchArray buffer. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_6_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___f_v_a_r_P_a_t_c_h_A_r_r_a_y_s │ │ │ │ │ +std::vector< void * > _fvarPatchArrays │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_a_l_l_o_c_a_t_e │ │ │ │ │ +bool allocate(Far::PatchTable const *patchTable) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ +void * GetPatchIndexBuffer() const │ │ │ │ │ +Returns the cuda memory of the patch control vertices. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_6_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ +int GetNumFVarChannels() const │ │ │ │ │ +Returns the number of face-varying channels buffers. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___p_a_t_c_h_A_r_r_a_y_s │ │ │ │ │ +void * _patchArrays │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_P_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r │ │ │ │ │ +void * GetPatchParamBuffer() const │ │ │ │ │ +Returns the cuda memory of the array of Osd::PatchParam buffer. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_F_V_a_r_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ +void * GetFVarPatchIndexBuffer(int fvarChannel=0) const │ │ │ │ │ +Returns the cuda memory of the array of face-varying control vertices. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_F_V_a_r_P_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r │ │ │ │ │ +void * GetFVarPatchParamBuffer(int fvarChannel=0) const │ │ │ │ │ +Returns the cuda memory of the array of face-varying param. │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_9_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +CudaPatchTable() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___p_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r │ │ │ │ │ +void * _patchParamBuffer │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___i_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ +void * _indexBuffer │ │ │ │ │ +DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_1 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _o_p_e_n_c_l_._h │ │ │ │ │ + * _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00794.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/cudaPatchTable.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/opencl.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -87,48 +87,24 @@ │ │ │ │
No Matches
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ -
│ │ │ │ -Classes | │ │ │ │ -Namespaces
│ │ │ │ -
cudaPatchTable.h File Reference
│ │ │ │ +
opencl.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │ -
#include "../version.h"
│ │ │ │ -#include "../osd/nonCopyable.h"
│ │ │ │ -#include "../osd/types.h"
│ │ │ │ -#include <vector>
│ │ │ │ +
#include <CL/opencl.h>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -

│ │ │ │ -Classes

class  CudaPatchTable
 CUDA patch table. More...
 
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -

│ │ │ │ -Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,28 +1,11 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -cudaPatchTable.h File Reference │ │ │ │ │ -#include "../version.h" │ │ │ │ │ -#include "../osd/nonCopyable.h" │ │ │ │ │ -#include "_._._/_o_s_d_/_t_y_p_e_s_._h" │ │ │ │ │ -#include │ │ │ │ │ +opencl.h File Reference │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ -CCllaasssseess │ │ │ │ │ -class   _C_u_d_a_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -  CUDA patch table. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -NNaammeessppaacceess │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ -  │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │ -  │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │ -  │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │ -  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h │ │ │ │ │ + * _o_p_e_n_c_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00794_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/cudaPatchTable.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/opencl.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ -
cudaPatchTable.h
│ │ │ │ +
opencl.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2015 Pixar
│ │ │ │ +
2// Copyright 2014 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -119,131 +119,32 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_OPENCL_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_OPENCL_H
│ │ │ │
27
│ │ │ │ -
28#include "../version.h"
│ │ │ │ -
29
│ │ │ │ -
30#include "../osd/nonCopyable.h"
│ │ │ │ -
31#include "../osd/types.h"
│ │ │ │ -
32
│ │ │ │ -
33#include <vector>
│ │ │ │ -
34
│ │ │ │ -
35namespace OpenSubdiv {
│ │ │ │ -
36namespace OPENSUBDIV_VERSION {
│ │ │ │ +
28#if defined(OPENSUBDIV_HAS_CLEW)
│ │ │ │ +
29# include <clew.h>
│ │ │ │ +
30#else
│ │ │ │ +
31# if defined(__APPLE__)
│ │ │ │ +
32# include <OpenCL/opencl.h>
│ │ │ │ +
33# else
│ │ │ │ +
34# include <CL/opencl.h>
│ │ │ │ +
35# endif
│ │ │ │ +
36#endif
│ │ │ │
37
│ │ │ │ -
38namespace Far{
│ │ │ │ -
39 class PatchTable;
│ │ │ │ -
40};
│ │ │ │ -
41
│ │ │ │ -
42namespace Osd {
│ │ │ │ -
43
│ │ │ │ -
│ │ │ │ -
51class CudaPatchTable : private NonCopyable<CudaPatchTable> {
│ │ │ │ -
52public:
│ │ │ │ -
54 static CudaPatchTable *Create(Far::PatchTable const *patchTable,
│ │ │ │ -
55 void *deviceContext = NULL);
│ │ │ │ - │ │ │ │ -
58
│ │ │ │ -
60 void *GetPatchArrayBuffer() const { return _patchArrays; }
│ │ │ │ -
61
│ │ │ │ -
63 void *GetPatchIndexBuffer() const { return _indexBuffer; }
│ │ │ │ -
64
│ │ │ │ -
66 void *GetPatchParamBuffer() const { return _patchParamBuffer; }
│ │ │ │ -
67
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ -
71 }
│ │ │ │ -
│ │ │ │ -
│ │ │ │ - │ │ │ │ - │ │ │ │ -
75 }
│ │ │ │ -
│ │ │ │ -
76
│ │ │ │ -
78 int GetNumFVarChannels() const { return (int)_fvarPatchArrays.size(); }
│ │ │ │ -
79
│ │ │ │ -
│ │ │ │ -
81 void *GetFVarPatchArrayBuffer(int fvarChannel) const {
│ │ │ │ -
82 return _fvarPatchArrays[fvarChannel];
│ │ │ │ -
83 }
│ │ │ │ -
│ │ │ │ -
84
│ │ │ │ -
│ │ │ │ -
86 void *GetFVarPatchIndexBuffer(int fvarChannel = 0) const {
│ │ │ │ -
87 return _fvarIndexBuffers[fvarChannel];
│ │ │ │ -
88 }
│ │ │ │ -
│ │ │ │ -
89
│ │ │ │ -
│ │ │ │ -
91 void *GetFVarPatchParamBuffer(int fvarChannel = 0) const {
│ │ │ │ -
92 return _fvarParamBuffers[fvarChannel];
│ │ │ │ -
93 }
│ │ │ │ -
│ │ │ │ -
94
│ │ │ │ -
95protected:
│ │ │ │ - │ │ │ │ -
97
│ │ │ │ -
98 bool allocate(Far::PatchTable const *patchTable);
│ │ │ │ -
99
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
103
│ │ │ │ - │ │ │ │ - │ │ │ │ -
106
│ │ │ │ -
107 std::vector<void *> _fvarPatchArrays;
│ │ │ │ -
108 std::vector<void *> _fvarIndexBuffers;
│ │ │ │ -
109 std::vector<void *> _fvarParamBuffers;
│ │ │ │ -
110};
│ │ │ │ -
│ │ │ │ -
111
│ │ │ │ -
112} // end namespace Osd
│ │ │ │ -
113
│ │ │ │ -
114} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
115using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
116
│ │ │ │ -
117} // end namespace OpenSubdiv
│ │ │ │ -
118
│ │ │ │ -
119#endif // OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H
│ │ │ │ - │ │ │ │ -
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ - │ │ │ │ -
void * GetFVarPatchArrayBuffer(int fvarChannel) const
Returns the cuda memory of the array of Osd::PatchArray buffer.
│ │ │ │ - │ │ │ │ -
static CudaPatchTable * Create(Far::PatchTable const *patchTable, void *deviceContext=NULL)
Creator. Returns NULL if error.
│ │ │ │ - │ │ │ │ -
void * GetVaryingPatchIndexBuffer() const
Returns the cuda memory of the array of varying control vertices.
│ │ │ │ - │ │ │ │ -
void * GetVaryingPatchArrayBuffer() const
Returns the cuda memory of the array of Osd::PatchArray buffer.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
void * GetPatchArrayBuffer() const
Returns the cuda memory of the array of Osd::PatchArray buffer.
│ │ │ │ - │ │ │ │ -
bool allocate(Far::PatchTable const *patchTable)
│ │ │ │ -
void * GetPatchIndexBuffer() const
Returns the cuda memory of the patch control vertices.
│ │ │ │ -
int GetNumFVarChannels() const
Returns the number of face-varying channels buffers.
│ │ │ │ - │ │ │ │ -
void * GetPatchParamBuffer() const
Returns the cuda memory of the array of Osd::PatchParam buffer.
│ │ │ │ -
void * GetFVarPatchIndexBuffer(int fvarChannel=0) const
Returns the cuda memory of the array of face-varying control vertices.
│ │ │ │ -
void * GetFVarPatchParamBuffer(int fvarChannel=0) const
Returns the cuda memory of the array of face-varying param.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ +
38#endif // OPENSUBDIV3_OSD_CL_UTIL_H
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -cudaPatchTable.h │ │ │ │ │ +opencl.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2015 Pixar │ │ │ │ │ +2// Copyright 2014 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -24,167 +24,25 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_OPENCL_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_OPENCL_H │ │ │ │ │ 27 │ │ │ │ │ -28#include "../version.h" │ │ │ │ │ -29 │ │ │ │ │ -30#include "../osd/nonCopyable.h" │ │ │ │ │ -31#include "../osd/types.h" │ │ │ │ │ -32 │ │ │ │ │ -33#include │ │ │ │ │ -34 │ │ │ │ │ -35namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -36namespace OPENSUBDIV_VERSION { │ │ │ │ │ +28#if defined(OPENSUBDIV_HAS_CLEW) │ │ │ │ │ +29# include │ │ │ │ │ +30#else │ │ │ │ │ +31# if defined(__APPLE__) │ │ │ │ │ +32# include │ │ │ │ │ +33# else │ │ │ │ │ +34# include │ │ │ │ │ +35# endif │ │ │ │ │ +36#endif │ │ │ │ │ 37 │ │ │ │ │ -38namespace Far{ │ │ │ │ │ -39 class PatchTable; │ │ │ │ │ -40}; │ │ │ │ │ -41 │ │ │ │ │ -42namespace Osd { │ │ │ │ │ -43 │ │ │ │ │ -_5_1class _C_u_d_a_P_a_t_c_h_T_a_b_l_e : private NonCopyable { │ │ │ │ │ -52public: │ │ │ │ │ -_5_4 static _C_u_d_a_P_a_t_c_h_T_a_b_l_e *_C_r_e_a_t_e(_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e const *patchTable, │ │ │ │ │ -55 void *deviceContext = NULL); │ │ │ │ │ -_5_7 _~_C_u_d_a_P_a_t_c_h_T_a_b_l_e(); │ │ │ │ │ -58 │ │ │ │ │ -_6_0 void *_G_e_t_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r() const { return ___p_a_t_c_h_A_r_r_a_y_s; } │ │ │ │ │ -61 │ │ │ │ │ -_6_3 void *_G_e_t_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r() const { return ___i_n_d_e_x_B_u_f_f_e_r; } │ │ │ │ │ -64 │ │ │ │ │ -_6_6 void *_G_e_t_P_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r() const { return ___p_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r; } │ │ │ │ │ -67 │ │ │ │ │ -_6_9 void *_G_e_t_V_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r() const { │ │ │ │ │ -70 return ___v_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_s; │ │ │ │ │ -71 } │ │ │ │ │ -_7_3 void *_G_e_t_V_a_r_y_i_n_g_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r() const { │ │ │ │ │ -74 return ___v_a_r_y_i_n_g_I_n_d_e_x_B_u_f_f_e_r; │ │ │ │ │ -75 } │ │ │ │ │ -76 │ │ │ │ │ -_7_8 int _G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s() const { return (int)___f_v_a_r_P_a_t_c_h_A_r_r_a_y_s.size(); } │ │ │ │ │ -79 │ │ │ │ │ -_8_1 void *_G_e_t_F_V_a_r_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r(int fvarChannel) const { │ │ │ │ │ -82 return ___f_v_a_r_P_a_t_c_h_A_r_r_a_y_s[fvarChannel]; │ │ │ │ │ -83 } │ │ │ │ │ -84 │ │ │ │ │ -_8_6 void *_G_e_t_F_V_a_r_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r(int fvarChannel = 0) const { │ │ │ │ │ -87 return ___f_v_a_r_I_n_d_e_x_B_u_f_f_e_r_s[fvarChannel]; │ │ │ │ │ -88 } │ │ │ │ │ -89 │ │ │ │ │ -_9_1 void *_G_e_t_F_V_a_r_P_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r(int fvarChannel = 0) const { │ │ │ │ │ -92 return ___f_v_a_r_P_a_r_a_m_B_u_f_f_e_r_s[fvarChannel]; │ │ │ │ │ -93 } │ │ │ │ │ -94 │ │ │ │ │ -95protected: │ │ │ │ │ -_9_6 _C_u_d_a_P_a_t_c_h_T_a_b_l_e(); │ │ │ │ │ -97 │ │ │ │ │ -_9_8 bool _a_l_l_o_c_a_t_e(_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e const *patchTable); │ │ │ │ │ -99 │ │ │ │ │ -_1_0_0 void *___p_a_t_c_h_A_r_r_a_y_s; │ │ │ │ │ -_1_0_1 void *___i_n_d_e_x_B_u_f_f_e_r; │ │ │ │ │ -_1_0_2 void *___p_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r; │ │ │ │ │ -103 │ │ │ │ │ -_1_0_4 void *___v_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_s; │ │ │ │ │ -_1_0_5 void *___v_a_r_y_i_n_g_I_n_d_e_x_B_u_f_f_e_r; │ │ │ │ │ -106 │ │ │ │ │ -_1_0_7 std::vector ___f_v_a_r_P_a_t_c_h_A_r_r_a_y_s; │ │ │ │ │ -_1_0_8 std::vector ___f_v_a_r_I_n_d_e_x_B_u_f_f_e_r_s; │ │ │ │ │ -_1_0_9 std::vector ___f_v_a_r_P_a_r_a_m_B_u_f_f_e_r_s; │ │ │ │ │ -110}; │ │ │ │ │ -111 │ │ │ │ │ -112} // end namespace Osd │ │ │ │ │ -113 │ │ │ │ │ -114} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -115using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -116 │ │ │ │ │ -117} // end namespace OpenSubdiv │ │ │ │ │ -118 │ │ │ │ │ -119#endif // OPENSUBDIV3_OSD_CUDA_PATCH_TABLE_H │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v │ │ │ │ │ -DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -Container for arrays of parametric patches. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_._h_:_5_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -CUDA patch table. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_F_V_a_r_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r │ │ │ │ │ -void * GetFVarPatchArrayBuffer(int fvarChannel) const │ │ │ │ │ -Returns the cuda memory of the array of Osd::PatchArray buffer. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_8_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___f_v_a_r_P_a_r_a_m_B_u_f_f_e_r_s │ │ │ │ │ -std::vector< void * > _fvarParamBuffers │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ -static CudaPatchTable * Create(Far::PatchTable const *patchTable, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -Creator. Returns NULL if error. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___v_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_s │ │ │ │ │ -void * _varyingPatchArrays │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_V_a_r_y_i_n_g_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ -void * GetVaryingPatchIndexBuffer() const │ │ │ │ │ -Returns the cuda memory of the array of varying control vertices. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___f_v_a_r_I_n_d_e_x_B_u_f_f_e_r_s │ │ │ │ │ -std::vector< void * > _fvarIndexBuffers │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_V_a_r_y_i_n_g_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r │ │ │ │ │ -void * GetVaryingPatchArrayBuffer() const │ │ │ │ │ -Returns the cuda memory of the array of Osd::PatchArray buffer. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_6_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___v_a_r_y_i_n_g_I_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ -void * _varyingIndexBuffer │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_~_C_u_d_a_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -~CudaPatchTable() │ │ │ │ │ -Destructor. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_P_a_t_c_h_A_r_r_a_y_B_u_f_f_e_r │ │ │ │ │ -void * GetPatchArrayBuffer() const │ │ │ │ │ -Returns the cuda memory of the array of Osd::PatchArray buffer. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_6_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___f_v_a_r_P_a_t_c_h_A_r_r_a_y_s │ │ │ │ │ -std::vector< void * > _fvarPatchArrays │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_a_l_l_o_c_a_t_e │ │ │ │ │ -bool allocate(Far::PatchTable const *patchTable) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ -void * GetPatchIndexBuffer() const │ │ │ │ │ -Returns the cuda memory of the patch control vertices. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_6_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_N_u_m_F_V_a_r_C_h_a_n_n_e_l_s │ │ │ │ │ -int GetNumFVarChannels() const │ │ │ │ │ -Returns the number of face-varying channels buffers. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_7_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___p_a_t_c_h_A_r_r_a_y_s │ │ │ │ │ -void * _patchArrays │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_P_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r │ │ │ │ │ -void * GetPatchParamBuffer() const │ │ │ │ │ -Returns the cuda memory of the array of Osd::PatchParam buffer. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_F_V_a_r_P_a_t_c_h_I_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ -void * GetFVarPatchIndexBuffer(int fvarChannel=0) const │ │ │ │ │ -Returns the cuda memory of the array of face-varying control vertices. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_G_e_t_F_V_a_r_P_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r │ │ │ │ │ -void * GetFVarPatchParamBuffer(int fvarChannel=0) const │ │ │ │ │ -Returns the cuda memory of the array of face-varying param. │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_9_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -CudaPatchTable() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___p_a_t_c_h_P_a_r_a_m_B_u_f_f_e_r │ │ │ │ │ -void * _patchParamBuffer │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_u_d_a_P_a_t_c_h_T_a_b_l_e_:_:___i_n_d_e_x_B_u_f_f_e_r │ │ │ │ │ -void * _indexBuffer │ │ │ │ │ -DDeeffiinniittiioonn _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h_:_1_0_1 │ │ │ │ │ +38#endif // OPENSUBDIV3_OSD_CL_UTIL_H │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _c_u_d_a_P_a_t_c_h_T_a_b_l_e_._h │ │ │ │ │ + * _o_p_e_n_c_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00797.html │ │ │ │ @@ -94,15 +94,15 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
clVertexBuffer.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/opencl.h"
│ │ │ │ +#include "../osd/opencl.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00797_source.html │ │ │ │ @@ -184,15 +184,15 @@ │ │ │ │
93
│ │ │ │
94} // end namespace OPENSUBDIV_VERSION
│ │ │ │
95using namespace OPENSUBDIV_VERSION;
│ │ │ │
96
│ │ │ │
97} // end namespace OpenSubdiv
│ │ │ │
98
│ │ │ │
99#endif // OPENSUBDIV3_OSD_CL_VERTEX_BUFFER_H
│ │ │ │ - │ │ │ │ + │ │ │ │
Concrete vertex buffer class for OpenCL subdivision.
│ │ │ │
void UpdateData(const float *src, int startVertex, int numVertices, DEVICE_CONTEXT context, cl_event *startEvents=NULL, unsigned int numStartEvents=0, cl_event *endEvent=NULL)
│ │ │ │ │ │ │ │
CLVertexBuffer(int numElements, int numVertices, cl_context clContext)
Constructor.
│ │ │ │
void UpdateData(const float *src, int startVertex, int numVertices, cl_command_queue clQueue, cl_event *startEvents=NULL, unsigned int numStartEvents=0, cl_event *endEvent=NULL)
│ │ │ │
int GetNumElements() const
Returns how many elements defined in this vertex buffer.
│ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00800.html │ │ │ │ @@ -94,15 +94,15 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
clPatchTable.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/opencl.h"
│ │ │ │ +#include "../osd/opencl.h"
│ │ │ │ #include "../osd/nonCopyable.h"
│ │ │ │ #include "../osd/types.h"
│ │ │ │ #include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  CLVertexBuffer
 Concrete vertex buffer class for OpenCL subdivision. More...
│ │ │ │ │ │ │ │ │ │ │ │

│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00800_source.html │ │ │ │ @@ -200,15 +200,15 @@ │ │ │ │
113
│ │ │ │
114} // end namespace OPENSUBDIV_VERSION
│ │ │ │
115using namespace OPENSUBDIV_VERSION;
│ │ │ │
116
│ │ │ │
117} // end namespace OpenSubdiv
│ │ │ │
118
│ │ │ │
119#endif // OPENSUBDIV3_OSD_CL_PATCH_TABLE_H
│ │ │ │ - │ │ │ │ + │ │ │ │
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
cl_mem GetPatchParamBuffer() const
Returns the CL memory of the array of Osd::PatchParam buffer.
│ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00803.html │ │ │ │ @@ -94,17 +94,17 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
clEvaluator.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/opencl.h"
│ │ │ │ +#include "../osd/opencl.h"
│ │ │ │ #include "../osd/types.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00803_source.html │ │ │ │ @@ -1324,18 +1324,18 @@ │ │ │ │
2630} // end namespace OPENSUBDIV_VERSION
│ │ │ │
2631using namespace OPENSUBDIV_VERSION;
│ │ │ │
2632
│ │ │ │
2633} // end namespace OpenSubdiv
│ │ │ │
2634
│ │ │ │
2635
│ │ │ │
2636#endif // OPENSUBDIV3_OSD_CL_EVALUATOR_H
│ │ │ │ - │ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ -
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ + │ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ +
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ │ │ │ │ │ │ │ │
CLStencilTable(Far::StencilTable const *stencilTable, cl_context clContext)
│ │ │ │ │ │ │ │
static CLStencilTable * Create(Far::LimitStencilTable const *limitStencilTable, DEVICE_CONTEXT context)
Definition clEvaluator.h:61
│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00806_source.html │ │ │ │ @@ -150,15 +150,15 @@ │ │ │ │
47
│ │ │ │
48} // end namespace OPENSUBDIV_VERSION
│ │ │ │
49using namespace OPENSUBDIV_VERSION;
│ │ │ │
50
│ │ │ │
51} // end namespace OpenSubdiv
│ │ │ │
52
│ │ │ │
53#endif //OPENSUBDIV3_OSD_MTL_COMMON_H
│ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ -Classes | │ │ │ │ -Namespaces
│ │ │ │ -
mtlPatchShaderSource.h File Reference
│ │ │ │ +Namespaces | │ │ │ │ +Typedefs
│ │ │ │ +
mtlMesh.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │ -
import "../version.h"
│ │ │ │ -import "../far/patchDescriptor.h"
│ │ │ │ -import <string>
│ │ │ │ +
#include "../version.h"
│ │ │ │ +#include "../osd/mesh.h"
│ │ │ │ +#include "../osd/mtlPatchTable.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  CLStencilTable
 OpenCL stencil table. More...
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -

│ │ │ │ -Classes

class  MTLPatchShaderSource
 Provides shader source which can be used by client code. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ +

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │

│ │ │ │ +Typedefs

typedef MeshInterface< MTLPatchTableMTLMeshInterface
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,25 +1,24 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -mtlPatchShaderSource.h File Reference │ │ │ │ │ -import "../version.h" │ │ │ │ │ -import "_._._/_f_a_r_/_p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ -import │ │ │ │ │ +_N_a_m_e_s_p_a_c_e_s | _T_y_p_e_d_e_f_s │ │ │ │ │ +mtlMesh.h File Reference │ │ │ │ │ +#include "../version.h" │ │ │ │ │ +#include "_._._/_o_s_d_/_m_e_s_h_._h" │ │ │ │ │ +#include "_._._/_o_s_d_/_m_t_l_P_a_t_c_h_T_a_b_l_e_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ -CCllaasssseess │ │ │ │ │ -class   _M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -  Provides shader source which can be used by client code. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ +TTyyppeeddeeffss │ │ │ │ │ +typedef _M_e_s_h_I_n_t_e_r_f_a_c_e< _M_T_L_P_a_t_c_h_T_a_b_l_e >  _M_T_L_M_e_s_h_I_n_t_e_r_f_a_c_e │ │ │ │ │ +  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_._h │ │ │ │ │ + * _m_t_l_M_e_s_h_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00809.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,3 @@ │ │ │ │ │ var a00809 = [ │ │ │ │ │ - ["MTLPatchShaderSource", "a01301.html", null] │ │ │ │ │ + ["MTLMeshInterface", "a00809.html#aa41e5b43fe46eeb0f97ff6ebdb1935aa", null] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00809_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlPatchShaderSource.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlMesh.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
mtlPatchShaderSource.h
│ │ │ │ +
mtlMesh.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,82 +119,44 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_MTL_MESH_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_MTL_MESH_H
│ │ │ │
27
│ │ │ │ -
28#import "../version.h"
│ │ │ │ -
29
│ │ │ │ -
30#import "../far/patchDescriptor.h"
│ │ │ │ +
28#include "../version.h"
│ │ │ │ +
29#include "../osd/mesh.h"
│ │ │ │ +
30#include "../osd/mtlPatchTable.h"
│ │ │ │
31
│ │ │ │ -
32#import <string>
│ │ │ │ -
33
│ │ │ │ -
34namespace OpenSubdiv {
│ │ │ │ -
35namespace OPENSUBDIV_VERSION {
│ │ │ │ -
36
│ │ │ │ -
37namespace Osd {
│ │ │ │ -
38
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
41public:
│ │ │ │ -
45 static std::string GetPatchBasisShaderSource();
│ │ │ │ +
32
│ │ │ │ +
33namespace OpenSubdiv {
│ │ │ │ +
34namespace OPENSUBDIV_VERSION {
│ │ │ │ +
35
│ │ │ │ +
36namespace Osd {
│ │ │ │ +
37
│ │ │ │ + │ │ │ │ +
39
│ │ │ │ +
40} // end namespace Osd
│ │ │ │ +
41
│ │ │ │ +
42} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
43using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
44
│ │ │ │ +
45} // end namespace OpenSubdiv
│ │ │ │
46
│ │ │ │ -
50 static std::string GetPatchDrawingShaderSource();
│ │ │ │ -
51
│ │ │ │ -
59
│ │ │ │ -
60 static std::string GetCommonShaderSource();
│ │ │ │ -
61
│ │ │ │ - │ │ │ │ -
63
│ │ │ │ - │ │ │ │ -
65
│ │ │ │ - │ │ │ │ -
67
│ │ │ │ -
72 static std::string GetVertexShaderSource(
│ │ │ │ - │ │ │ │ - │ │ │ │ -
75 static std::string GetHullShaderSource(
│ │ │ │ - │ │ │ │ - │ │ │ │ -
78 static std::string GetDomainShaderSource(
│ │ │ │ - │ │ │ │ - │ │ │ │ -
81
│ │ │ │ -
83
│ │ │ │ -
84};
│ │ │ │ -
│ │ │ │ -
85
│ │ │ │ -
86} // end namespace Osd
│ │ │ │ -
87
│ │ │ │ -
88} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
89using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
90
│ │ │ │ -
91} // end namespace OpenSubdiv
│ │ │ │ -
92
│ │ │ │ -
93#endif // OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE
│ │ │ │ - │ │ │ │ - │ │ │ │ -
Provides shader source which can be used by client code.
│ │ │ │ -
static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │ -
static std::string GetPatchDrawingShaderSource()
Returns shader source which can be used while drawing piecewise parametric patches resulting from sub...
│ │ │ │ -
static std::string GetHullShaderSource(Far::PatchDescriptor::Type type, Far::PatchDescriptor::Type fvarType)
│ │ │ │ -
static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │ -
static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type, Far::PatchDescriptor::Type fvarType)
Deprecated.
│ │ │ │ -
static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type, Far::PatchDescriptor::Type fvarType)
│ │ │ │ -
static std::string GetHullShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │ -
static std::string GetPatchBasisShaderSource()
Returns shader source which can be used to evaluate position and first and second derivatives on piec...
│ │ │ │ - │ │ │ │ +
47#endif // OPENSUBDIV3_OSD_MTL_MESH_H
│ │ │ │ + │ │ │ │ +
MeshInterface< MTLPatchTable > MTLMeshInterface
Definition mtlMesh.h:38
│ │ │ │ + │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -mtlPatchShaderSource.h │ │ │ │ │ +mtlMesh.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,102 +24,41 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_MTL_MESH_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_MTL_MESH_H │ │ │ │ │ 27 │ │ │ │ │ -28#import "../version.h" │ │ │ │ │ -29 │ │ │ │ │ -30#import "../far/patchDescriptor.h" │ │ │ │ │ +28#include "../version.h" │ │ │ │ │ +29#include "../osd/mesh.h" │ │ │ │ │ +30#include "../osd/mtlPatchTable.h" │ │ │ │ │ 31 │ │ │ │ │ -32#import │ │ │ │ │ -33 │ │ │ │ │ -34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -35namespace OPENSUBDIV_VERSION { │ │ │ │ │ -36 │ │ │ │ │ -37namespace Osd { │ │ │ │ │ -38 │ │ │ │ │ -_4_0class _M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e { │ │ │ │ │ -41public: │ │ │ │ │ -_4_5 static std::string _G_e_t_P_a_t_c_h_B_a_s_i_s_S_h_a_d_e_r_S_o_u_r_c_e(); │ │ │ │ │ +32 │ │ │ │ │ +33namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +34namespace OPENSUBDIV_VERSION { │ │ │ │ │ +35 │ │ │ │ │ +36namespace Osd { │ │ │ │ │ +37 │ │ │ │ │ +_3_8typedef _M_e_s_h_I_n_t_e_r_f_a_c_e_<_M_T_L_P_a_t_c_h_T_a_b_l_e_> _M_T_L_M_e_s_h_I_n_t_e_r_f_a_c_e; │ │ │ │ │ +39 │ │ │ │ │ +40} // end namespace Osd │ │ │ │ │ +41 │ │ │ │ │ +42} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +43using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +44 │ │ │ │ │ +45} // end namespace OpenSubdiv │ │ │ │ │ 46 │ │ │ │ │ -_5_0 static std::string _G_e_t_P_a_t_c_h_D_r_a_w_i_n_g_S_h_a_d_e_r_S_o_u_r_c_e(); │ │ │ │ │ -51 │ │ │ │ │ -59 │ │ │ │ │ -_6_0 static std::string _G_e_t_C_o_m_m_o_n_S_h_a_d_e_r_S_o_u_r_c_e(); │ │ │ │ │ -61 │ │ │ │ │ -_6_2 static std::string _G_e_t_V_e_r_t_e_x_S_h_a_d_e_r_S_o_u_r_c_e(_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type); │ │ │ │ │ -63 │ │ │ │ │ -_6_4 static std::string _G_e_t_H_u_l_l_S_h_a_d_e_r_S_o_u_r_c_e(_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type); │ │ │ │ │ -65 │ │ │ │ │ -_6_6 static std::string _G_e_t_D_o_m_a_i_n_S_h_a_d_e_r_S_o_u_r_c_e(_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type); │ │ │ │ │ -67 │ │ │ │ │ -_7_2 static std::string _G_e_t_V_e_r_t_e_x_S_h_a_d_e_r_S_o_u_r_c_e( │ │ │ │ │ -73 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type, │ │ │ │ │ -74 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e fvarType); │ │ │ │ │ -_7_5 static std::string _G_e_t_H_u_l_l_S_h_a_d_e_r_S_o_u_r_c_e( │ │ │ │ │ -76 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type, │ │ │ │ │ -77 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e fvarType); │ │ │ │ │ -_7_8 static std::string _G_e_t_D_o_m_a_i_n_S_h_a_d_e_r_S_o_u_r_c_e( │ │ │ │ │ -79 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type, │ │ │ │ │ -80 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e fvarType); │ │ │ │ │ -81 │ │ │ │ │ -83 │ │ │ │ │ -84}; │ │ │ │ │ -85 │ │ │ │ │ -86} // end namespace Osd │ │ │ │ │ -87 │ │ │ │ │ -88} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -89using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -90 │ │ │ │ │ -91} // end namespace OpenSubdiv │ │ │ │ │ -92 │ │ │ │ │ -93#endif // OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE │ │ │ │ │ +47#endif // OPENSUBDIV3_OSD_MTL_MESH_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e │ │ │ │ │ -Type │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h_:_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -Provides shader source which can be used by client code. │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_._h_:_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ -_G_e_t_V_e_r_t_e_x_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ -_G_e_t_P_a_t_c_h_D_r_a_w_i_n_g_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetPatchDrawingShaderSource() │ │ │ │ │ -Returns shader source which can be used while drawing piecewise parametric │ │ │ │ │ -patches resulting from sub... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_:_G_e_t_H_u_l_l_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetHullShaderSource(Far::PatchDescriptor::Type type, Far:: │ │ │ │ │ -PatchDescriptor::Type fvarType) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ -_G_e_t_D_o_m_a_i_n_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ -_G_e_t_V_e_r_t_e_x_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type, Far:: │ │ │ │ │ -PatchDescriptor::Type fvarType) │ │ │ │ │ -Deprecated. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ -_G_e_t_D_o_m_a_i_n_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type, Far:: │ │ │ │ │ -PatchDescriptor::Type fvarType) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_:_G_e_t_H_u_l_l_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetHullShaderSource(Far::PatchDescriptor::Type type) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ -_G_e_t_P_a_t_c_h_B_a_s_i_s_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetPatchBasisShaderSource() │ │ │ │ │ -Returns shader source which can be used to evaluate position and first and │ │ │ │ │ -second derivatives on piec... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ -_G_e_t_C_o_m_m_o_n_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ -static std::string GetCommonShaderSource() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_M_e_s_h_I_n_t_e_r_f_a_c_e │ │ │ │ │ +MeshInterface< MTLPatchTable > MTLMeshInterface │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_M_e_s_h_._h_:_3_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_e_s_h_I_n_t_e_r_f_a_c_e │ │ │ │ │ +DDeeffiinniittiioonn _m_e_s_h_._h_:_6_8 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_._h │ │ │ │ │ + * _m_t_l_M_e_s_h_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00812.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlMesh.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlPatchShaderSource.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -88,43 +88,44 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ -Namespaces | │ │ │ │ -Typedefs
│ │ │ │ -
mtlMesh.h File Reference
│ │ │ │ +Classes | │ │ │ │ +Namespaces
│ │ │ │ +
mtlPatchShaderSource.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │ -
#include "../version.h"
│ │ │ │ -#include "../osd/mesh.h"
│ │ │ │ -#include "../osd/mtlPatchTable.h"
│ │ │ │ +
import "../version.h"
│ │ │ │ +import "../far/patchDescriptor.h"
│ │ │ │ +import <string>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +

│ │ │ │ +Classes

class  MTLPatchShaderSource
 Provides shader source which can be used by client code. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │

│ │ │ │ -Typedefs

typedef MeshInterface< MTLPatchTableMTLMeshInterface
 
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,24 +1,25 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -_N_a_m_e_s_p_a_c_e_s | _T_y_p_e_d_e_f_s │ │ │ │ │ -mtlMesh.h File Reference │ │ │ │ │ -#include "../version.h" │ │ │ │ │ -#include "_._._/_o_s_d_/_m_e_s_h_._h" │ │ │ │ │ -#include "_._._/_o_s_d_/_m_t_l_P_a_t_c_h_T_a_b_l_e_._h" │ │ │ │ │ +_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ +mtlPatchShaderSource.h File Reference │ │ │ │ │ +import "../version.h" │ │ │ │ │ +import "_._._/_f_a_r_/_p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ +import │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ +CCllaasssseess │ │ │ │ │ +class   _M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +  Provides shader source which can be used by client code. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ -TTyyppeeddeeffss │ │ │ │ │ -typedef _M_e_s_h_I_n_t_e_r_f_a_c_e< _M_T_L_P_a_t_c_h_T_a_b_l_e >  _M_T_L_M_e_s_h_I_n_t_e_r_f_a_c_e │ │ │ │ │ -  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_M_e_s_h_._h │ │ │ │ │ + * _m_t_l_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00812.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,3 @@ │ │ │ │ │ var a00812 = [ │ │ │ │ │ - ["MTLMeshInterface", "a00812.html#aa41e5b43fe46eeb0f97ff6ebdb1935aa", null] │ │ │ │ │ + ["MTLPatchShaderSource", "a01301.html", null] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00812_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlMesh.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlPatchShaderSource.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
mtlMesh.h
│ │ │ │ +
mtlPatchShaderSource.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,44 +119,82 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_MTL_MESH_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_MTL_MESH_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE_H
│ │ │ │
27
│ │ │ │ -
28#include "../version.h"
│ │ │ │ -
29#include "../osd/mesh.h"
│ │ │ │ -
30#include "../osd/mtlPatchTable.h"
│ │ │ │ +
28#import "../version.h"
│ │ │ │ +
29
│ │ │ │ +
30#import "../far/patchDescriptor.h"
│ │ │ │
31
│ │ │ │ -
32
│ │ │ │ -
33namespace OpenSubdiv {
│ │ │ │ -
34namespace OPENSUBDIV_VERSION {
│ │ │ │ -
35
│ │ │ │ -
36namespace Osd {
│ │ │ │ -
37
│ │ │ │ - │ │ │ │ -
39
│ │ │ │ -
40} // end namespace Osd
│ │ │ │ -
41
│ │ │ │ -
42} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
43using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
44
│ │ │ │ -
45} // end namespace OpenSubdiv
│ │ │ │ +
32#import <string>
│ │ │ │ +
33
│ │ │ │ +
34namespace OpenSubdiv {
│ │ │ │ +
35namespace OPENSUBDIV_VERSION {
│ │ │ │ +
36
│ │ │ │ +
37namespace Osd {
│ │ │ │ +
38
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
41public:
│ │ │ │ +
45 static std::string GetPatchBasisShaderSource();
│ │ │ │
46
│ │ │ │ -
47#endif // OPENSUBDIV3_OSD_MTL_MESH_H
│ │ │ │ - │ │ │ │ -
MeshInterface< MTLPatchTable > MTLMeshInterface
Definition mtlMesh.h:38
│ │ │ │ - │ │ │ │ +
50 static std::string GetPatchDrawingShaderSource();
│ │ │ │ +
51
│ │ │ │ +
59
│ │ │ │ +
60 static std::string GetCommonShaderSource();
│ │ │ │ +
61
│ │ │ │ + │ │ │ │ +
63
│ │ │ │ + │ │ │ │ +
65
│ │ │ │ + │ │ │ │ +
67
│ │ │ │ +
72 static std::string GetVertexShaderSource(
│ │ │ │ + │ │ │ │ + │ │ │ │ +
75 static std::string GetHullShaderSource(
│ │ │ │ + │ │ │ │ + │ │ │ │ +
78 static std::string GetDomainShaderSource(
│ │ │ │ + │ │ │ │ + │ │ │ │ +
81
│ │ │ │ +
83
│ │ │ │ +
84};
│ │ │ │ +
│ │ │ │ +
85
│ │ │ │ +
86} // end namespace Osd
│ │ │ │ +
87
│ │ │ │ +
88} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
89using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
90
│ │ │ │ +
91} // end namespace OpenSubdiv
│ │ │ │ +
92
│ │ │ │ +
93#endif // OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE
│ │ │ │ + │ │ │ │ + │ │ │ │ +
Provides shader source which can be used by client code.
│ │ │ │ +
static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │ +
static std::string GetPatchDrawingShaderSource()
Returns shader source which can be used while drawing piecewise parametric patches resulting from sub...
│ │ │ │ +
static std::string GetHullShaderSource(Far::PatchDescriptor::Type type, Far::PatchDescriptor::Type fvarType)
│ │ │ │ +
static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │ +
static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type, Far::PatchDescriptor::Type fvarType)
Deprecated.
│ │ │ │ +
static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type, Far::PatchDescriptor::Type fvarType)
│ │ │ │ +
static std::string GetHullShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │ +
static std::string GetPatchBasisShaderSource()
Returns shader source which can be used to evaluate position and first and second derivatives on piec...
│ │ │ │ + │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -mtlMesh.h │ │ │ │ │ +mtlPatchShaderSource.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,41 +24,102 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_MTL_MESH_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_MTL_MESH_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE_H │ │ │ │ │ 27 │ │ │ │ │ -28#include "../version.h" │ │ │ │ │ -29#include "../osd/mesh.h" │ │ │ │ │ -30#include "../osd/mtlPatchTable.h" │ │ │ │ │ +28#import "../version.h" │ │ │ │ │ +29 │ │ │ │ │ +30#import "../far/patchDescriptor.h" │ │ │ │ │ 31 │ │ │ │ │ -32 │ │ │ │ │ -33namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -34namespace OPENSUBDIV_VERSION { │ │ │ │ │ -35 │ │ │ │ │ -36namespace Osd { │ │ │ │ │ -37 │ │ │ │ │ -_3_8typedef _M_e_s_h_I_n_t_e_r_f_a_c_e_<_M_T_L_P_a_t_c_h_T_a_b_l_e_> _M_T_L_M_e_s_h_I_n_t_e_r_f_a_c_e; │ │ │ │ │ -39 │ │ │ │ │ -40} // end namespace Osd │ │ │ │ │ -41 │ │ │ │ │ -42} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -43using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -44 │ │ │ │ │ -45} // end namespace OpenSubdiv │ │ │ │ │ +32#import │ │ │ │ │ +33 │ │ │ │ │ +34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +35namespace OPENSUBDIV_VERSION { │ │ │ │ │ +36 │ │ │ │ │ +37namespace Osd { │ │ │ │ │ +38 │ │ │ │ │ +_4_0class _M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e { │ │ │ │ │ +41public: │ │ │ │ │ +_4_5 static std::string _G_e_t_P_a_t_c_h_B_a_s_i_s_S_h_a_d_e_r_S_o_u_r_c_e(); │ │ │ │ │ 46 │ │ │ │ │ -47#endif // OPENSUBDIV3_OSD_MTL_MESH_H │ │ │ │ │ +_5_0 static std::string _G_e_t_P_a_t_c_h_D_r_a_w_i_n_g_S_h_a_d_e_r_S_o_u_r_c_e(); │ │ │ │ │ +51 │ │ │ │ │ +59 │ │ │ │ │ +_6_0 static std::string _G_e_t_C_o_m_m_o_n_S_h_a_d_e_r_S_o_u_r_c_e(); │ │ │ │ │ +61 │ │ │ │ │ +_6_2 static std::string _G_e_t_V_e_r_t_e_x_S_h_a_d_e_r_S_o_u_r_c_e(_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type); │ │ │ │ │ +63 │ │ │ │ │ +_6_4 static std::string _G_e_t_H_u_l_l_S_h_a_d_e_r_S_o_u_r_c_e(_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type); │ │ │ │ │ +65 │ │ │ │ │ +_6_6 static std::string _G_e_t_D_o_m_a_i_n_S_h_a_d_e_r_S_o_u_r_c_e(_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type); │ │ │ │ │ +67 │ │ │ │ │ +_7_2 static std::string _G_e_t_V_e_r_t_e_x_S_h_a_d_e_r_S_o_u_r_c_e( │ │ │ │ │ +73 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type, │ │ │ │ │ +74 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e fvarType); │ │ │ │ │ +_7_5 static std::string _G_e_t_H_u_l_l_S_h_a_d_e_r_S_o_u_r_c_e( │ │ │ │ │ +76 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type, │ │ │ │ │ +77 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e fvarType); │ │ │ │ │ +_7_8 static std::string _G_e_t_D_o_m_a_i_n_S_h_a_d_e_r_S_o_u_r_c_e( │ │ │ │ │ +79 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type, │ │ │ │ │ +80 _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e fvarType); │ │ │ │ │ +81 │ │ │ │ │ +83 │ │ │ │ │ +84}; │ │ │ │ │ +85 │ │ │ │ │ +86} // end namespace Osd │ │ │ │ │ +87 │ │ │ │ │ +88} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +89using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +90 │ │ │ │ │ +91} // end namespace OpenSubdiv │ │ │ │ │ +92 │ │ │ │ │ +93#endif // OPENSUBDIV3_OSD_MTL_PATCH_SHADER_SOURCE │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_M_e_s_h_I_n_t_e_r_f_a_c_e │ │ │ │ │ -MeshInterface< MTLPatchTable > MTLMeshInterface │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_M_e_s_h_._h_:_3_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_e_s_h_I_n_t_e_r_f_a_c_e │ │ │ │ │ -DDeeffiinniittiioonn _m_e_s_h_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e │ │ │ │ │ +Type │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h_:_4_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +Provides shader source which can be used by client code. │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_._h_:_4_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ +_G_e_t_V_e_r_t_e_x_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ +_G_e_t_P_a_t_c_h_D_r_a_w_i_n_g_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetPatchDrawingShaderSource() │ │ │ │ │ +Returns shader source which can be used while drawing piecewise parametric │ │ │ │ │ +patches resulting from sub... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_:_G_e_t_H_u_l_l_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetHullShaderSource(Far::PatchDescriptor::Type type, Far:: │ │ │ │ │ +PatchDescriptor::Type fvarType) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ +_G_e_t_D_o_m_a_i_n_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ +_G_e_t_V_e_r_t_e_x_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type, Far:: │ │ │ │ │ +PatchDescriptor::Type fvarType) │ │ │ │ │ +Deprecated. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ +_G_e_t_D_o_m_a_i_n_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type, Far:: │ │ │ │ │ +PatchDescriptor::Type fvarType) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_:_G_e_t_H_u_l_l_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetHullShaderSource(Far::PatchDescriptor::Type type) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ +_G_e_t_P_a_t_c_h_B_a_s_i_s_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetPatchBasisShaderSource() │ │ │ │ │ +Returns shader source which can be used to evaluate position and first and │ │ │ │ │ +second derivatives on piec... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_:_: │ │ │ │ │ +_G_e_t_C_o_m_m_o_n_S_h_a_d_e_r_S_o_u_r_c_e │ │ │ │ │ +static std::string GetCommonShaderSource() │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_M_e_s_h_._h │ │ │ │ │ + * _m_t_l_P_a_t_c_h_S_h_a_d_e_r_S_o_u_r_c_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00815_source.html │ │ │ │ @@ -196,15 +196,15 @@ │ │ │ │
91
│ │ │ │
92} //end namespace OPENSUBDIV_VERSION
│ │ │ │
93using namespace OPENSUBDIV_VERSION;
│ │ │ │
94
│ │ │ │
95} //end namespace OpenSubdiv
│ │ │ │
96
│ │ │ │
97#endif //end OPENSUBDIV3_OSD_MTL_PATCH_TABLE_H
│ │ │ │ - │ │ │ │ + │ │ │ │
std::vector< PatchArray > PatchArrayVector
Definition types.h:132
│ │ │ │
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ │ │ │ │ │ │ │ │
PatchArrayVector const & GetPatchArrays() const
│ │ │ │
bool allocate(Far::PatchTable const *farPatchTable, MTLContext *context)
│ │ │ │
static MTLPatchTable * Create(Far::PatchTable const *farPatchTable, MTLContext *context)
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00818.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlLegacyGregoryPatchTable.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlVertexBuffer.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,27 +90,25 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
mtlLegacyGregoryPatchTable.h File Reference
│ │ │ │ +
mtlVertexBuffer.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/patchTable.h"
│ │ │ │ -#include "../osd/nonCopyable.h"
│ │ │ │ #include "../osd/mtlCommon.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  MTLLegacyGregoryPatchTable
class  CPUMTLVertexBuffer
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -119,13 +117,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,25 +1,23 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -mtlLegacyGregoryPatchTable.h File Reference │ │ │ │ │ +mtlVertexBuffer.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_f_a_r_/_p_a_t_c_h_T_a_b_l_e_._h" │ │ │ │ │ -#include "../osd/nonCopyable.h" │ │ │ │ │ #include "_._._/_o_s_d_/_m_t_l_C_o_m_m_o_n_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +class   _C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h │ │ │ │ │ + * _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00818.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,3 @@ │ │ │ │ │ var a00818 = [ │ │ │ │ │ - ["MTLLegacyGregoryPatchTable", "a01297.html", "a01297"] │ │ │ │ │ + ["CPUMTLVertexBuffer", "a01309.html", "a01309"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00818_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlLegacyGregoryPatchTable.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlVertexBuffer.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
mtlLegacyGregoryPatchTable.h
│ │ │ │ +
mtlVertexBuffer.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,112 +119,97 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29#include "../far/patchTable.h"
│ │ │ │ -
30#include "../osd/nonCopyable.h"
│ │ │ │ -
31#include "../osd/mtlCommon.h"
│ │ │ │ -
32
│ │ │ │ -
33@protocol MTLDevice;
│ │ │ │ -
34@protocol MTLBuffer;
│ │ │ │ -
35
│ │ │ │ -
36namespace OpenSubdiv {
│ │ │ │ -
37namespace OPENSUBDIV_VERSION {
│ │ │ │ +
29#include "../osd/mtlCommon.h"
│ │ │ │ +
30
│ │ │ │ +
31@protocol MTLDevice;
│ │ │ │ +
32@protocol MTLBuffer;
│ │ │ │ +
33
│ │ │ │ +
34namespace OpenSubdiv {
│ │ │ │ +
35namespace OPENSUBDIV_VERSION {
│ │ │ │ +
36
│ │ │ │ +
37namespace Osd {
│ │ │ │
38
│ │ │ │ -
39namespace Osd {
│ │ │ │ -
40
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
42: private NonCopyable<MTLLegacyGregoryPatchTable>
│ │ │ │ -
43{
│ │ │ │ -
44public:
│ │ │ │ - │ │ │ │ -
46
│ │ │ │ -
47 template<typename DEVICE_CONTEXT>
│ │ │ │ -
│ │ │ │ -
48 static MTLLegacyGregoryPatchTable* Create(Far::PatchTable const* farPatchTable, DEVICE_CONTEXT context) {
│ │ │ │ -
49 return Create(farPatchTable, context);
│ │ │ │ -
50 }
│ │ │ │ -
│ │ │ │ -
51
│ │ │ │ -
52 static MTLLegacyGregoryPatchTable* Create(Far::PatchTable const* farPatchTable, MTLContext* context);
│ │ │ │ -
53
│ │ │ │ -
54 void UpdateVertexBuffer(id<MTLBuffer> vbo, int numVertices, int numVertexElements, MTLContext* context);
│ │ │ │ -
55
│ │ │ │ -
│ │ │ │ -
56 id<MTLBuffer> GetVertexBuffer() const
│ │ │ │ -
57 {
│ │ │ │ -
58 return _vertexBuffer;
│ │ │ │ -
59 }
│ │ │ │ -
│ │ │ │ -
60
│ │ │ │ -
│ │ │ │ -
61 id<MTLBuffer> GetVertexValenceBuffer() const
│ │ │ │ -
62 {
│ │ │ │ -
63 return _vertexValenceBuffer;
│ │ │ │ -
64 }
│ │ │ │ -
│ │ │ │ -
65
│ │ │ │ -
│ │ │ │ -
66 id<MTLBuffer> GetQuadOffsetsBuffer() const
│ │ │ │ -
67 {
│ │ │ │ -
68 return _quadOffsetsBuffer;
│ │ │ │ -
69 }
│ │ │ │ -
│ │ │ │ -
70
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
72 {
│ │ │ │ - │ │ │ │ -
74 return _quadOffsetsBase[1];
│ │ │ │ -
75 return _quadOffsetsBase[0];
│ │ │ │ -
76 }
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
40public:
│ │ │ │ +
41 static CPUMTLVertexBuffer* Create(int numElements, int numVertices, MTLContext* context);
│ │ │ │ +
42
│ │ │ │ +
43 void UpdateData(const float* src, int startVertex, int numVertices, MTLContext* context);
│ │ │ │ +
44
│ │ │ │ +
│ │ │ │ +
45 int GetNumElements() const
│ │ │ │ +
46 {
│ │ │ │ +
47 return _numElements;
│ │ │ │ +
48 }
│ │ │ │ +
│ │ │ │ +
49
│ │ │ │ +
│ │ │ │ +
50 int GetNumVertices() const
│ │ │ │ +
51 {
│ │ │ │ +
52 return _numVertices;
│ │ │ │ +
53 }
│ │ │ │ +
│ │ │ │ +
54
│ │ │ │ +
55 float* BindCpuBuffer();
│ │ │ │ +
56 id<MTLBuffer> BindMTLBuffer(MTLContext* context);
│ │ │ │ +
57
│ │ │ │ +
│ │ │ │ +
58 id<MTLBuffer> BindVBO(MTLContext* context)
│ │ │ │ +
59 {
│ │ │ │ +
60 return BindMTLBuffer(context);
│ │ │ │ +
61 }
│ │ │ │ +
│ │ │ │ +
62
│ │ │ │ +
63protected:
│ │ │ │ +
64
│ │ │ │ +
65 CPUMTLVertexBuffer(int numElements, int numVertices);
│ │ │ │ +
66
│ │ │ │ +
67 bool allocate(MTLContext* context);
│ │ │ │ +
68
│ │ │ │ +
69private:
│ │ │ │ +
70 int _numElements;
│ │ │ │ +
71 int _numVertices;
│ │ │ │ +
72 id<MTLBuffer> _buffer;
│ │ │ │ +
73 bool _dirty;
│ │ │ │ +
74};
│ │ │ │
│ │ │ │ +
75
│ │ │ │ +
76} //end namespace Osd
│ │ │ │
77
│ │ │ │ -
78private:
│ │ │ │ -
79 id<MTLBuffer> _vertexBuffer;
│ │ │ │ -
80 id<MTLBuffer> _vertexValenceBuffer;
│ │ │ │ -
81 id<MTLBuffer> _quadOffsetsBuffer;
│ │ │ │ -
82 int _quadOffsetsBase[2];
│ │ │ │ -
83};
│ │ │ │ -
│ │ │ │ -
84
│ │ │ │ -
85} //end namespace Osd
│ │ │ │ -
86
│ │ │ │ -
87} //end namespace OPENSUBDIV_VERSION
│ │ │ │ -
88using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
89
│ │ │ │ -
90} //end namespace OpenSuddiv
│ │ │ │ -
91
│ │ │ │ -
92#endif // OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ +
78} //end namespace OPENSUBDIV_VERSION
│ │ │ │ +
79 using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
80
│ │ │ │ +
81} //end namespace OpenSubdiv
│ │ │ │ +
82
│ │ │ │ +
83#endif // OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H
│ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ -
static MTLLegacyGregoryPatchTable * Create(Far::PatchTable const *farPatchTable, DEVICE_CONTEXT context)
│ │ │ │ - │ │ │ │ - │ │ │ │ -
static MTLLegacyGregoryPatchTable * Create(Far::PatchTable const *farPatchTable, MTLContext *context)
│ │ │ │ -
void UpdateVertexBuffer(id< MTLBuffer > vbo, int numVertices, int numVertexElements, MTLContext *context)
│ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ +
CPUMTLVertexBuffer(int numElements, int numVertices)
│ │ │ │ +
static CPUMTLVertexBuffer * Create(int numElements, int numVertices, MTLContext *context)
│ │ │ │ + │ │ │ │ +
void UpdateData(const float *src, int startVertex, int numVertices, MTLContext *context)
│ │ │ │ + │ │ │ │ +
id< MTLBuffer > BindMTLBuffer(MTLContext *context)
│ │ │ │ + │ │ │ │ + │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -mtlLegacyGregoryPatchTable.h │ │ │ │ │ +mtlVertexBuffer.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,127 +24,101 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29#include "../far/patchTable.h" │ │ │ │ │ -30#include "../osd/nonCopyable.h" │ │ │ │ │ -31#include "../osd/mtlCommon.h" │ │ │ │ │ -32 │ │ │ │ │ -33@protocol MTLDevice; │ │ │ │ │ -34@protocol MTLBuffer; │ │ │ │ │ -35 │ │ │ │ │ -36namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -37namespace OPENSUBDIV_VERSION { │ │ │ │ │ +29#include "../osd/mtlCommon.h" │ │ │ │ │ +30 │ │ │ │ │ +31@protocol MTLDevice; │ │ │ │ │ +32@protocol MTLBuffer; │ │ │ │ │ +33 │ │ │ │ │ +34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +35namespace OPENSUBDIV_VERSION { │ │ │ │ │ +36 │ │ │ │ │ +37namespace Osd { │ │ │ │ │ 38 │ │ │ │ │ -39namespace Osd { │ │ │ │ │ -40 │ │ │ │ │ -_4_1class _M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -42: private NonCopyable │ │ │ │ │ -43{ │ │ │ │ │ -44public: │ │ │ │ │ -_4_5 _~_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e(); │ │ │ │ │ -46 │ │ │ │ │ -47 template │ │ │ │ │ -_4_8 static _M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e* _C_r_e_a_t_e(_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e const* │ │ │ │ │ -farPatchTable, DEVICE_CONTEXT context) { │ │ │ │ │ -49 return Create(farPatchTable, context); │ │ │ │ │ -50 } │ │ │ │ │ -51 │ │ │ │ │ -_5_2 static _M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e* _C_r_e_a_t_e(_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e const* │ │ │ │ │ -farPatchTable, _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -53 │ │ │ │ │ -_5_4 void _U_p_d_a_t_e_V_e_r_t_e_x_B_u_f_f_e_r(id vbo, int numVertices, int │ │ │ │ │ -numVertexElements, _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -55 │ │ │ │ │ -_5_6 id _G_e_t_V_e_r_t_e_x_B_u_f_f_e_r() const │ │ │ │ │ -57 { │ │ │ │ │ -58 return _vertexBuffer; │ │ │ │ │ -59 } │ │ │ │ │ -60 │ │ │ │ │ -_6_1 id _G_e_t_V_e_r_t_e_x_V_a_l_e_n_c_e_B_u_f_f_e_r() const │ │ │ │ │ -62 { │ │ │ │ │ -63 return _vertexValenceBuffer; │ │ │ │ │ -64 } │ │ │ │ │ -65 │ │ │ │ │ -_6_6 id _G_e_t_Q_u_a_d_O_f_f_s_e_t_s_B_u_f_f_e_r() const │ │ │ │ │ -67 { │ │ │ │ │ -68 return _quadOffsetsBuffer; │ │ │ │ │ -69 } │ │ │ │ │ -70 │ │ │ │ │ -_7_1 int _G_e_t_Q_u_a_d_O_f_f_s_e_t_s_B_a_s_e(_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type) │ │ │ │ │ -72 { │ │ │ │ │ -73 if(type == _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_G_R_E_G_O_R_Y___B_O_U_N_D_A_R_Y) │ │ │ │ │ -74 return _quadOffsetsBase[1]; │ │ │ │ │ -75 return _quadOffsetsBase[0]; │ │ │ │ │ -76 } │ │ │ │ │ +_3_9class _C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r { │ │ │ │ │ +40public: │ │ │ │ │ +_4_1 static _C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r* _C_r_e_a_t_e(int numElements, int numVertices, │ │ │ │ │ +_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +42 │ │ │ │ │ +_4_3 void _U_p_d_a_t_e_D_a_t_a(const float* src, int startVertex, int numVertices, │ │ │ │ │ +_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +44 │ │ │ │ │ +_4_5 int _G_e_t_N_u_m_E_l_e_m_e_n_t_s() const │ │ │ │ │ +46 { │ │ │ │ │ +47 return _numElements; │ │ │ │ │ +48 } │ │ │ │ │ +49 │ │ │ │ │ +_5_0 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s() const │ │ │ │ │ +51 { │ │ │ │ │ +52 return _numVertices; │ │ │ │ │ +53 } │ │ │ │ │ +54 │ │ │ │ │ +_5_5 float* _B_i_n_d_C_p_u_B_u_f_f_e_r(); │ │ │ │ │ +_5_6 id _B_i_n_d_M_T_L_B_u_f_f_e_r(_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +57 │ │ │ │ │ +_5_8 id _B_i_n_d_V_B_O(_M_T_L_C_o_n_t_e_x_t* context) │ │ │ │ │ +59 { │ │ │ │ │ +60 return _B_i_n_d_M_T_L_B_u_f_f_e_r(context); │ │ │ │ │ +61 } │ │ │ │ │ +62 │ │ │ │ │ +63protected: │ │ │ │ │ +64 │ │ │ │ │ +_6_5 _C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r(int numElements, int numVertices); │ │ │ │ │ +66 │ │ │ │ │ +_6_7 bool _a_l_l_o_c_a_t_e(_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +68 │ │ │ │ │ +69private: │ │ │ │ │ +70 int _numElements; │ │ │ │ │ +71 int _numVertices; │ │ │ │ │ +72 id _buffer; │ │ │ │ │ +73 bool _dirty; │ │ │ │ │ +74}; │ │ │ │ │ +75 │ │ │ │ │ +76} //end namespace Osd │ │ │ │ │ 77 │ │ │ │ │ -78private: │ │ │ │ │ -79 id _vertexBuffer; │ │ │ │ │ -80 id _vertexValenceBuffer; │ │ │ │ │ -81 id _quadOffsetsBuffer; │ │ │ │ │ -82 int _quadOffsetsBase[2]; │ │ │ │ │ -83}; │ │ │ │ │ -84 │ │ │ │ │ -85} //end namespace Osd │ │ │ │ │ -86 │ │ │ │ │ -87} //end namespace OPENSUBDIV_VERSION │ │ │ │ │ -88using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -89 │ │ │ │ │ -90} //end namespace OpenSuddiv │ │ │ │ │ -91 │ │ │ │ │ -92#endif // OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H │ │ │ │ │ +78} //end namespace OPENSUBDIV_VERSION │ │ │ │ │ +79 using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +80 │ │ │ │ │ +81} //end namespace OpenSubdiv │ │ │ │ │ +82 │ │ │ │ │ +83#endif // OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e │ │ │ │ │ -Type │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h_:_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_G_R_E_G_O_R_Y___B_O_U_N_D_A_R_Y │ │ │ │ │ -@ GREGORY_BOUNDARY │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -Container for arrays of parametric patches. │ │ │ │ │ -DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_._h_:_5_5 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_n_t_e_x_t │ │ │ │ │ DDeeffiinniittiioonn _m_t_l_C_o_m_m_o_n_._h_:_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_4_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ -_G_e_t_Q_u_a_d_O_f_f_s_e_t_s_B_a_s_e │ │ │ │ │ -int GetQuadOffsetsBase(Far::PatchDescriptor::Type type) │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ -static MTLLegacyGregoryPatchTable * Create(Far::PatchTable const │ │ │ │ │ -*farPatchTable, DEVICE_CONTEXT context) │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ -_G_e_t_V_e_r_t_e_x_V_a_l_e_n_c_e_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetVertexValenceBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ -_G_e_t_Q_u_a_d_O_f_f_s_e_t_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetQuadOffsetsBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ -static MTLLegacyGregoryPatchTable * Create(Far::PatchTable const │ │ │ │ │ -*farPatchTable, MTLContext *context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ -_U_p_d_a_t_e_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -void UpdateVertexBuffer(id< MTLBuffer > vbo, int numVertices, int │ │ │ │ │ -numVertexElements, MTLContext *context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ -_~_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ -~MTLLegacyGregoryPatchTable() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ -_G_e_t_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetVertexBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_3_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_V_B_O │ │ │ │ │ +id< MTLBuffer > BindVBO(MTLContext *context) │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_5_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +CPUMTLVertexBuffer(int numElements, int numVertices) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_r_e_a_t_e │ │ │ │ │ +static CPUMTLVertexBuffer * Create(int numElements, int numVertices, MTLContext │ │ │ │ │ +*context) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_E_l_e_m_e_n_t_s │ │ │ │ │ +int GetNumElements() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_4_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_U_p_d_a_t_e_D_a_t_a │ │ │ │ │ +void UpdateData(const float *src, int startVertex, int numVertices, MTLContext │ │ │ │ │ +*context) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s │ │ │ │ │ +int GetNumVertices() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_5_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_M_T_L_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > BindMTLBuffer(MTLContext *context) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_C_p_u_B_u_f_f_e_r │ │ │ │ │ +float * BindCpuBuffer() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_a_l_l_o_c_a_t_e │ │ │ │ │ +bool allocate(MTLContext *context) │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h │ │ │ │ │ + * _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00821.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlComputeEvaluator.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlLegacyGregoryPatchTable.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,46 +90,42 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
mtlComputeEvaluator.h File Reference
│ │ │ │ +
mtlLegacyGregoryPatchTable.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/types.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../far/patchTable.h"
│ │ │ │ +#include "../osd/nonCopyable.h"
│ │ │ │ #include "../osd/mtlCommon.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  MTLStencilTable
 
class  MTLComputeEvaluator
class  MTLLegacyGregoryPatchTable
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,29 +1,25 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -mtlComputeEvaluator.h File Reference │ │ │ │ │ +mtlLegacyGregoryPatchTable.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_o_s_d_/_t_y_p_e_s_._h" │ │ │ │ │ -#include "_._._/_o_s_d_/_b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_p_a_t_c_h_T_a_b_l_e_._h" │ │ │ │ │ +#include "../osd/nonCopyable.h" │ │ │ │ │ #include "_._._/_o_s_d_/_m_t_l_C_o_m_m_o_n_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -  │ │ │ │ │ -class   _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +class   _M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │ -  │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ + * _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00821.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,3 @@ │ │ │ │ │ var a00821 = [ │ │ │ │ │ - ["MTLStencilTable", "a01289.html", "a01289"], │ │ │ │ │ - ["MTLComputeEvaluator", "a01293.html", "a01293"] │ │ │ │ │ + ["MTLLegacyGregoryPatchTable", "a01297.html", "a01297"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00821_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlComputeEvaluator.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlLegacyGregoryPatchTable.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
mtlComputeEvaluator.h
│ │ │ │ +
mtlLegacyGregoryPatchTable.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,1138 +119,112 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29
│ │ │ │ -
30#include "../osd/types.h"
│ │ │ │ -
31#include "../osd/bufferDescriptor.h"
│ │ │ │ -
32#include "../osd/mtlCommon.h"
│ │ │ │ -
33
│ │ │ │ -
34@protocol MTLDevice;
│ │ │ │ -
35@protocol MTLBuffer;
│ │ │ │ -
36@protocol MTLLibrary;
│ │ │ │ -
37@protocol MTLComputePipelineState;
│ │ │ │ +
29#include "../far/patchTable.h"
│ │ │ │ +
30#include "../osd/nonCopyable.h"
│ │ │ │ +
31#include "../osd/mtlCommon.h"
│ │ │ │ +
32
│ │ │ │ +
33@protocol MTLDevice;
│ │ │ │ +
34@protocol MTLBuffer;
│ │ │ │ +
35
│ │ │ │ +
36namespace OpenSubdiv {
│ │ │ │ +
37namespace OPENSUBDIV_VERSION {
│ │ │ │
38
│ │ │ │ -
39namespace OpenSubdiv {
│ │ │ │ -
40namespace OPENSUBDIV_VERSION {
│ │ │ │ -
41
│ │ │ │ -
42namespace Far {
│ │ │ │ -
43 class PatchTable;
│ │ │ │ -
44 class StencilTable;
│ │ │ │ -
45 class LimitStencilTable;
│ │ │ │ -
46}
│ │ │ │ -
47
│ │ │ │ -
48namespace Osd {
│ │ │ │ -
49
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
51{
│ │ │ │ -
52public:
│ │ │ │ -
53 template<typename STENCIL_TABLE, typename DEVICE_CONTEXT>
│ │ │ │ -
│ │ │ │ -
54 static MTLStencilTable* Create(STENCIL_TABLE* stencilTable,
│ │ │ │ -
55 DEVICE_CONTEXT context)
│ │ │ │ -
56 {
│ │ │ │ -
57 return new MTLStencilTable(stencilTable, context);
│ │ │ │ -
58 }
│ │ │ │ +
39namespace Osd {
│ │ │ │ +
40
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
42: private NonCopyable<MTLLegacyGregoryPatchTable>
│ │ │ │ +
43{
│ │ │ │ +
44public:
│ │ │ │ + │ │ │ │ +
46
│ │ │ │ +
47 template<typename DEVICE_CONTEXT>
│ │ │ │ +
│ │ │ │ +
48 static MTLLegacyGregoryPatchTable* Create(Far::PatchTable const* farPatchTable, DEVICE_CONTEXT context) {
│ │ │ │ +
49 return Create(farPatchTable, context);
│ │ │ │ +
50 }
│ │ │ │ +
│ │ │ │ +
51
│ │ │ │ +
52 static MTLLegacyGregoryPatchTable* Create(Far::PatchTable const* farPatchTable, MTLContext* context);
│ │ │ │ +
53
│ │ │ │ +
54 void UpdateVertexBuffer(id<MTLBuffer> vbo, int numVertices, int numVertexElements, MTLContext* context);
│ │ │ │ +
55
│ │ │ │ +
│ │ │ │ +
56 id<MTLBuffer> GetVertexBuffer() const
│ │ │ │ +
57 {
│ │ │ │ +
58 return _vertexBuffer;
│ │ │ │ +
59 }
│ │ │ │
│ │ │ │ -
59
│ │ │ │
60
│ │ │ │ -
61 MTLStencilTable(Far::StencilTable const* stencilTable, MTLContext* context);
│ │ │ │ -
62 MTLStencilTable(Far::LimitStencilTable const* stencilTable, MTLContext* context);
│ │ │ │ - │ │ │ │ -
64
│ │ │ │ -
65 id<MTLBuffer> GetSizesBuffer() const { return _sizesBuffer; }
│ │ │ │ -
66 id<MTLBuffer> GetOffsetsBuffer() const { return _offsetsBuffer; }
│ │ │ │ -
67 id<MTLBuffer> GetIndicesBuffer() const { return _indicesBuffer; }
│ │ │ │ -
68 id<MTLBuffer> GetWeightsBuffer() const { return _weightsBuffer; }
│ │ │ │ -
69 id<MTLBuffer> GetDuWeightsBuffer() const { return _duWeightsBuffer; }
│ │ │ │ -
70 id<MTLBuffer> GetDvWeightsBuffer() const { return _dvWeightsBuffer; }
│ │ │ │ -
71 id<MTLBuffer> GetDuuWeightsBuffer() const { return _duuWeightsBuffer; }
│ │ │ │ -
72 id<MTLBuffer> GetDuvWeightsBuffer() const { return _duvWeightsBuffer; }
│ │ │ │ -
73 id<MTLBuffer> GetDvvWeightsBuffer() const { return _dvvWeightsBuffer; }
│ │ │ │ -
74
│ │ │ │ -
75 int GetNumStencils() const { return _numStencils; }
│ │ │ │ -
76
│ │ │ │ -
77private:
│ │ │ │ -
78 id<MTLBuffer> _sizesBuffer;
│ │ │ │ -
79 id<MTLBuffer> _offsetsBuffer;
│ │ │ │ -
80 id<MTLBuffer> _indicesBuffer;
│ │ │ │ -
81 id<MTLBuffer> _weightsBuffer;
│ │ │ │ -
82 id<MTLBuffer> _duWeightsBuffer;
│ │ │ │ -
83 id<MTLBuffer> _dvWeightsBuffer;
│ │ │ │ -
84 id<MTLBuffer> _duuWeightsBuffer;
│ │ │ │ -
85 id<MTLBuffer> _duvWeightsBuffer;
│ │ │ │ -
86 id<MTLBuffer> _dvvWeightsBuffer;
│ │ │ │ -
87
│ │ │ │ -
88 int _numStencils;
│ │ │ │ -
89};
│ │ │ │ -
│ │ │ │ -
90
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
92{
│ │ │ │ -
93public:
│ │ │ │ -
94 typedef bool Instantiatable;
│ │ │ │ -
95
│ │ │ │ - │ │ │ │ -
97 BufferDescriptor const &dstDesc,
│ │ │ │ -
98 BufferDescriptor const &duDesc,
│ │ │ │ -
99 BufferDescriptor const &dvDesc,
│ │ │ │ -
100 MTLContext* context);
│ │ │ │ -
101
│ │ │ │ - │ │ │ │ -
103 BufferDescriptor const &dstDesc,
│ │ │ │ -
104 BufferDescriptor const &duDesc,
│ │ │ │ -
105 BufferDescriptor const &dvDesc,
│ │ │ │ -
106 BufferDescriptor const &duuDesc,
│ │ │ │ -
107 BufferDescriptor const &duvDesc,
│ │ │ │ -
108 BufferDescriptor const &dvvDesc,
│ │ │ │ -
109 MTLContext* context);
│ │ │ │ -
110
│ │ │ │ - │ │ │ │ - │ │ │ │ -
113
│ │ │ │ -
119
│ │ │ │ -
148 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
149 static bool EvalStencils(
│ │ │ │ -
150 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
151 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
152 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
153 MTLComputeEvaluator const *instance,
│ │ │ │ -
154 MTLContext* context)
│ │ │ │ -
155 {
│ │ │ │ -
156 if (instance) {
│ │ │ │ -
157 return instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ -
158 dstBuffer, dstDesc,
│ │ │ │ -
159 stencilTable,
│ │ │ │ -
160 context);
│ │ │ │ -
161 } else {
│ │ │ │ -
162 // Create an instance on demand (slow)
│ │ │ │ -
163 instance = Create(srcDesc, dstDesc,
│ │ │ │ - │ │ │ │ - │ │ │ │ -
166 context);
│ │ │ │ -
167 if (instance) {
│ │ │ │ -
168 bool r = instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ -
169 dstBuffer, dstDesc,
│ │ │ │ -
170 stencilTable,
│ │ │ │ -
171 context);
│ │ │ │ -
172 delete instance;
│ │ │ │ -
173 return r;
│ │ │ │ -
174 }
│ │ │ │ -
175 return false;
│ │ │ │ -
176 }
│ │ │ │ -
177 }
│ │ │ │ -
│ │ │ │ -
178
│ │ │ │ -
219 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
220 static bool EvalStencils(
│ │ │ │ -
221 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
222 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
223 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
224 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
225 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
226 MTLComputeEvaluator const *instance,
│ │ │ │ -
227 MTLContext* context) {
│ │ │ │ -
228
│ │ │ │ -
229 if (instance) {
│ │ │ │ -
230 return instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ -
231 dstBuffer, dstDesc,
│ │ │ │ -
232 duBuffer, duDesc,
│ │ │ │ -
233 dvBuffer, dvDesc,
│ │ │ │ -
234 stencilTable,
│ │ │ │ -
235 context);
│ │ │ │ -
236 } else {
│ │ │ │ -
237 // Create an instance on demand (slow)
│ │ │ │ -
238 instance = Create(srcDesc, dstDesc, duDesc, dvDesc, context);
│ │ │ │ -
239 if (instance) {
│ │ │ │ -
240 bool r = instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ -
241 dstBuffer, dstDesc,
│ │ │ │ -
242 duBuffer, duDesc,
│ │ │ │ -
243 dvBuffer, dvDesc,
│ │ │ │ -
244 stencilTable,
│ │ │ │ -
245 context);
│ │ │ │ -
246 delete instance;
│ │ │ │ -
247 return r;
│ │ │ │ -
248 }
│ │ │ │ -
249 return false;
│ │ │ │ -
250 }
│ │ │ │ -
251 }
│ │ │ │ -
│ │ │ │ -
252
│ │ │ │ -
311 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
312 static bool EvalStencils(
│ │ │ │ -
313 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
314 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
315 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
316 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
317 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
318 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
319 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
320 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
321 MTLComputeEvaluator const *instance,
│ │ │ │ -
322 MTLContext* context) {
│ │ │ │ -
323
│ │ │ │ -
324 if (instance) {
│ │ │ │ -
325 return instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ -
326 dstBuffer, dstDesc,
│ │ │ │ -
327 duBuffer, duDesc,
│ │ │ │ -
328 dvBuffer, dvDesc,
│ │ │ │ -
329 duuBuffer, duuDesc,
│ │ │ │ -
330 duvBuffer, duvDesc,
│ │ │ │ -
331 dvvBuffer, dvvDesc,
│ │ │ │ -
332 stencilTable,
│ │ │ │ -
333 context);
│ │ │ │ -
334 } else {
│ │ │ │ -
335 // Create an instance on demand (slow)
│ │ │ │ -
336 instance = Create(srcDesc, dstDesc, duDesc, dvDesc,
│ │ │ │ -
337 duuDesc, duvDesc, dvvDesc, context);
│ │ │ │ -
338 if (instance) {
│ │ │ │ -
339 bool r = instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ -
340 dstBuffer, dstDesc,
│ │ │ │ -
341 duBuffer, duDesc,
│ │ │ │ -
342 dvBuffer, dvDesc,
│ │ │ │ -
343 duuBuffer, duuDesc,
│ │ │ │ -
344 duvBuffer, duvDesc,
│ │ │ │ -
345 dvvBuffer, dvvDesc,
│ │ │ │ -
346 stencilTable,
│ │ │ │ -
347 context);
│ │ │ │ -
348 delete instance;
│ │ │ │ -
349 return r;
│ │ │ │ -
350 }
│ │ │ │ -
351 return false;
│ │ │ │ -
352 }
│ │ │ │ -
353 }
│ │ │ │ -
│ │ │ │ -
354
│ │ │ │ -
375 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
377 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
378 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
379 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
380 MTLContext* context) const
│ │ │ │ -
381 {
│ │ │ │ -
382 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ -
383 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ -
384 0, BufferDescriptor(),
│ │ │ │ -
385 0, BufferDescriptor(),
│ │ │ │ -
386 stencilTable->GetSizesBuffer(),
│ │ │ │ -
387 stencilTable->GetOffsetsBuffer(),
│ │ │ │ -
388 stencilTable->GetIndicesBuffer(),
│ │ │ │ -
389 stencilTable->GetWeightsBuffer(),
│ │ │ │ -
390 0,
│ │ │ │ -
391 0,
│ │ │ │ -
392 /* start = */ 0,
│ │ │ │ -
393 /* end = */ stencilTable->GetNumStencils(),
│ │ │ │ -
394 context);
│ │ │ │ -
395 }
│ │ │ │ -
│ │ │ │ -
396
│ │ │ │ -
429 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
431 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
432 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
433 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
434 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
435 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
436 MTLContext* context) const
│ │ │ │ -
437 {
│ │ │ │ -
438 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ -
439 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ -
440 duBuffer->BindMTLBuffer(context), duDesc,
│ │ │ │ -
441 dvBuffer->BindMTLBuffer(context), dvDesc,
│ │ │ │ -
442 stencilTable->GetSizesBuffer(),
│ │ │ │ -
443 stencilTable->GetOffsetsBuffer(),
│ │ │ │ -
444 stencilTable->GetIndicesBuffer(),
│ │ │ │ -
445 stencilTable->GetWeightsBuffer(),
│ │ │ │ -
446 stencilTable->GetDuWeightsBuffer(),
│ │ │ │ -
447 stencilTable->GetDvWeightsBuffer(),
│ │ │ │ -
448 /* start = */ 0,
│ │ │ │ -
449 /* end = */ stencilTable->GetNumStencils(),
│ │ │ │ -
450 context);
│ │ │ │ -
451 }
│ │ │ │ -
│ │ │ │ -
452
│ │ │ │ -
503 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
505 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
506 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
507 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
508 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
509 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
510 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
511 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
512 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
513 MTLContext* context) const
│ │ │ │ -
514 {
│ │ │ │ -
515 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ -
516 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ -
517 duBuffer->BindMTLBuffer(context), duDesc,
│ │ │ │ -
518 dvBuffer->BindMTLBuffer(context), dvDesc,
│ │ │ │ -
519 duuBuffer->BindMTLBuffer(context), duuDesc,
│ │ │ │ -
520 duvBuffer->BindMTLBuffer(context), duvDesc,
│ │ │ │ -
521 dvvBuffer->BindMTLBuffer(context), dvvDesc,
│ │ │ │ -
522 stencilTable->GetSizesBuffer(),
│ │ │ │ -
523 stencilTable->GetOffsetsBuffer(),
│ │ │ │ -
524 stencilTable->GetIndicesBuffer(),
│ │ │ │ -
525 stencilTable->GetWeightsBuffer(),
│ │ │ │ -
526 stencilTable->GetDuWeightsBuffer(),
│ │ │ │ -
527 stencilTable->GetDvWeightsBuffer(),
│ │ │ │ -
528 stencilTable->GetDuuWeightsBuffer(),
│ │ │ │ -
529 stencilTable->GetDuvWeightsBuffer(),
│ │ │ │ -
530 stencilTable->GetDvvWeightsBuffer(),
│ │ │ │ -
531 /* start = */ 0,
│ │ │ │ -
532 /* end = */ stencilTable->GetNumStencils(),
│ │ │ │ -
533 context);
│ │ │ │ -
534 }
│ │ │ │ -
│ │ │ │ -
535
│ │ │ │ -
574 bool EvalStencils(id<MTLBuffer> srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
575 id<MTLBuffer> dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
576 id<MTLBuffer> duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
577 id<MTLBuffer> dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
578 id<MTLBuffer> sizesBuffer,
│ │ │ │ -
579 id<MTLBuffer> offsetsBuffer,
│ │ │ │ -
580 id<MTLBuffer> indicesBuffer,
│ │ │ │ -
581 id<MTLBuffer> weightsBuffer,
│ │ │ │ -
582 id<MTLBuffer> duWeightsBuffer,
│ │ │ │ -
583 id<MTLBuffer> dvWeightsBuffer,
│ │ │ │ -
584 int start,
│ │ │ │ -
585 int end,
│ │ │ │ -
586 MTLContext* context) const;
│ │ │ │ -
587
│ │ │ │ -
644 bool EvalStencils(id<MTLBuffer> srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
645 id<MTLBuffer> dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
646 id<MTLBuffer> duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
647 id<MTLBuffer> dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
648 id<MTLBuffer> duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
649 id<MTLBuffer> duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
650 id<MTLBuffer> dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
651 id<MTLBuffer> sizesBuffer,
│ │ │ │ -
652 id<MTLBuffer> offsetsBuffer,
│ │ │ │ -
653 id<MTLBuffer> indicesBuffer,
│ │ │ │ -
654 id<MTLBuffer> weightsBuffer,
│ │ │ │ -
655 id<MTLBuffer> duWeightsBuffer,
│ │ │ │ -
656 id<MTLBuffer> dvWeightsBuffer,
│ │ │ │ -
657 id<MTLBuffer> duuWeightsBuffer,
│ │ │ │ -
658 id<MTLBuffer> duvWeightsBuffer,
│ │ │ │ -
659 id<MTLBuffer> dvvWeightsBuffer,
│ │ │ │ -
660 int start,
│ │ │ │ -
661 int end,
│ │ │ │ -
662 MTLContext* context) const;
│ │ │ │ -
663
│ │ │ │ -
669
│ │ │ │ -
703 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
704 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
705 static bool EvalPatches(
│ │ │ │ -
706 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
707 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
708 int numPatchCoords,
│ │ │ │ -
709 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
710 PATCH_TABLE *patchTable,
│ │ │ │ -
711 MTLComputeEvaluator const *instance,
│ │ │ │ -
712 MTLContext* context) {
│ │ │ │ -
713
│ │ │ │ -
714 if (instance) {
│ │ │ │ -
715 return instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ -
716 dstBuffer, dstDesc,
│ │ │ │ -
717 numPatchCoords, patchCoords,
│ │ │ │ -
718 patchTable,
│ │ │ │ -
719 context);
│ │ │ │ -
720 } else {
│ │ │ │ -
721 // Create an instance on demand (slow)
│ │ │ │ -
722 instance = Create(srcDesc, dstDesc,
│ │ │ │ - │ │ │ │ - │ │ │ │ -
725 context);
│ │ │ │ -
726 if (instance) {
│ │ │ │ -
727 bool r = instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ -
728 dstBuffer, dstDesc,
│ │ │ │ -
729 numPatchCoords, patchCoords,
│ │ │ │ -
730 patchTable,
│ │ │ │ -
731 context);
│ │ │ │ -
732 delete instance;
│ │ │ │ -
733 return r;
│ │ │ │ -
734 }
│ │ │ │ -
735 return false;
│ │ │ │ -
736 }
│ │ │ │ -
737 }
│ │ │ │ -
│ │ │ │ -
738
│ │ │ │ -
784 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
785 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
786 static bool EvalPatches(
│ │ │ │ -
787 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
788 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
789 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
790 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
791 int numPatchCoords,
│ │ │ │ -
792 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
793 PATCH_TABLE *patchTable,
│ │ │ │ -
794 MTLComputeEvaluator* instance,
│ │ │ │ -
795 MTLContext* context) {
│ │ │ │ -
796
│ │ │ │ -
797 if (instance) {
│ │ │ │ -
798 return instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ -
799 dstBuffer, dstDesc,
│ │ │ │ -
800 duBuffer, duDesc,
│ │ │ │ -
801 dvBuffer, dvDesc,
│ │ │ │ -
802 numPatchCoords, patchCoords,
│ │ │ │ -
803 patchTable,
│ │ │ │ -
804 context);
│ │ │ │ -
805 } else {
│ │ │ │ -
806 // Create an instance on demand (slow)
│ │ │ │ -
807 instance = Create(srcDesc, dstDesc,
│ │ │ │ -
808 duDesc, dvDesc, context);
│ │ │ │ -
809 if (instance) {
│ │ │ │ -
810 bool r = instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ -
811 dstBuffer, dstDesc,
│ │ │ │ -
812 duBuffer, duDesc,
│ │ │ │ -
813 dvBuffer, dvDesc,
│ │ │ │ -
814 numPatchCoords, patchCoords,
│ │ │ │ -
815 patchTable,
│ │ │ │ -
816 context);
│ │ │ │ -
817 delete instance;
│ │ │ │ -
818 return r;
│ │ │ │ -
819 }
│ │ │ │ -
820 return false;
│ │ │ │ -
821 }
│ │ │ │ -
822 }
│ │ │ │ -
│ │ │ │ -
823
│ │ │ │ -
887 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
888 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
889 static bool EvalPatches(
│ │ │ │ -
890 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
891 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
892 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
893 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
894 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
895 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
896 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
897 int numPatchCoords,
│ │ │ │ -
898 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
899 PATCH_TABLE *patchTable,
│ │ │ │ -
900 MTLComputeEvaluator* instance,
│ │ │ │ -
901 MTLContext* context) {
│ │ │ │ -
902
│ │ │ │ -
903 if (instance) {
│ │ │ │ -
904 return instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ -
905 dstBuffer, dstDesc,
│ │ │ │ -
906 duBuffer, duDesc,
│ │ │ │ -
907 dvBuffer, dvDesc,
│ │ │ │ -
908 duuBuffer, duuDesc,
│ │ │ │ -
909 duvBuffer, duvDesc,
│ │ │ │ -
910 dvvBuffer, dvvDesc,
│ │ │ │ -
911 numPatchCoords, patchCoords,
│ │ │ │ -
912 patchTable,
│ │ │ │ -
913 context);
│ │ │ │ -
914 } else {
│ │ │ │ -
915 // Create an instance on demand (slow)
│ │ │ │ -
916 instance = Create(srcDesc, dstDesc,
│ │ │ │ -
917 duDesc, dvDesc,
│ │ │ │ -
918 duuDesc, duvDesc, dvvDesc, context);
│ │ │ │ -
919 if (instance) {
│ │ │ │ -
920 bool r = instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ -
921 dstBuffer, dstDesc,
│ │ │ │ -
922 duBuffer, duDesc,
│ │ │ │ -
923 dvBuffer, dvDesc,
│ │ │ │ -
924 duuBuffer, duuDesc,
│ │ │ │ -
925 duvBuffer, duvDesc,
│ │ │ │ -
926 dvvBuffer, dvvDesc,
│ │ │ │ -
927 numPatchCoords, patchCoords,
│ │ │ │ -
928 patchTable,
│ │ │ │ -
929 context);
│ │ │ │ -
930 delete instance;
│ │ │ │ -
931 return r;
│ │ │ │ -
932 }
│ │ │ │ -
933 return false;
│ │ │ │ -
934 }
│ │ │ │ -
935 }
│ │ │ │ -
│ │ │ │ -
936
│ │ │ │ -
964 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
965 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
967 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
968 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
969 int numPatchCoords,
│ │ │ │ -
970 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
971 PATCH_TABLE *patchTable,
│ │ │ │ -
972 MTLContext* context) const {
│ │ │ │ -
973
│ │ │ │ -
974 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ -
975 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ -
976 0, BufferDescriptor(),
│ │ │ │ -
977 0, BufferDescriptor(),
│ │ │ │ -
978 numPatchCoords,
│ │ │ │ -
979 patchCoords->BindMTLBuffer(context),
│ │ │ │ -
980 patchTable->GetPatchArrays(),
│ │ │ │ -
981 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
982 patchTable->GetPatchParamBuffer(),
│ │ │ │ -
983 context);
│ │ │ │ -
984 }
│ │ │ │ -
│ │ │ │ -
985
│ │ │ │ -
1023 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1024 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1026 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1027 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1028 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1029 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1030 int numPatchCoords,
│ │ │ │ -
1031 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1032 PATCH_TABLE *patchTable,
│ │ │ │ -
1033 MTLContext* context) const {
│ │ │ │ -
1034
│ │ │ │ -
1035 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ -
1036 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ -
1037 duBuffer->BindMTLBuffer(context), duDesc,
│ │ │ │ -
1038 dvBuffer->BindMTLBuffer(context), dvDesc,
│ │ │ │ -
1039 numPatchCoords,
│ │ │ │ -
1040 patchCoords->BindMTLBuffer(context),
│ │ │ │ -
1041 patchTable->GetPatchArrays(),
│ │ │ │ -
1042 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
1043 patchTable->GetPatchParamBuffer(),
│ │ │ │ -
1044 context);
│ │ │ │ -
1045 }
│ │ │ │ -
│ │ │ │ -
1046
│ │ │ │ -
1102 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1103 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1105 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1106 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1107 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1108 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1109 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
1110 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
1111 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
1112 int numPatchCoords,
│ │ │ │ -
1113 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1114 PATCH_TABLE *patchTable,
│ │ │ │ -
1115 MTLContext* context) const {
│ │ │ │ -
1116
│ │ │ │ -
1117 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ -
1118 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ -
1119 duBuffer->BindMTLBuffer(context), duDesc,
│ │ │ │ -
1120 dvBuffer->BindMTLBuffer(context), dvDesc,
│ │ │ │ -
1121 duuBuffer->BindMTLBuffer(context), duuDesc,
│ │ │ │ -
1122 duvBuffer->BindMTLBuffer(context), duvDesc,
│ │ │ │ -
1123 dvvBuffer->BindMTLBuffer(context), dvvDesc,
│ │ │ │ -
1124 numPatchCoords,
│ │ │ │ -
1125 patchCoords->BindMTLBuffer(context),
│ │ │ │ -
1126 patchTable->GetPatchArrays(),
│ │ │ │ -
1127 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
1128 patchTable->GetPatchParamBuffer(),
│ │ │ │ -
1129 context);
│ │ │ │ -
1130 }
│ │ │ │ -
│ │ │ │ -
1131
│ │ │ │ -
1132 bool EvalPatches(id<MTLBuffer> srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1133 id<MTLBuffer> dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1134 id<MTLBuffer> duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1135 id<MTLBuffer> dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1136 int numPatchCoords,
│ │ │ │ -
1137 id<MTLBuffer> patchCoordsBuffer,
│ │ │ │ -
1138 const PatchArrayVector &patchArrays,
│ │ │ │ -
1139 id<MTLBuffer> patchIndexBuffer,
│ │ │ │ -
1140 id<MTLBuffer> patchParamsBuffer,
│ │ │ │ -
1141 MTLContext* context) const;
│ │ │ │ -
1142
│ │ │ │ -
1143 bool EvalPatches(id<MTLBuffer> srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1144 id<MTLBuffer> dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1145 id<MTLBuffer> duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1146 id<MTLBuffer> dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1147 id<MTLBuffer> duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
1148 id<MTLBuffer> duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
1149 id<MTLBuffer> dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
1150 int numPatchCoords,
│ │ │ │ -
1151 id<MTLBuffer> patchCoordsBuffer,
│ │ │ │ -
1152 const PatchArrayVector &patchArrays,
│ │ │ │ -
1153 id<MTLBuffer> patchIndexBuffer,
│ │ │ │ -
1154 id<MTLBuffer> patchParamsBuffer,
│ │ │ │ -
1155 MTLContext* context) const;
│ │ │ │ -
1156
│ │ │ │ -
1190 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1191 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1193 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1194 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1195 int numPatchCoords,
│ │ │ │ -
1196 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1197 PATCH_TABLE *patchTable,
│ │ │ │ -
1198 MTLComputeEvaluator const *instance,
│ │ │ │ -
1199 MTLContext* deviceContext) {
│ │ │ │ -
1200
│ │ │ │ -
1201 if (instance) {
│ │ │ │ -
1202 return instance->EvalPatchesVarying(
│ │ │ │ -
1203 srcBuffer, srcDesc,
│ │ │ │ -
1204 dstBuffer, dstDesc,
│ │ │ │ -
1205 numPatchCoords, patchCoords,
│ │ │ │ -
1206 patchTable,
│ │ │ │ -
1207 deviceContext);
│ │ │ │ -
1208 } else {
│ │ │ │ -
1209 // Create an instance on demand (slow)
│ │ │ │ -
1210 instance = Create(srcDesc, dstDesc,
│ │ │ │ - │ │ │ │ - │ │ │ │ -
1213 deviceContext);
│ │ │ │ -
1214 if (instance) {
│ │ │ │ -
1215 bool r = instance->EvalPatchesVarying(
│ │ │ │ -
1216 srcBuffer, srcDesc,
│ │ │ │ -
1217 dstBuffer, dstDesc,
│ │ │ │ -
1218 numPatchCoords, patchCoords,
│ │ │ │ -
1219 patchTable,
│ │ │ │ -
1220 deviceContext);
│ │ │ │ -
1221 delete instance;
│ │ │ │ -
1222 return r;
│ │ │ │ -
1223 }
│ │ │ │ -
1224 return false;
│ │ │ │ -
1225 }
│ │ │ │ -
1226 }
│ │ │ │ -
│ │ │ │ -
1227
│ │ │ │ -
1255 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1256 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1258 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1259 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1260 int numPatchCoords,
│ │ │ │ -
1261 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1262 PATCH_TABLE *patchTable,
│ │ │ │ -
1263 MTLContext* deviceContext) const {
│ │ │ │ -
1264
│ │ │ │ -
1265 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ -
1266 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ -
1267 0, BufferDescriptor(),
│ │ │ │ -
1268 0, BufferDescriptor(),
│ │ │ │ -
1269 numPatchCoords,
│ │ │ │ -
1270 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ -
1271 patchTable->GetVaryingPatchArrays(),
│ │ │ │ -
1272 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
1273 patchTable->GetPatchParamBuffer(),
│ │ │ │ -
1274 deviceContext
│ │ │ │ -
1275 );
│ │ │ │ -
1276 }
│ │ │ │ -
│ │ │ │ -
1277
│ │ │ │ -
1323 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1324 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1326 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1327 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1328 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1329 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1330 int numPatchCoords,
│ │ │ │ -
1331 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1332 PATCH_TABLE *patchTable,
│ │ │ │ -
1333 MTLComputeEvaluator const *instance,
│ │ │ │ -
1334 MTLContext* deviceContext) {
│ │ │ │ -
1335
│ │ │ │ -
1336 if (instance) {
│ │ │ │ -
1337 return instance->EvalPatchesVarying(
│ │ │ │ -
1338 srcBuffer, srcDesc,
│ │ │ │ -
1339 dstBuffer, dstDesc,
│ │ │ │ -
1340 duBuffer, duDesc,
│ │ │ │ -
1341 dvBuffer, dvDesc,
│ │ │ │ -
1342 numPatchCoords, patchCoords,
│ │ │ │ -
1343 patchTable,
│ │ │ │ -
1344 deviceContext);
│ │ │ │ -
1345 } else {
│ │ │ │ -
1346 // Create an instance on demand (slow)
│ │ │ │ -
1347 instance = Create(srcDesc, dstDesc,
│ │ │ │ -
1348 duDesc, dvDesc,
│ │ │ │ -
1349 deviceContext);
│ │ │ │ -
1350 if (instance) {
│ │ │ │ -
1351 bool r = instance->EvalPatchesVarying(
│ │ │ │ -
1352 srcBuffer, srcDesc,
│ │ │ │ -
1353 dstBuffer, dstDesc,
│ │ │ │ -
1354 duBuffer, duDesc,
│ │ │ │ -
1355 dvBuffer, dvDesc,
│ │ │ │ -
1356 numPatchCoords, patchCoords,
│ │ │ │ -
1357 patchTable,
│ │ │ │ -
1358 deviceContext);
│ │ │ │ -
1359 delete instance;
│ │ │ │ -
1360 return r;
│ │ │ │ -
1361 }
│ │ │ │ -
1362 return false;
│ │ │ │ -
1363 }
│ │ │ │ -
1364 }
│ │ │ │ -
│ │ │ │ -
1365
│ │ │ │ -
1405 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1406 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1408 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1409 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1410 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1411 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1412 int numPatchCoords,
│ │ │ │ -
1413 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1414 PATCH_TABLE *patchTable,
│ │ │ │ -
1415 MTLContext* deviceContext) const {
│ │ │ │ -
1416
│ │ │ │ -
1417 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ -
1418 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ -
1419 duBuffer->BindMTLBuffer(deviceContext), duDesc,
│ │ │ │ -
1420 dvBuffer->BindMTLBuffer(deviceContext), dvDesc,
│ │ │ │ -
1421 numPatchCoords,
│ │ │ │ -
1422 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ -
1423 patchTable->GetVaryingPatchArrays(),
│ │ │ │ -
1424 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
1425 patchTable->GetPatchParamBuffer(),
│ │ │ │ -
1426 deviceContext
│ │ │ │ -
1427 );
│ │ │ │ -
1428 }
│ │ │ │ -
│ │ │ │ -
1429
│ │ │ │ -
1430
│ │ │ │ -
1494 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1495 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1497 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1498 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1499 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1500 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1501 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
1502 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
1503 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
1504 int numPatchCoords,
│ │ │ │ -
1505 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1506 PATCH_TABLE *patchTable,
│ │ │ │ -
1507 MTLComputeEvaluator const *instance,
│ │ │ │ -
1508 MTLContext* deviceContext) {
│ │ │ │ -
1509
│ │ │ │ -
1510 if (instance) {
│ │ │ │ -
1511 return instance->EvalPatchesVarying(
│ │ │ │ -
1512 srcBuffer, srcDesc,
│ │ │ │ -
1513 dstBuffer, dstDesc,
│ │ │ │ -
1514 duBuffer, duDesc,
│ │ │ │ -
1515 dvBuffer, dvDesc,
│ │ │ │ -
1516 duuBuffer, duuDesc,
│ │ │ │ -
1517 duvBuffer, duvDesc,
│ │ │ │ -
1518 dvvBuffer, dvvDesc,
│ │ │ │ -
1519 numPatchCoords, patchCoords,
│ │ │ │ -
1520 patchTable,
│ │ │ │ -
1521 deviceContext);
│ │ │ │ -
1522 } else {
│ │ │ │ -
1523 // Create an instance on demand (slow)
│ │ │ │ -
1524 instance = Create(srcDesc, dstDesc,
│ │ │ │ -
1525 duDesc, dvDesc,
│ │ │ │ -
1526 duuDesc, duvDesc, dvvDesc,
│ │ │ │ -
1527 deviceContext);
│ │ │ │ -
1528 if (instance) {
│ │ │ │ -
1529 bool r = instance->EvalPatchesVarying(
│ │ │ │ -
1530 srcBuffer, srcDesc,
│ │ │ │ -
1531 dstBuffer, dstDesc,
│ │ │ │ -
1532 duBuffer, duDesc,
│ │ │ │ -
1533 dvBuffer, dvDesc,
│ │ │ │ -
1534 duuBuffer, duuDesc,
│ │ │ │ -
1535 duvBuffer, duvDesc,
│ │ │ │ -
1536 dvvBuffer, dvvDesc,
│ │ │ │ -
1537 numPatchCoords, patchCoords,
│ │ │ │ -
1538 patchTable,
│ │ │ │ -
1539 deviceContext);
│ │ │ │ -
1540 delete instance;
│ │ │ │ -
1541 return r;
│ │ │ │ -
1542 }
│ │ │ │ -
1543 return false;
│ │ │ │ -
1544 }
│ │ │ │ -
1545 }
│ │ │ │ -
│ │ │ │ -
1546
│ │ │ │ -
1604 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1605 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1607 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1608 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1609 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1610 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1611 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
1612 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
1613 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
1614 int numPatchCoords,
│ │ │ │ -
1615 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1616 PATCH_TABLE *patchTable,
│ │ │ │ -
1617 MTLContext* deviceContext) const {
│ │ │ │ -
1618
│ │ │ │ -
1619 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ -
1620 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ -
1621 duBuffer->BindMTLBuffer(deviceContext), duDesc,
│ │ │ │ -
1622 dvBuffer->BindMTLBuffer(deviceContext), dvDesc,
│ │ │ │ -
1623 duuBuffer->BindMTLBuffer(deviceContext), duuDesc,
│ │ │ │ -
1624 duvBuffer->BindMTLBuffer(deviceContext), duvDesc,
│ │ │ │ -
1625 dvvBuffer->BindMTLBuffer(deviceContext), dvvDesc,
│ │ │ │ -
1626 numPatchCoords,
│ │ │ │ -
1627 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ -
1628 patchTable->GetVaryingPatchArrays(),
│ │ │ │ -
1629 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
1630 patchTable->GetPatchParamBuffer(),
│ │ │ │ -
1631 deviceContext
│ │ │ │ -
1632 );
│ │ │ │ -
1633 }
│ │ │ │ -
│ │ │ │ -
1634
│ │ │ │ -
1670 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1671 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1673 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1674 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1675 int numPatchCoords,
│ │ │ │ -
1676 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1677 PATCH_TABLE *patchTable,
│ │ │ │ -
1678 int fvarChannel,
│ │ │ │ -
1679 MTLComputeEvaluator const *instance,
│ │ │ │ -
1680 MTLContext* deviceContext) {
│ │ │ │ -
1681
│ │ │ │ -
1682 if (instance) {
│ │ │ │ -
1683 return instance->EvalPatchesFaceVarying(
│ │ │ │ -
1684 srcBuffer, srcDesc,
│ │ │ │ -
1685 dstBuffer, dstDesc,
│ │ │ │ -
1686 numPatchCoords, patchCoords,
│ │ │ │ -
1687 patchTable,
│ │ │ │ -
1688 fvarChannel,
│ │ │ │ -
1689 deviceContext);
│ │ │ │ -
1690 } else {
│ │ │ │ -
1691 // Create an instance on demand (slow)
│ │ │ │ -
1692 instance = Create(srcDesc, dstDesc,
│ │ │ │ - │ │ │ │ - │ │ │ │ -
1695 deviceContext);
│ │ │ │ -
1696 if (instance) {
│ │ │ │ -
1697 bool r = instance->EvalPatchesFaceVarying(
│ │ │ │ -
1698 srcBuffer, srcDesc,
│ │ │ │ -
1699 dstBuffer, dstDesc,
│ │ │ │ -
1700 numPatchCoords, patchCoords,
│ │ │ │ -
1701 patchTable,
│ │ │ │ -
1702 fvarChannel,
│ │ │ │ -
1703 deviceContext);
│ │ │ │ -
1704 delete instance;
│ │ │ │ -
1705 return r;
│ │ │ │ -
1706 }
│ │ │ │ -
1707 return false;
│ │ │ │ -
1708 }
│ │ │ │ -
1709 }
│ │ │ │ -
│ │ │ │ -
1710
│ │ │ │ -
1740 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1741 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1743 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1744 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1745 int numPatchCoords,
│ │ │ │ -
1746 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1747 PATCH_TABLE *patchTable,
│ │ │ │ -
1748 int fvarChannel,
│ │ │ │ -
1749 MTLContext* deviceContext) const {
│ │ │ │ -
1750
│ │ │ │ -
1751 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ -
1752 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ -
1753 0, BufferDescriptor(),
│ │ │ │ -
1754 0, BufferDescriptor(),
│ │ │ │ -
1755 numPatchCoords,
│ │ │ │ -
1756 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ -
1757 patchTable->GetFVarPatchArrays(fvarChannel),
│ │ │ │ -
1758 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
1759 patchTable->GetFVarPatchParamBuffer(fvarChannel),
│ │ │ │ -
1760 deviceContext
│ │ │ │ -
1761 );
│ │ │ │ -
1762 }
│ │ │ │ -
│ │ │ │ -
1763
│ │ │ │ -
1811 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1812 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1814 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1815 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1816 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1817 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1818 int numPatchCoords,
│ │ │ │ -
1819 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1820 PATCH_TABLE *patchTable,
│ │ │ │ -
1821 int fvarChannel,
│ │ │ │ -
1822 MTLComputeEvaluator const *instance,
│ │ │ │ -
1823 MTLContext* deviceContext) {
│ │ │ │ -
1824
│ │ │ │ -
1825 if (instance) {
│ │ │ │ -
1826 return instance->EvalPatchesFaceVarying(
│ │ │ │ -
1827 srcBuffer, srcDesc,
│ │ │ │ -
1828 dstBuffer, dstDesc,
│ │ │ │ -
1829 duBuffer, duDesc,
│ │ │ │ -
1830 dvBuffer, dvDesc,
│ │ │ │ -
1831 numPatchCoords, patchCoords,
│ │ │ │ -
1832 patchTable,
│ │ │ │ -
1833 fvarChannel,
│ │ │ │ -
1834 deviceContext);
│ │ │ │ -
1835 } else {
│ │ │ │ -
1836 // Create an instance on demand (slow)
│ │ │ │ -
1837 instance = Create(srcDesc, dstDesc,
│ │ │ │ -
1838 duDesc, dvDesc,
│ │ │ │ -
1839 deviceContext);
│ │ │ │ -
1840 if (instance) {
│ │ │ │ -
1841 bool r = instance->EvalPatchesFaceVarying(
│ │ │ │ -
1842 srcBuffer, srcDesc,
│ │ │ │ -
1843 dstBuffer, dstDesc,
│ │ │ │ -
1844 duBuffer, duDesc,
│ │ │ │ -
1845 dvBuffer, dvDesc,
│ │ │ │ -
1846 numPatchCoords, patchCoords,
│ │ │ │ -
1847 patchTable,
│ │ │ │ -
1848 fvarChannel,
│ │ │ │ -
1849 deviceContext);
│ │ │ │ -
1850 delete instance;
│ │ │ │ -
1851 return r;
│ │ │ │ -
1852 }
│ │ │ │ -
1853 return false;
│ │ │ │ -
1854 }
│ │ │ │ -
1855 }
│ │ │ │ -
│ │ │ │ -
1856
│ │ │ │ -
1898 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1899 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1901 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1902 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1903 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1904 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1905 int numPatchCoords,
│ │ │ │ -
1906 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1907 PATCH_TABLE *patchTable,
│ │ │ │ -
1908 int fvarChannel,
│ │ │ │ -
1909 MTLContext* deviceContext) const {
│ │ │ │ -
1910
│ │ │ │ -
1911 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ -
1912 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ -
1913 duBuffer->BindMTLBuffer(deviceContext), duDesc,
│ │ │ │ -
1914 dvBuffer->BindMTLBuffer(deviceContext), dvDesc,
│ │ │ │ -
1915 numPatchCoords,
│ │ │ │ -
1916 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ -
1917 patchTable->GetFVarPatchArrays(fvarChannel),
│ │ │ │ -
1918 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
1919 patchTable->GetFVarPatchParamBuffer(fvarChannel),
│ │ │ │ -
1920 deviceContext
│ │ │ │ -
1921 );
│ │ │ │ -
1922 }
│ │ │ │ -
│ │ │ │ -
1923
│ │ │ │ -
1989 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1990 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1992 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1993 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1994 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1995 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1996 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
1997 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
1998 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
1999 int numPatchCoords,
│ │ │ │ -
2000 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
2001 PATCH_TABLE *patchTable,
│ │ │ │ -
2002 int fvarChannel,
│ │ │ │ -
2003 MTLComputeEvaluator const *instance,
│ │ │ │ -
2004 MTLContext* deviceContext) {
│ │ │ │ -
2005
│ │ │ │ -
2006 if (instance) {
│ │ │ │ -
2007 return instance->EvalPatchesFaceVarying(
│ │ │ │ -
2008 srcBuffer, srcDesc,
│ │ │ │ -
2009 dstBuffer, dstDesc,
│ │ │ │ -
2010 duBuffer, duDesc,
│ │ │ │ -
2011 dvBuffer, dvDesc,
│ │ │ │ -
2012 duuBuffer, duuDesc,
│ │ │ │ -
2013 duvBuffer, duvDesc,
│ │ │ │ -
2014 dvvBuffer, dvvDesc,
│ │ │ │ -
2015 numPatchCoords, patchCoords,
│ │ │ │ -
2016 patchTable,
│ │ │ │ -
2017 fvarChannel,
│ │ │ │ -
2018 deviceContext);
│ │ │ │ -
2019 } else {
│ │ │ │ -
2020 // Create an instance on demand (slow)
│ │ │ │ -
2021 instance = Create(srcDesc, dstDesc,
│ │ │ │ -
2022 duDesc, dvDesc,
│ │ │ │ -
2023 duuDesc, duvDesc, dvvDesc,
│ │ │ │ -
2024 deviceContext);
│ │ │ │ -
2025 if (instance) {
│ │ │ │ -
2026 bool r = instance->EvalPatchesFaceVarying(
│ │ │ │ -
2027 srcBuffer, srcDesc,
│ │ │ │ -
2028 dstBuffer, dstDesc,
│ │ │ │ -
2029 duBuffer, duDesc,
│ │ │ │ -
2030 dvBuffer, dvDesc,
│ │ │ │ -
2031 duuBuffer, duuDesc,
│ │ │ │ -
2032 duvBuffer, duvDesc,
│ │ │ │ -
2033 dvvBuffer, dvvDesc,
│ │ │ │ -
2034 numPatchCoords, patchCoords,
│ │ │ │ -
2035 patchTable,
│ │ │ │ -
2036 fvarChannel,
│ │ │ │ -
2037 deviceContext);
│ │ │ │ -
2038 delete instance;
│ │ │ │ -
2039 return r;
│ │ │ │ -
2040 }
│ │ │ │ -
2041 return false;
│ │ │ │ -
2042 }
│ │ │ │ -
2043 }
│ │ │ │ -
│ │ │ │ -
2044
│ │ │ │ -
2104 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
2105 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
2107 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
2108 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
2109 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
2110 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
2111 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
2112 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
2113 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
2114 int numPatchCoords,
│ │ │ │ -
2115 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
2116 PATCH_TABLE *patchTable,
│ │ │ │ -
2117 int fvarChannel,
│ │ │ │ -
2118 MTLContext* deviceContext) const {
│ │ │ │ -
2119
│ │ │ │ -
2120 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ -
2121 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ -
2122 duBuffer->BindMTLBuffer(deviceContext), duDesc,
│ │ │ │ -
2123 dvBuffer->BindMTLBuffer(deviceContext), dvDesc,
│ │ │ │ -
2124 duuBuffer->BindMTLBuffer(deviceContext), duuDesc,
│ │ │ │ -
2125 duvBuffer->BindMTLBuffer(deviceContext), duvDesc,
│ │ │ │ -
2126 dvvBuffer->BindMTLBuffer(deviceContext), dvvDesc,
│ │ │ │ -
2127 numPatchCoords,
│ │ │ │ -
2128 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ -
2129 patchTable->GetFVarPatchArrays(fvarChannel),
│ │ │ │ -
2130 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
2131 patchTable->GetFVarPatchParamBuffer(fvarChannel),
│ │ │ │ -
2132 fvarChannel,
│ │ │ │ -
2133 deviceContext
│ │ │ │ -
2134 );
│ │ │ │ -
2135 }
│ │ │ │ -
│ │ │ │ -
2136
│ │ │ │ -
2138 bool Compile(BufferDescriptor const &srcDesc,
│ │ │ │ -
2139 BufferDescriptor const &dstDesc,
│ │ │ │ -
2140 BufferDescriptor const &duDesc,
│ │ │ │ -
2141 BufferDescriptor const &dvDesc,
│ │ │ │ -
2142 BufferDescriptor const &duuDesc,
│ │ │ │ -
2143 BufferDescriptor const &duvDesc,
│ │ │ │ -
2144 BufferDescriptor const &dvvDesc,
│ │ │ │ -
2145 MTLContext* context);
│ │ │ │ -
2146
│ │ │ │ -
2148 static void Synchronize(MTLContext* context);
│ │ │ │ -
2149
│ │ │ │ -
2150 private:
│ │ │ │ -
2151
│ │ │ │ -
2152 id<MTLLibrary> _computeLibrary;
│ │ │ │ -
2153 id<MTLComputePipelineState> _evalStencils;
│ │ │ │ -
2154 id<MTLComputePipelineState> _evalPatches;
│ │ │ │ -
2155 id<MTLBuffer> _parameterBuffer;
│ │ │ │ -
2156
│ │ │ │ -
2157 int _workGroupSize;
│ │ │ │ -
2158};
│ │ │ │ -
│ │ │ │ -
2159
│ │ │ │ -
2160} //end namespace Osd
│ │ │ │ -
2161
│ │ │ │ -
2162} //end namespace OPENSUBDIV_VERSION
│ │ │ │ -
2163using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
2164
│ │ │ │ -
2165} //end namespace OpenSubdiv
│ │ │ │ -
2166
│ │ │ │ -
2167#endif // OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H
│ │ │ │ - │ │ │ │ -
std::vector< PatchArray > PatchArrayVector
Definition types.h:132
│ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ -
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ +
│ │ │ │ +
61 id<MTLBuffer> GetVertexValenceBuffer() const
│ │ │ │ +
62 {
│ │ │ │ +
63 return _vertexValenceBuffer;
│ │ │ │ +
64 }
│ │ │ │ +
│ │ │ │ +
65
│ │ │ │ +
│ │ │ │ +
66 id<MTLBuffer> GetQuadOffsetsBuffer() const
│ │ │ │ +
67 {
│ │ │ │ +
68 return _quadOffsetsBuffer;
│ │ │ │ +
69 }
│ │ │ │ +
│ │ │ │ +
70
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
72 {
│ │ │ │ + │ │ │ │ +
74 return _quadOffsetsBase[1];
│ │ │ │ +
75 return _quadOffsetsBase[0];
│ │ │ │ +
76 }
│ │ │ │ +
│ │ │ │ +
77
│ │ │ │ +
78private:
│ │ │ │ +
79 id<MTLBuffer> _vertexBuffer;
│ │ │ │ +
80 id<MTLBuffer> _vertexValenceBuffer;
│ │ │ │ +
81 id<MTLBuffer> _quadOffsetsBuffer;
│ │ │ │ +
82 int _quadOffsetsBase[2];
│ │ │ │ +
83};
│ │ │ │ +
│ │ │ │ +
84
│ │ │ │ +
85} //end namespace Osd
│ │ │ │ +
86
│ │ │ │ +
87} //end namespace OPENSUBDIV_VERSION
│ │ │ │ +
88using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
89
│ │ │ │ +
90} //end namespace OpenSuddiv
│ │ │ │ +
91
│ │ │ │ +
92#endif // OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ │ │ │ │ - │ │ │ │ -
MTLStencilTable(Far::LimitStencilTable const *stencilTable, MTLContext *context)
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
MTLStencilTable(Far::StencilTable const *stencilTable, MTLContext *context)
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
static MTLStencilTable * Create(STENCIL_TABLE *stencilTable, DEVICE_CONTEXT context)
│ │ │ │ - │ │ │ │ - │ │ │ │ -
bool EvalStencils(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, BufferDescriptor const &dvDesc, id< MTLBuffer > duuBuffer, BufferDescriptor const &duuDesc, id< MTLBuffer > duvBuffer, BufferDescriptor const &duvDesc, id< MTLBuffer > dvvBuffer, BufferDescriptor const &dvvDesc, id< MTLBuffer > sizesBuffer, id< MTLBuffer > offsetsBuffer, id< MTLBuffer > indicesBuffer, id< MTLBuffer > weightsBuffer, id< MTLBuffer > duWeightsBuffer, id< MTLBuffer > dvWeightsBuffer, id< MTLBuffer > duuWeightsBuffer, id< MTLBuffer > duvWeightsBuffer, id< MTLBuffer > dvvWeightsBuffer, int start, int end, MTLContext *context) const
Dispatch the MTL compute kernel on GPU asynchronously returns false if the kernel hasn't been compile...
│ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator *instance, MTLContext *context)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, MTLComputeEvaluator const *instance, MTLContext *context)
Generic static stencil function. This function has a same signature as other device kernels have so t...
│ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ - │ │ │ │ - │ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, MTLContext *context)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ - │ │ │ │ -
bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, MTLComputeEvaluator const *instance, MTLContext *context)
Generic static stencil function. This function has a same signature as other device kernels have so t...
│ │ │ │ -
bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, MTLContext *context) const
Generic stencil function.
│ │ │ │ -
bool EvalPatches(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, BufferDescriptor const &dvDesc, id< MTLBuffer > duuBuffer, BufferDescriptor const &duuDesc, id< MTLBuffer > duvBuffer, BufferDescriptor const &duvDesc, id< MTLBuffer > dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, id< MTLBuffer > patchCoordsBuffer, const PatchArrayVector &patchArrays, id< MTLBuffer > patchIndexBuffer, id< MTLBuffer > patchParamsBuffer, MTLContext *context) const
│ │ │ │ -
bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static void Synchronize(MTLContext *context)
Wait for the dispatched kernel to finish.
│ │ │ │ -
bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, MTLContext *context) const
Generic stencil function.
│ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator *instance, MTLContext *context)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, MTLContext *context) const
Generic stencil function.
│ │ │ │ -
bool EvalStencils(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, BufferDescriptor const &dvDesc, id< MTLBuffer > sizesBuffer, id< MTLBuffer > offsetsBuffer, id< MTLBuffer > indicesBuffer, id< MTLBuffer > weightsBuffer, id< MTLBuffer > duWeightsBuffer, id< MTLBuffer > dvWeightsBuffer, int start, int end, MTLContext *context) const
Dispatch the MTL compute kernel on GPU asynchronously returns false if the kernel hasn't been compile...
│ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *context) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, MTLComputeEvaluator const *instance, MTLContext *context)
Generic static stencil function. This function has a same signature as other device kernels have so t...
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *context) const
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ -
bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *context) const
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ -
bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static MTLComputeEvaluator * Create(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, MTLContext *context)
│ │ │ │ -
static MTLComputeEvaluator * Create(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, MTLContext *context)
│ │ │ │ -
bool Compile(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, MTLContext *context)
Configure compute pipline state. Returns false if it fails to create the pipeline state.
│ │ │ │ -
bool EvalPatches(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, id< MTLBuffer > patchCoordsBuffer, const PatchArrayVector &patchArrays, id< MTLBuffer > patchIndexBuffer, id< MTLBuffer > patchParamsBuffer, MTLContext *context) const
│ │ │ │ + │ │ │ │ + │ │ │ │ +
static MTLLegacyGregoryPatchTable * Create(Far::PatchTable const *farPatchTable, DEVICE_CONTEXT context)
│ │ │ │ + │ │ │ │ + │ │ │ │ +
static MTLLegacyGregoryPatchTable * Create(Far::PatchTable const *farPatchTable, MTLContext *context)
│ │ │ │ +
void UpdateVertexBuffer(id< MTLBuffer > vbo, int numVertices, int numVertexElements, MTLContext *context)
│ │ │ │ + │ │ │ │ + │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -mtlComputeEvaluator.h │ │ │ │ │ +mtlLegacyGregoryPatchTable.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,1382 +24,127 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29 │ │ │ │ │ -30#include "../osd/types.h" │ │ │ │ │ -31#include "../osd/bufferDescriptor.h" │ │ │ │ │ -32#include "../osd/mtlCommon.h" │ │ │ │ │ -33 │ │ │ │ │ -34@protocol MTLDevice; │ │ │ │ │ -35@protocol MTLBuffer; │ │ │ │ │ -36@protocol MTLLibrary; │ │ │ │ │ -37@protocol MTLComputePipelineState; │ │ │ │ │ +29#include "../far/patchTable.h" │ │ │ │ │ +30#include "../osd/nonCopyable.h" │ │ │ │ │ +31#include "../osd/mtlCommon.h" │ │ │ │ │ +32 │ │ │ │ │ +33@protocol MTLDevice; │ │ │ │ │ +34@protocol MTLBuffer; │ │ │ │ │ +35 │ │ │ │ │ +36namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +37namespace OPENSUBDIV_VERSION { │ │ │ │ │ 38 │ │ │ │ │ -39namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -40namespace OPENSUBDIV_VERSION { │ │ │ │ │ -41 │ │ │ │ │ -42namespace Far { │ │ │ │ │ -43 class PatchTable; │ │ │ │ │ -44 class StencilTable; │ │ │ │ │ -45 class LimitStencilTable; │ │ │ │ │ -46} │ │ │ │ │ -47 │ │ │ │ │ -48namespace Osd { │ │ │ │ │ -49 │ │ │ │ │ -_5_0class _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -51{ │ │ │ │ │ -52public: │ │ │ │ │ -53 template │ │ │ │ │ -_5_4 static _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e* _C_r_e_a_t_e(STENCIL_TABLE* stencilTable, │ │ │ │ │ -55 DEVICE_CONTEXT context) │ │ │ │ │ -56 { │ │ │ │ │ -57 return new _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e(stencilTable, context); │ │ │ │ │ -58 } │ │ │ │ │ -59 │ │ │ │ │ +39namespace Osd { │ │ │ │ │ +40 │ │ │ │ │ +_4_1class _M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +42: private NonCopyable │ │ │ │ │ +43{ │ │ │ │ │ +44public: │ │ │ │ │ +_4_5 _~_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e(); │ │ │ │ │ +46 │ │ │ │ │ +47 template │ │ │ │ │ +_4_8 static _M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e* _C_r_e_a_t_e(_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e const* │ │ │ │ │ +farPatchTable, DEVICE_CONTEXT context) { │ │ │ │ │ +49 return Create(farPatchTable, context); │ │ │ │ │ +50 } │ │ │ │ │ +51 │ │ │ │ │ +_5_2 static _M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e* _C_r_e_a_t_e(_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e const* │ │ │ │ │ +farPatchTable, _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +53 │ │ │ │ │ +_5_4 void _U_p_d_a_t_e_V_e_r_t_e_x_B_u_f_f_e_r(id vbo, int numVertices, int │ │ │ │ │ +numVertexElements, _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +55 │ │ │ │ │ +_5_6 id _G_e_t_V_e_r_t_e_x_B_u_f_f_e_r() const │ │ │ │ │ +57 { │ │ │ │ │ +58 return _vertexBuffer; │ │ │ │ │ +59 } │ │ │ │ │ 60 │ │ │ │ │ -_6_1 _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e(_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e const* stencilTable, _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -_6_2 _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e(_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e const* stencilTable, _M_T_L_C_o_n_t_e_x_t* │ │ │ │ │ -context); │ │ │ │ │ -_6_3 _~_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e(); │ │ │ │ │ -64 │ │ │ │ │ -_6_5 id _G_e_t_S_i_z_e_s_B_u_f_f_e_r() const { return _sizesBuffer; } │ │ │ │ │ -_6_6 id _G_e_t_O_f_f_s_e_t_s_B_u_f_f_e_r() const { return _offsetsBuffer; } │ │ │ │ │ -_6_7 id _G_e_t_I_n_d_i_c_e_s_B_u_f_f_e_r() const { return _indicesBuffer; } │ │ │ │ │ -_6_8 id _G_e_t_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _weightsBuffer; } │ │ │ │ │ -_6_9 id _G_e_t_D_u_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _duWeightsBuffer; } │ │ │ │ │ -_7_0 id _G_e_t_D_v_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _dvWeightsBuffer; } │ │ │ │ │ -_7_1 id _G_e_t_D_u_u_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _duuWeightsBuffer; } │ │ │ │ │ -_7_2 id _G_e_t_D_u_v_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _duvWeightsBuffer; } │ │ │ │ │ -_7_3 id _G_e_t_D_v_v_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _dvvWeightsBuffer; } │ │ │ │ │ -74 │ │ │ │ │ -_7_5 int _G_e_t_N_u_m_S_t_e_n_c_i_l_s() const { return _numStencils; } │ │ │ │ │ -76 │ │ │ │ │ -77private: │ │ │ │ │ -78 id _sizesBuffer; │ │ │ │ │ -79 id _offsetsBuffer; │ │ │ │ │ -80 id _indicesBuffer; │ │ │ │ │ -81 id _weightsBuffer; │ │ │ │ │ -82 id _duWeightsBuffer; │ │ │ │ │ -83 id _dvWeightsBuffer; │ │ │ │ │ -84 id _duuWeightsBuffer; │ │ │ │ │ -85 id _duvWeightsBuffer; │ │ │ │ │ -86 id _dvvWeightsBuffer; │ │ │ │ │ -87 │ │ │ │ │ -88 int _numStencils; │ │ │ │ │ -89}; │ │ │ │ │ -90 │ │ │ │ │ -_9_1class _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ -92{ │ │ │ │ │ -93public: │ │ │ │ │ -_9_4 typedef bool _I_n_s_t_a_n_t_i_a_t_a_b_l_e; │ │ │ │ │ -95 │ │ │ │ │ -_9_6 static _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r * _C_r_e_a_t_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -97 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -98 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -99 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -100 _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -101 │ │ │ │ │ -_1_0_2 static _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r * _C_r_e_a_t_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -103 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -104 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -105 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -106 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -107 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -108 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -109 _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -110 │ │ │ │ │ -_1_1_1 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r(); │ │ │ │ │ -_1_1_2 _~_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r(); │ │ │ │ │ -113 │ │ │ │ │ -119 │ │ │ │ │ -148 template │ │ │ │ │ -_1_4_9 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -150 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -151 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -152 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -153 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -154 _M_T_L_C_o_n_t_e_x_t* context) │ │ │ │ │ -155 { │ │ │ │ │ -156 if (instance) { │ │ │ │ │ -157 return instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ -158 dstBuffer, dstDesc, │ │ │ │ │ -159 stencilTable, │ │ │ │ │ -160 context); │ │ │ │ │ -161 } else { │ │ │ │ │ -162 // Create an instance on demand (slow) │ │ │ │ │ -163 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -164 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -165 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -166 context); │ │ │ │ │ -167 if (instance) { │ │ │ │ │ -168 bool r = instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ -169 dstBuffer, dstDesc, │ │ │ │ │ -170 stencilTable, │ │ │ │ │ -171 context); │ │ │ │ │ -172 delete instance; │ │ │ │ │ -173 return r; │ │ │ │ │ -174 } │ │ │ │ │ -175 return false; │ │ │ │ │ -176 } │ │ │ │ │ -177 } │ │ │ │ │ -178 │ │ │ │ │ -219 template │ │ │ │ │ -_2_2_0 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -221 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -222 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -223 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -224 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -225 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -226 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -227 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ -228 │ │ │ │ │ -229 if (instance) { │ │ │ │ │ -230 return instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ -231 dstBuffer, dstDesc, │ │ │ │ │ -232 duBuffer, duDesc, │ │ │ │ │ -233 dvBuffer, dvDesc, │ │ │ │ │ -234 stencilTable, │ │ │ │ │ -235 context); │ │ │ │ │ -236 } else { │ │ │ │ │ -237 // Create an instance on demand (slow) │ │ │ │ │ -238 instance = Create(srcDesc, dstDesc, duDesc, dvDesc, context); │ │ │ │ │ -239 if (instance) { │ │ │ │ │ -240 bool r = instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ -241 dstBuffer, dstDesc, │ │ │ │ │ -242 duBuffer, duDesc, │ │ │ │ │ -243 dvBuffer, dvDesc, │ │ │ │ │ -244 stencilTable, │ │ │ │ │ -245 context); │ │ │ │ │ -246 delete instance; │ │ │ │ │ -247 return r; │ │ │ │ │ -248 } │ │ │ │ │ -249 return false; │ │ │ │ │ -250 } │ │ │ │ │ -251 } │ │ │ │ │ -252 │ │ │ │ │ -311 template │ │ │ │ │ -_3_1_2 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -313 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -314 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -315 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -316 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -317 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -318 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -319 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -320 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -321 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -322 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ -323 │ │ │ │ │ -324 if (instance) { │ │ │ │ │ -325 return instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ -326 dstBuffer, dstDesc, │ │ │ │ │ -327 duBuffer, duDesc, │ │ │ │ │ -328 dvBuffer, dvDesc, │ │ │ │ │ -329 duuBuffer, duuDesc, │ │ │ │ │ -330 duvBuffer, duvDesc, │ │ │ │ │ -331 dvvBuffer, dvvDesc, │ │ │ │ │ -332 stencilTable, │ │ │ │ │ -333 context); │ │ │ │ │ -334 } else { │ │ │ │ │ -335 // Create an instance on demand (slow) │ │ │ │ │ -336 instance = Create(srcDesc, dstDesc, duDesc, dvDesc, │ │ │ │ │ -337 duuDesc, duvDesc, dvvDesc, context); │ │ │ │ │ -338 if (instance) { │ │ │ │ │ -339 bool r = instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ -340 dstBuffer, dstDesc, │ │ │ │ │ -341 duBuffer, duDesc, │ │ │ │ │ -342 dvBuffer, dvDesc, │ │ │ │ │ -343 duuBuffer, duuDesc, │ │ │ │ │ -344 duvBuffer, duvDesc, │ │ │ │ │ -345 dvvBuffer, dvvDesc, │ │ │ │ │ -346 stencilTable, │ │ │ │ │ -347 context); │ │ │ │ │ -348 delete instance; │ │ │ │ │ -349 return r; │ │ │ │ │ -350 } │ │ │ │ │ -351 return false; │ │ │ │ │ -352 } │ │ │ │ │ -353 } │ │ │ │ │ -354 │ │ │ │ │ -375 template │ │ │ │ │ -_3_7_6 bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -377 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -378 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -379 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -380 _M_T_L_C_o_n_t_e_x_t* context) const │ │ │ │ │ -381 { │ │ │ │ │ -382 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ -383 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ -384 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -385 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -386 stencilTable->GetSizesBuffer(), │ │ │ │ │ -387 stencilTable->GetOffsetsBuffer(), │ │ │ │ │ -388 stencilTable->GetIndicesBuffer(), │ │ │ │ │ -389 stencilTable->GetWeightsBuffer(), │ │ │ │ │ -390 0, │ │ │ │ │ -391 0, │ │ │ │ │ -392 /* start = */ 0, │ │ │ │ │ -393 /* end = */ stencilTable->GetNumStencils(), │ │ │ │ │ -394 context); │ │ │ │ │ -395 } │ │ │ │ │ -396 │ │ │ │ │ -429 template │ │ │ │ │ -_4_3_0 bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -431 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -432 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -433 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -434 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -435 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -436 _M_T_L_C_o_n_t_e_x_t* context) const │ │ │ │ │ -437 { │ │ │ │ │ -438 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ -439 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ -440 duBuffer->BindMTLBuffer(context), duDesc, │ │ │ │ │ -441 dvBuffer->BindMTLBuffer(context), dvDesc, │ │ │ │ │ -442 stencilTable->GetSizesBuffer(), │ │ │ │ │ -443 stencilTable->GetOffsetsBuffer(), │ │ │ │ │ -444 stencilTable->GetIndicesBuffer(), │ │ │ │ │ -445 stencilTable->GetWeightsBuffer(), │ │ │ │ │ -446 stencilTable->GetDuWeightsBuffer(), │ │ │ │ │ -447 stencilTable->GetDvWeightsBuffer(), │ │ │ │ │ -448 /* start = */ 0, │ │ │ │ │ -449 /* end = */ stencilTable->GetNumStencils(), │ │ │ │ │ -450 context); │ │ │ │ │ -451 } │ │ │ │ │ -452 │ │ │ │ │ -503 template │ │ │ │ │ -_5_0_4 bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -505 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -506 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -507 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -508 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -509 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -510 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -511 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -512 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -513 _M_T_L_C_o_n_t_e_x_t* context) const │ │ │ │ │ -514 { │ │ │ │ │ -515 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ -516 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ -517 duBuffer->BindMTLBuffer(context), duDesc, │ │ │ │ │ -518 dvBuffer->BindMTLBuffer(context), dvDesc, │ │ │ │ │ -519 duuBuffer->BindMTLBuffer(context), duuDesc, │ │ │ │ │ -520 duvBuffer->BindMTLBuffer(context), duvDesc, │ │ │ │ │ -521 dvvBuffer->BindMTLBuffer(context), dvvDesc, │ │ │ │ │ -522 stencilTable->GetSizesBuffer(), │ │ │ │ │ -523 stencilTable->GetOffsetsBuffer(), │ │ │ │ │ -524 stencilTable->GetIndicesBuffer(), │ │ │ │ │ -525 stencilTable->GetWeightsBuffer(), │ │ │ │ │ -526 stencilTable->GetDuWeightsBuffer(), │ │ │ │ │ -527 stencilTable->GetDvWeightsBuffer(), │ │ │ │ │ -528 stencilTable->GetDuuWeightsBuffer(), │ │ │ │ │ -529 stencilTable->GetDuvWeightsBuffer(), │ │ │ │ │ -530 stencilTable->GetDvvWeightsBuffer(), │ │ │ │ │ -531 /* start = */ 0, │ │ │ │ │ -532 /* end = */ stencilTable->GetNumStencils(), │ │ │ │ │ -533 context); │ │ │ │ │ -534 } │ │ │ │ │ -535 │ │ │ │ │ -_5_7_4 bool _E_v_a_l_S_t_e_n_c_i_l_s(id srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -575 id dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -576 id duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -577 id dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -578 id sizesBuffer, │ │ │ │ │ -579 id offsetsBuffer, │ │ │ │ │ -580 id indicesBuffer, │ │ │ │ │ -581 id weightsBuffer, │ │ │ │ │ -582 id duWeightsBuffer, │ │ │ │ │ -583 id dvWeightsBuffer, │ │ │ │ │ -584 int start, │ │ │ │ │ -585 int end, │ │ │ │ │ -586 _M_T_L_C_o_n_t_e_x_t* context) const; │ │ │ │ │ -587 │ │ │ │ │ -_6_4_4 bool _E_v_a_l_S_t_e_n_c_i_l_s(id srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -645 id dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -646 id duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -647 id dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -648 id duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -649 id duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -650 id dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -651 id sizesBuffer, │ │ │ │ │ -652 id offsetsBuffer, │ │ │ │ │ -653 id indicesBuffer, │ │ │ │ │ -654 id weightsBuffer, │ │ │ │ │ -655 id duWeightsBuffer, │ │ │ │ │ -656 id dvWeightsBuffer, │ │ │ │ │ -657 id duuWeightsBuffer, │ │ │ │ │ -658 id duvWeightsBuffer, │ │ │ │ │ -659 id dvvWeightsBuffer, │ │ │ │ │ -660 int start, │ │ │ │ │ -661 int end, │ │ │ │ │ -662 _M_T_L_C_o_n_t_e_x_t* context) const; │ │ │ │ │ -663 │ │ │ │ │ -669 │ │ │ │ │ -703 template │ │ │ │ │ -_7_0_5 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -706 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -707 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -708 int numPatchCoords, │ │ │ │ │ -709 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -710 PATCH_TABLE *patchTable, │ │ │ │ │ -711 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -712 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ -713 │ │ │ │ │ -714 if (instance) { │ │ │ │ │ -715 return instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ -716 dstBuffer, dstDesc, │ │ │ │ │ -717 numPatchCoords, patchCoords, │ │ │ │ │ -718 patchTable, │ │ │ │ │ -719 context); │ │ │ │ │ -720 } else { │ │ │ │ │ -721 // Create an instance on demand (slow) │ │ │ │ │ -722 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -723 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -724 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -725 context); │ │ │ │ │ -726 if (instance) { │ │ │ │ │ -727 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ -728 dstBuffer, dstDesc, │ │ │ │ │ -729 numPatchCoords, patchCoords, │ │ │ │ │ -730 patchTable, │ │ │ │ │ -731 context); │ │ │ │ │ -732 delete instance; │ │ │ │ │ -733 return r; │ │ │ │ │ -734 } │ │ │ │ │ -735 return false; │ │ │ │ │ -736 } │ │ │ │ │ -737 } │ │ │ │ │ -738 │ │ │ │ │ -784 template │ │ │ │ │ -_7_8_6 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -787 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -788 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -789 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -790 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -791 int numPatchCoords, │ │ │ │ │ -792 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -793 PATCH_TABLE *patchTable, │ │ │ │ │ -794 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r* instance, │ │ │ │ │ -795 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ -796 │ │ │ │ │ -797 if (instance) { │ │ │ │ │ -798 return instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ -799 dstBuffer, dstDesc, │ │ │ │ │ -800 duBuffer, duDesc, │ │ │ │ │ -801 dvBuffer, dvDesc, │ │ │ │ │ -802 numPatchCoords, patchCoords, │ │ │ │ │ -803 patchTable, │ │ │ │ │ -804 context); │ │ │ │ │ -805 } else { │ │ │ │ │ -806 // Create an instance on demand (slow) │ │ │ │ │ -807 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -808 duDesc, dvDesc, context); │ │ │ │ │ -809 if (instance) { │ │ │ │ │ -810 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ -811 dstBuffer, dstDesc, │ │ │ │ │ -812 duBuffer, duDesc, │ │ │ │ │ -813 dvBuffer, dvDesc, │ │ │ │ │ -814 numPatchCoords, patchCoords, │ │ │ │ │ -815 patchTable, │ │ │ │ │ -816 context); │ │ │ │ │ -817 delete instance; │ │ │ │ │ -818 return r; │ │ │ │ │ -819 } │ │ │ │ │ -820 return false; │ │ │ │ │ -821 } │ │ │ │ │ -822 } │ │ │ │ │ -823 │ │ │ │ │ -887 template │ │ │ │ │ -_8_8_9 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -890 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -891 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -892 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -893 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -894 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -895 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -896 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -897 int numPatchCoords, │ │ │ │ │ -898 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -899 PATCH_TABLE *patchTable, │ │ │ │ │ -900 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r* instance, │ │ │ │ │ -901 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ -902 │ │ │ │ │ -903 if (instance) { │ │ │ │ │ -904 return instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ -905 dstBuffer, dstDesc, │ │ │ │ │ -906 duBuffer, duDesc, │ │ │ │ │ -907 dvBuffer, dvDesc, │ │ │ │ │ -908 duuBuffer, duuDesc, │ │ │ │ │ -909 duvBuffer, duvDesc, │ │ │ │ │ -910 dvvBuffer, dvvDesc, │ │ │ │ │ -911 numPatchCoords, patchCoords, │ │ │ │ │ -912 patchTable, │ │ │ │ │ -913 context); │ │ │ │ │ -914 } else { │ │ │ │ │ -915 // Create an instance on demand (slow) │ │ │ │ │ -916 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -917 duDesc, dvDesc, │ │ │ │ │ -918 duuDesc, duvDesc, dvvDesc, context); │ │ │ │ │ -919 if (instance) { │ │ │ │ │ -920 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ -921 dstBuffer, dstDesc, │ │ │ │ │ -922 duBuffer, duDesc, │ │ │ │ │ -923 dvBuffer, dvDesc, │ │ │ │ │ -924 duuBuffer, duuDesc, │ │ │ │ │ -925 duvBuffer, duvDesc, │ │ │ │ │ -926 dvvBuffer, dvvDesc, │ │ │ │ │ -927 numPatchCoords, patchCoords, │ │ │ │ │ -928 patchTable, │ │ │ │ │ -929 context); │ │ │ │ │ -930 delete instance; │ │ │ │ │ -931 return r; │ │ │ │ │ -932 } │ │ │ │ │ -933 return false; │ │ │ │ │ -934 } │ │ │ │ │ -935 } │ │ │ │ │ -936 │ │ │ │ │ -964 template │ │ │ │ │ -_9_6_6 bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -967 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -968 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -969 int numPatchCoords, │ │ │ │ │ -970 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -971 PATCH_TABLE *patchTable, │ │ │ │ │ -972 _M_T_L_C_o_n_t_e_x_t* context) const { │ │ │ │ │ -973 │ │ │ │ │ -974 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ -975 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ -976 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -977 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -978 numPatchCoords, │ │ │ │ │ -979 patchCoords->BindMTLBuffer(context), │ │ │ │ │ -980 patchTable->GetPatchArrays(), │ │ │ │ │ -981 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -982 patchTable->GetPatchParamBuffer(), │ │ │ │ │ -983 context); │ │ │ │ │ -984 } │ │ │ │ │ -985 │ │ │ │ │ -1023 template │ │ │ │ │ -_1_0_2_5 bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -1026 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1027 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1028 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1029 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1030 int numPatchCoords, │ │ │ │ │ -1031 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1032 PATCH_TABLE *patchTable, │ │ │ │ │ -1033 _M_T_L_C_o_n_t_e_x_t* context) const { │ │ │ │ │ -1034 │ │ │ │ │ -1035 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ -1036 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ -1037 duBuffer->BindMTLBuffer(context), duDesc, │ │ │ │ │ -1038 dvBuffer->BindMTLBuffer(context), dvDesc, │ │ │ │ │ -1039 numPatchCoords, │ │ │ │ │ -1040 patchCoords->BindMTLBuffer(context), │ │ │ │ │ -1041 patchTable->GetPatchArrays(), │ │ │ │ │ -1042 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -1043 patchTable->GetPatchParamBuffer(), │ │ │ │ │ -1044 context); │ │ │ │ │ -1045 } │ │ │ │ │ -1046 │ │ │ │ │ -1102 template │ │ │ │ │ -_1_1_0_4 bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -1105 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1106 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1107 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1108 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1109 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -1110 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -1111 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -1112 int numPatchCoords, │ │ │ │ │ -1113 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1114 PATCH_TABLE *patchTable, │ │ │ │ │ -1115 _M_T_L_C_o_n_t_e_x_t* context) const { │ │ │ │ │ -1116 │ │ │ │ │ -1117 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ -1118 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ -1119 duBuffer->BindMTLBuffer(context), duDesc, │ │ │ │ │ -1120 dvBuffer->BindMTLBuffer(context), dvDesc, │ │ │ │ │ -1121 duuBuffer->BindMTLBuffer(context), duuDesc, │ │ │ │ │ -1122 duvBuffer->BindMTLBuffer(context), duvDesc, │ │ │ │ │ -1123 dvvBuffer->BindMTLBuffer(context), dvvDesc, │ │ │ │ │ -1124 numPatchCoords, │ │ │ │ │ -1125 patchCoords->BindMTLBuffer(context), │ │ │ │ │ -1126 patchTable->GetPatchArrays(), │ │ │ │ │ -1127 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -1128 patchTable->GetPatchParamBuffer(), │ │ │ │ │ -1129 context); │ │ │ │ │ -1130 } │ │ │ │ │ -1131 │ │ │ │ │ -_1_1_3_2 bool _E_v_a_l_P_a_t_c_h_e_s(id srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1133 id dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1134 id duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1135 id dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1136 int numPatchCoords, │ │ │ │ │ -1137 id patchCoordsBuffer, │ │ │ │ │ -1138 const _P_a_t_c_h_A_r_r_a_y_V_e_c_t_o_r &patchArrays, │ │ │ │ │ -1139 id patchIndexBuffer, │ │ │ │ │ -1140 id patchParamsBuffer, │ │ │ │ │ -1141 _M_T_L_C_o_n_t_e_x_t* context) const; │ │ │ │ │ -1142 │ │ │ │ │ -_1_1_4_3 bool _E_v_a_l_P_a_t_c_h_e_s(id srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1144 id dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1145 id duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1146 id dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1147 id duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -1148 id duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -1149 id dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -1150 int numPatchCoords, │ │ │ │ │ -1151 id patchCoordsBuffer, │ │ │ │ │ -1152 const _P_a_t_c_h_A_r_r_a_y_V_e_c_t_o_r &patchArrays, │ │ │ │ │ -1153 id patchIndexBuffer, │ │ │ │ │ -1154 id patchParamsBuffer, │ │ │ │ │ -1155 _M_T_L_C_o_n_t_e_x_t* context) const; │ │ │ │ │ -1156 │ │ │ │ │ -1190 template │ │ │ │ │ -_1_1_9_2 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1193 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1194 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1195 int numPatchCoords, │ │ │ │ │ -1196 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1197 PATCH_TABLE *patchTable, │ │ │ │ │ -1198 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -1199 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ -1200 │ │ │ │ │ -1201 if (instance) { │ │ │ │ │ -1202 return instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1203 srcBuffer, srcDesc, │ │ │ │ │ -1204 dstBuffer, dstDesc, │ │ │ │ │ -1205 numPatchCoords, patchCoords, │ │ │ │ │ -1206 patchTable, │ │ │ │ │ -1207 deviceContext); │ │ │ │ │ -1208 } else { │ │ │ │ │ -1209 // Create an instance on demand (slow) │ │ │ │ │ -1210 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -1211 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -1212 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -1213 deviceContext); │ │ │ │ │ -1214 if (instance) { │ │ │ │ │ -1215 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1216 srcBuffer, srcDesc, │ │ │ │ │ -1217 dstBuffer, dstDesc, │ │ │ │ │ -1218 numPatchCoords, patchCoords, │ │ │ │ │ -1219 patchTable, │ │ │ │ │ -1220 deviceContext); │ │ │ │ │ -1221 delete instance; │ │ │ │ │ -1222 return r; │ │ │ │ │ -1223 } │ │ │ │ │ -1224 return false; │ │ │ │ │ -1225 } │ │ │ │ │ -1226 } │ │ │ │ │ -1227 │ │ │ │ │ -1255 template │ │ │ │ │ -_1_2_5_7 bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1258 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1259 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1260 int numPatchCoords, │ │ │ │ │ -1261 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1262 PATCH_TABLE *patchTable, │ │ │ │ │ -1263 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ -1264 │ │ │ │ │ -1265 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ -1266 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ -1267 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -1268 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -1269 numPatchCoords, │ │ │ │ │ -1270 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ -1271 patchTable->GetVaryingPatchArrays(), │ │ │ │ │ -1272 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -1273 patchTable->GetPatchParamBuffer(), │ │ │ │ │ -1274 deviceContext │ │ │ │ │ -1275 ); │ │ │ │ │ -1276 } │ │ │ │ │ -1277 │ │ │ │ │ -1323 template │ │ │ │ │ -_1_3_2_5 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1326 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1327 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1328 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1329 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1330 int numPatchCoords, │ │ │ │ │ -1331 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1332 PATCH_TABLE *patchTable, │ │ │ │ │ -1333 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -1334 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ -1335 │ │ │ │ │ -1336 if (instance) { │ │ │ │ │ -1337 return instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1338 srcBuffer, srcDesc, │ │ │ │ │ -1339 dstBuffer, dstDesc, │ │ │ │ │ -1340 duBuffer, duDesc, │ │ │ │ │ -1341 dvBuffer, dvDesc, │ │ │ │ │ -1342 numPatchCoords, patchCoords, │ │ │ │ │ -1343 patchTable, │ │ │ │ │ -1344 deviceContext); │ │ │ │ │ -1345 } else { │ │ │ │ │ -1346 // Create an instance on demand (slow) │ │ │ │ │ -1347 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -1348 duDesc, dvDesc, │ │ │ │ │ -1349 deviceContext); │ │ │ │ │ -1350 if (instance) { │ │ │ │ │ -1351 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1352 srcBuffer, srcDesc, │ │ │ │ │ -1353 dstBuffer, dstDesc, │ │ │ │ │ -1354 duBuffer, duDesc, │ │ │ │ │ -1355 dvBuffer, dvDesc, │ │ │ │ │ -1356 numPatchCoords, patchCoords, │ │ │ │ │ -1357 patchTable, │ │ │ │ │ -1358 deviceContext); │ │ │ │ │ -1359 delete instance; │ │ │ │ │ -1360 return r; │ │ │ │ │ -1361 } │ │ │ │ │ -1362 return false; │ │ │ │ │ -1363 } │ │ │ │ │ -1364 } │ │ │ │ │ -1365 │ │ │ │ │ -1405 template │ │ │ │ │ -_1_4_0_7 bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1408 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1409 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1410 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1411 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1412 int numPatchCoords, │ │ │ │ │ -1413 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1414 PATCH_TABLE *patchTable, │ │ │ │ │ -1415 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ -1416 │ │ │ │ │ -1417 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ -1418 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ -1419 duBuffer->BindMTLBuffer(deviceContext), duDesc, │ │ │ │ │ -1420 dvBuffer->BindMTLBuffer(deviceContext), dvDesc, │ │ │ │ │ -1421 numPatchCoords, │ │ │ │ │ -1422 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ -1423 patchTable->GetVaryingPatchArrays(), │ │ │ │ │ -1424 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -1425 patchTable->GetPatchParamBuffer(), │ │ │ │ │ -1426 deviceContext │ │ │ │ │ -1427 ); │ │ │ │ │ -1428 } │ │ │ │ │ -1429 │ │ │ │ │ -1430 │ │ │ │ │ -1494 template │ │ │ │ │ -_1_4_9_6 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1497 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1498 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1499 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1500 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1501 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -1502 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -1503 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -1504 int numPatchCoords, │ │ │ │ │ -1505 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1506 PATCH_TABLE *patchTable, │ │ │ │ │ -1507 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -1508 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ -1509 │ │ │ │ │ -1510 if (instance) { │ │ │ │ │ -1511 return instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1512 srcBuffer, srcDesc, │ │ │ │ │ -1513 dstBuffer, dstDesc, │ │ │ │ │ -1514 duBuffer, duDesc, │ │ │ │ │ -1515 dvBuffer, dvDesc, │ │ │ │ │ -1516 duuBuffer, duuDesc, │ │ │ │ │ -1517 duvBuffer, duvDesc, │ │ │ │ │ -1518 dvvBuffer, dvvDesc, │ │ │ │ │ -1519 numPatchCoords, patchCoords, │ │ │ │ │ -1520 patchTable, │ │ │ │ │ -1521 deviceContext); │ │ │ │ │ -1522 } else { │ │ │ │ │ -1523 // Create an instance on demand (slow) │ │ │ │ │ -1524 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -1525 duDesc, dvDesc, │ │ │ │ │ -1526 duuDesc, duvDesc, dvvDesc, │ │ │ │ │ -1527 deviceContext); │ │ │ │ │ -1528 if (instance) { │ │ │ │ │ -1529 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1530 srcBuffer, srcDesc, │ │ │ │ │ -1531 dstBuffer, dstDesc, │ │ │ │ │ -1532 duBuffer, duDesc, │ │ │ │ │ -1533 dvBuffer, dvDesc, │ │ │ │ │ -1534 duuBuffer, duuDesc, │ │ │ │ │ -1535 duvBuffer, duvDesc, │ │ │ │ │ -1536 dvvBuffer, dvvDesc, │ │ │ │ │ -1537 numPatchCoords, patchCoords, │ │ │ │ │ -1538 patchTable, │ │ │ │ │ -1539 deviceContext); │ │ │ │ │ -1540 delete instance; │ │ │ │ │ -1541 return r; │ │ │ │ │ -1542 } │ │ │ │ │ -1543 return false; │ │ │ │ │ -1544 } │ │ │ │ │ -1545 } │ │ │ │ │ -1546 │ │ │ │ │ -1604 template │ │ │ │ │ -_1_6_0_6 bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -1607 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1608 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1609 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1610 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1611 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -1612 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -1613 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -1614 int numPatchCoords, │ │ │ │ │ -1615 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1616 PATCH_TABLE *patchTable, │ │ │ │ │ -1617 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ -1618 │ │ │ │ │ -1619 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ -1620 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ -1621 duBuffer->BindMTLBuffer(deviceContext), duDesc, │ │ │ │ │ -1622 dvBuffer->BindMTLBuffer(deviceContext), dvDesc, │ │ │ │ │ -1623 duuBuffer->BindMTLBuffer(deviceContext), duuDesc, │ │ │ │ │ -1624 duvBuffer->BindMTLBuffer(deviceContext), duvDesc, │ │ │ │ │ -1625 dvvBuffer->BindMTLBuffer(deviceContext), dvvDesc, │ │ │ │ │ -1626 numPatchCoords, │ │ │ │ │ -1627 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ -1628 patchTable->GetVaryingPatchArrays(), │ │ │ │ │ -1629 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -1630 patchTable->GetPatchParamBuffer(), │ │ │ │ │ -1631 deviceContext │ │ │ │ │ -1632 ); │ │ │ │ │ -1633 } │ │ │ │ │ -1634 │ │ │ │ │ -1670 template │ │ │ │ │ -_1_6_7_2 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1673 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1674 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1675 int numPatchCoords, │ │ │ │ │ -1676 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1677 PATCH_TABLE *patchTable, │ │ │ │ │ -1678 int fvarChannel, │ │ │ │ │ -1679 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -1680 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ -1681 │ │ │ │ │ -1682 if (instance) { │ │ │ │ │ -1683 return instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1684 srcBuffer, srcDesc, │ │ │ │ │ -1685 dstBuffer, dstDesc, │ │ │ │ │ -1686 numPatchCoords, patchCoords, │ │ │ │ │ -1687 patchTable, │ │ │ │ │ -1688 fvarChannel, │ │ │ │ │ -1689 deviceContext); │ │ │ │ │ -1690 } else { │ │ │ │ │ -1691 // Create an instance on demand (slow) │ │ │ │ │ -1692 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -1693 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -1694 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -1695 deviceContext); │ │ │ │ │ -1696 if (instance) { │ │ │ │ │ -1697 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1698 srcBuffer, srcDesc, │ │ │ │ │ -1699 dstBuffer, dstDesc, │ │ │ │ │ -1700 numPatchCoords, patchCoords, │ │ │ │ │ -1701 patchTable, │ │ │ │ │ -1702 fvarChannel, │ │ │ │ │ -1703 deviceContext); │ │ │ │ │ -1704 delete instance; │ │ │ │ │ -1705 return r; │ │ │ │ │ -1706 } │ │ │ │ │ -1707 return false; │ │ │ │ │ -1708 } │ │ │ │ │ -1709 } │ │ │ │ │ -1710 │ │ │ │ │ -1740 template │ │ │ │ │ -_1_7_4_2 bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1743 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1744 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1745 int numPatchCoords, │ │ │ │ │ -1746 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1747 PATCH_TABLE *patchTable, │ │ │ │ │ -1748 int fvarChannel, │ │ │ │ │ -1749 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ -1750 │ │ │ │ │ -1751 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ -1752 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ -1753 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -1754 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -1755 numPatchCoords, │ │ │ │ │ -1756 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ -1757 patchTable->GetFVarPatchArrays(fvarChannel), │ │ │ │ │ -1758 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -1759 patchTable->GetFVarPatchParamBuffer(fvarChannel), │ │ │ │ │ -1760 deviceContext │ │ │ │ │ -1761 ); │ │ │ │ │ -1762 } │ │ │ │ │ -1763 │ │ │ │ │ -1811 template │ │ │ │ │ -_1_8_1_3 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1814 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1815 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1816 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1817 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1818 int numPatchCoords, │ │ │ │ │ -1819 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1820 PATCH_TABLE *patchTable, │ │ │ │ │ -1821 int fvarChannel, │ │ │ │ │ -1822 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -1823 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ -1824 │ │ │ │ │ -1825 if (instance) { │ │ │ │ │ -1826 return instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1827 srcBuffer, srcDesc, │ │ │ │ │ -1828 dstBuffer, dstDesc, │ │ │ │ │ -1829 duBuffer, duDesc, │ │ │ │ │ -1830 dvBuffer, dvDesc, │ │ │ │ │ -1831 numPatchCoords, patchCoords, │ │ │ │ │ -1832 patchTable, │ │ │ │ │ -1833 fvarChannel, │ │ │ │ │ -1834 deviceContext); │ │ │ │ │ -1835 } else { │ │ │ │ │ -1836 // Create an instance on demand (slow) │ │ │ │ │ -1837 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -1838 duDesc, dvDesc, │ │ │ │ │ -1839 deviceContext); │ │ │ │ │ -1840 if (instance) { │ │ │ │ │ -1841 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1842 srcBuffer, srcDesc, │ │ │ │ │ -1843 dstBuffer, dstDesc, │ │ │ │ │ -1844 duBuffer, duDesc, │ │ │ │ │ -1845 dvBuffer, dvDesc, │ │ │ │ │ -1846 numPatchCoords, patchCoords, │ │ │ │ │ -1847 patchTable, │ │ │ │ │ -1848 fvarChannel, │ │ │ │ │ -1849 deviceContext); │ │ │ │ │ -1850 delete instance; │ │ │ │ │ -1851 return r; │ │ │ │ │ -1852 } │ │ │ │ │ -1853 return false; │ │ │ │ │ -1854 } │ │ │ │ │ -1855 } │ │ │ │ │ -1856 │ │ │ │ │ -1898 template │ │ │ │ │ -_1_9_0_0 bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1901 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1902 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1903 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1904 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1905 int numPatchCoords, │ │ │ │ │ -1906 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1907 PATCH_TABLE *patchTable, │ │ │ │ │ -1908 int fvarChannel, │ │ │ │ │ -1909 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ -1910 │ │ │ │ │ -1911 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ -1912 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ -1913 duBuffer->BindMTLBuffer(deviceContext), duDesc, │ │ │ │ │ -1914 dvBuffer->BindMTLBuffer(deviceContext), dvDesc, │ │ │ │ │ -1915 numPatchCoords, │ │ │ │ │ -1916 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ -1917 patchTable->GetFVarPatchArrays(fvarChannel), │ │ │ │ │ -1918 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -1919 patchTable->GetFVarPatchParamBuffer(fvarChannel), │ │ │ │ │ -1920 deviceContext │ │ │ │ │ -1921 ); │ │ │ │ │ -1922 } │ │ │ │ │ -1923 │ │ │ │ │ -1989 template │ │ │ │ │ -_1_9_9_1 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1992 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1993 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1994 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1995 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1996 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -1997 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -1998 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -1999 int numPatchCoords, │ │ │ │ │ -2000 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -2001 PATCH_TABLE *patchTable, │ │ │ │ │ -2002 int fvarChannel, │ │ │ │ │ -2003 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -2004 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ -2005 │ │ │ │ │ -2006 if (instance) { │ │ │ │ │ -2007 return instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -2008 srcBuffer, srcDesc, │ │ │ │ │ -2009 dstBuffer, dstDesc, │ │ │ │ │ -2010 duBuffer, duDesc, │ │ │ │ │ -2011 dvBuffer, dvDesc, │ │ │ │ │ -2012 duuBuffer, duuDesc, │ │ │ │ │ -2013 duvBuffer, duvDesc, │ │ │ │ │ -2014 dvvBuffer, dvvDesc, │ │ │ │ │ -2015 numPatchCoords, patchCoords, │ │ │ │ │ -2016 patchTable, │ │ │ │ │ -2017 fvarChannel, │ │ │ │ │ -2018 deviceContext); │ │ │ │ │ -2019 } else { │ │ │ │ │ -2020 // Create an instance on demand (slow) │ │ │ │ │ -2021 instance = Create(srcDesc, dstDesc, │ │ │ │ │ -2022 duDesc, dvDesc, │ │ │ │ │ -2023 duuDesc, duvDesc, dvvDesc, │ │ │ │ │ -2024 deviceContext); │ │ │ │ │ -2025 if (instance) { │ │ │ │ │ -2026 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -2027 srcBuffer, srcDesc, │ │ │ │ │ -2028 dstBuffer, dstDesc, │ │ │ │ │ -2029 duBuffer, duDesc, │ │ │ │ │ -2030 dvBuffer, dvDesc, │ │ │ │ │ -2031 duuBuffer, duuDesc, │ │ │ │ │ -2032 duvBuffer, duvDesc, │ │ │ │ │ -2033 dvvBuffer, dvvDesc, │ │ │ │ │ -2034 numPatchCoords, patchCoords, │ │ │ │ │ -2035 patchTable, │ │ │ │ │ -2036 fvarChannel, │ │ │ │ │ -2037 deviceContext); │ │ │ │ │ -2038 delete instance; │ │ │ │ │ -2039 return r; │ │ │ │ │ -2040 } │ │ │ │ │ -2041 return false; │ │ │ │ │ -2042 } │ │ │ │ │ -2043 } │ │ │ │ │ -2044 │ │ │ │ │ -2104 template │ │ │ │ │ -_2_1_0_6 bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -2107 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -2108 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -2109 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -2110 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -2111 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -2112 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -2113 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -2114 int numPatchCoords, │ │ │ │ │ -2115 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -2116 PATCH_TABLE *patchTable, │ │ │ │ │ -2117 int fvarChannel, │ │ │ │ │ -2118 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ -2119 │ │ │ │ │ -2120 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ -2121 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ -2122 duBuffer->BindMTLBuffer(deviceContext), duDesc, │ │ │ │ │ -2123 dvBuffer->BindMTLBuffer(deviceContext), dvDesc, │ │ │ │ │ -2124 duuBuffer->BindMTLBuffer(deviceContext), duuDesc, │ │ │ │ │ -2125 duvBuffer->BindMTLBuffer(deviceContext), duvDesc, │ │ │ │ │ -2126 dvvBuffer->BindMTLBuffer(deviceContext), dvvDesc, │ │ │ │ │ -2127 numPatchCoords, │ │ │ │ │ -2128 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ -2129 patchTable->GetFVarPatchArrays(fvarChannel), │ │ │ │ │ -2130 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -2131 patchTable->GetFVarPatchParamBuffer(fvarChannel), │ │ │ │ │ -2132 fvarChannel, │ │ │ │ │ -2133 deviceContext │ │ │ │ │ -2134 ); │ │ │ │ │ -2135 } │ │ │ │ │ -2136 │ │ │ │ │ -_2_1_3_8 bool _C_o_m_p_i_l_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -2139 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -2140 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -2141 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -2142 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -2143 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -2144 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -2145 _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -2146 │ │ │ │ │ -_2_1_4_8 static void _S_y_n_c_h_r_o_n_i_z_e(_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -2149 │ │ │ │ │ -2150 private: │ │ │ │ │ -2151 │ │ │ │ │ -2152 id _computeLibrary; │ │ │ │ │ -2153 id _evalStencils; │ │ │ │ │ -2154 id _evalPatches; │ │ │ │ │ -2155 id _parameterBuffer; │ │ │ │ │ -2156 │ │ │ │ │ -2157 int _workGroupSize; │ │ │ │ │ -2158}; │ │ │ │ │ -2159 │ │ │ │ │ -2160} //end namespace Osd │ │ │ │ │ -2161 │ │ │ │ │ -2162} //end namespace OPENSUBDIV_VERSION │ │ │ │ │ -2163using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -2164 │ │ │ │ │ -2165} //end namespace OpenSubdiv │ │ │ │ │ -2166 │ │ │ │ │ -2167#endif // OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H │ │ │ │ │ +_6_1 id _G_e_t_V_e_r_t_e_x_V_a_l_e_n_c_e_B_u_f_f_e_r() const │ │ │ │ │ +62 { │ │ │ │ │ +63 return _vertexValenceBuffer; │ │ │ │ │ +64 } │ │ │ │ │ +65 │ │ │ │ │ +_6_6 id _G_e_t_Q_u_a_d_O_f_f_s_e_t_s_B_u_f_f_e_r() const │ │ │ │ │ +67 { │ │ │ │ │ +68 return _quadOffsetsBuffer; │ │ │ │ │ +69 } │ │ │ │ │ +70 │ │ │ │ │ +_7_1 int _G_e_t_Q_u_a_d_O_f_f_s_e_t_s_B_a_s_e(_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e type) │ │ │ │ │ +72 { │ │ │ │ │ +73 if(type == _F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_G_R_E_G_O_R_Y___B_O_U_N_D_A_R_Y) │ │ │ │ │ +74 return _quadOffsetsBase[1]; │ │ │ │ │ +75 return _quadOffsetsBase[0]; │ │ │ │ │ +76 } │ │ │ │ │ +77 │ │ │ │ │ +78private: │ │ │ │ │ +79 id _vertexBuffer; │ │ │ │ │ +80 id _vertexValenceBuffer; │ │ │ │ │ +81 id _quadOffsetsBuffer; │ │ │ │ │ +82 int _quadOffsetsBase[2]; │ │ │ │ │ +83}; │ │ │ │ │ +84 │ │ │ │ │ +85} //end namespace Osd │ │ │ │ │ +86 │ │ │ │ │ +87} //end namespace OPENSUBDIV_VERSION │ │ │ │ │ +88using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +89 │ │ │ │ │ +90} //end namespace OpenSuddiv │ │ │ │ │ +91 │ │ │ │ │ +92#endif // OPENSUBDIV3_OSD_MTL_LEGACY_GREGORY_PATCH_TABLE_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_A_r_r_a_y_V_e_c_t_o_r │ │ │ │ │ -std::vector< PatchArray > PatchArrayVector │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_1_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -Stencil table class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -Limit stencil table class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ -data buffers.... │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_T_y_p_e │ │ │ │ │ +Type │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h_:_4_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_D_e_s_c_r_i_p_t_o_r_:_:_G_R_E_G_O_R_Y___B_O_U_N_D_A_R_Y │ │ │ │ │ +@ GREGORY_BOUNDARY │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +Container for arrays of parametric patches. │ │ │ │ │ +DDeeffiinniittiioonn _p_a_t_c_h_T_a_b_l_e_._h_:_5_5 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_n_t_e_x_t │ │ │ │ │ DDeeffiinniittiioonn _m_t_l_C_o_m_m_o_n_._h_:_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -MTLStencilTable(Far::LimitStencilTable const *stencilTable, MTLContext │ │ │ │ │ -*context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_u_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetDuWeightsBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_~_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -~MTLStencilTable() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_v_v_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetDvvWeightsBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -MTLStencilTable(Far::StencilTable const *stencilTable, MTLContext *context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_u_u_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetDuuWeightsBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_u_v_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetDuvWeightsBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_N_u_m_S_t_e_n_c_i_l_s │ │ │ │ │ -int GetNumStencils() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_I_n_d_i_c_e_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetIndicesBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_S_i_z_e_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetSizesBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_O_f_f_s_e_t_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetOffsetsBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetWeightsBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ -static MTLStencilTable * Create(STENCIL_TABLE *stencilTable, DEVICE_CONTEXT │ │ │ │ │ -context) │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_v_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > GetDvWeightsBuffer() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -bool EvalStencils(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > │ │ │ │ │ -duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, id< MTLBuffer > duuBuffer, BufferDescriptor │ │ │ │ │ -const &duuDesc, id< MTLBuffer > duvBuffer, BufferDescriptor const &duvDesc, id< │ │ │ │ │ -MTLBuffer > dvvBuffer, BufferDescriptor const &dvvDesc, id< MTLBuffer > │ │ │ │ │ -sizesBuffer, id< MTLBuffer > offsetsBuffer, id< MTLBuffer > indicesBuffer, id< │ │ │ │ │ -MTLBuffer > weightsBuffer, id< MTLBuffer > duWeightsBuffer, id< MTLBuffer > │ │ │ │ │ -dvWeightsBuffer, id< MTLBuffer > duuWeightsBuffer, id< MTLBuffer > │ │ │ │ │ -duvWeightsBuffer, id< MTLBuffer > dvvWeightsBuffer, int start, int end, │ │ │ │ │ -MTLContext *context) const │ │ │ │ │ -Dispatch the MTL compute kernel on GPU asynchronously returns false if the │ │ │ │ │ -kernel hasn't been compile... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ -*patchTable, MTLComputeEvaluator *instance, MTLContext *context) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, │ │ │ │ │ -MTLComputeEvaluator const *instance, MTLContext *context) │ │ │ │ │ -Generic static stencil function. This function has a same signature as other │ │ │ │ │ -device kernels have so t... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_3_1_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ -_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ -DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, │ │ │ │ │ -MTLComputeEvaluator const *instance, MTLContext *deviceContext) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_9_9_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ -MTLComputeEvaluator() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_~_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ -~MTLComputeEvaluator() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator │ │ │ │ │ -const *instance, MTLContext *context) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_0_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_I_n_s_t_a_n_t_i_a_t_a_b_l_e │ │ │ │ │ -bool Instantiatable │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ -*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ -BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, MTLContext *deviceContext) const │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_6_0_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, │ │ │ │ │ -MTLComputeEvaluator const *instance, MTLContext *context) │ │ │ │ │ -Generic static stencil function. This function has a same signature as other │ │ │ │ │ -device kernels have so t... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_2_2_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ -_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLContext │ │ │ │ │ -*deviceContext) const │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_9_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ -_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ -numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int │ │ │ │ │ -fvarChannel, MTLComputeEvaluator const *instance, MTLContext *deviceContext) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_6_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator │ │ │ │ │ -const *instance, MTLContext *deviceContext) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_4_9_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const │ │ │ │ │ -*stencilTable, MTLContext *context) const │ │ │ │ │ -Generic stencil function. │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_3_7_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -bool EvalPatches(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > │ │ │ │ │ -duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, id< MTLBuffer > duuBuffer, BufferDescriptor │ │ │ │ │ -const &duuDesc, id< MTLBuffer > duvBuffer, BufferDescriptor const &duvDesc, id< │ │ │ │ │ -MTLBuffer > dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, id< │ │ │ │ │ -MTLBuffer > patchCoordsBuffer, const PatchArrayVector &patchArrays, id< │ │ │ │ │ -MTLBuffer > patchIndexBuffer, id< MTLBuffer > patchParamsBuffer, MTLContext │ │ │ │ │ -*context) const │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ -_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, │ │ │ │ │ -MTLContext *deviceContext) const │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_2_1_0_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_S_y_n_c_h_r_o_n_i_z_e │ │ │ │ │ -static void Synchronize(MTLContext *context) │ │ │ │ │ -Wait for the dispatched kernel to finish. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, STENCIL_TABLE const *stencilTable, MTLContext *context) const │ │ │ │ │ -Generic stencil function. │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_4_3_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ -*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ -BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator *instance, │ │ │ │ │ -MTLContext *context) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_8_8_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ -_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ -numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int │ │ │ │ │ -fvarChannel, MTLContext *deviceContext) const │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_7_4_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ -numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, │ │ │ │ │ -MTLComputeEvaluator const *instance, MTLContext *deviceContext) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_1_9_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ -*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ -BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, MTLContext │ │ │ │ │ -*context) const │ │ │ │ │ -Generic stencil function. │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_0_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -bool EvalStencils(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > │ │ │ │ │ -duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, id< MTLBuffer > sizesBuffer, id< MTLBuffer > │ │ │ │ │ -offsetsBuffer, id< MTLBuffer > indicesBuffer, id< MTLBuffer > weightsBuffer, │ │ │ │ │ -id< MTLBuffer > duWeightsBuffer, id< MTLBuffer > dvWeightsBuffer, int start, │ │ │ │ │ -int end, MTLContext *context) const │ │ │ │ │ -Dispatch the MTL compute kernel on GPU asynchronously returns false if the │ │ │ │ │ -kernel hasn't been compile... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ -_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ -DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLComputeEvaluator │ │ │ │ │ -const *instance, MTLContext *deviceContext) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_8_1_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *context) │ │ │ │ │ -const │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE │ │ │ │ │ -const *stencilTable, MTLComputeEvaluator const *instance, MTLContext *context) │ │ │ │ │ -Generic static stencil function. This function has a same signature as other │ │ │ │ │ -device kernels have so t... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_4_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, │ │ │ │ │ -MTLContext *deviceContext) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_3_2_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ -*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ -BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, MTLContext *context) const │ │ │ │ │ -Generic limit eval function with derivatives. This function has a same │ │ │ │ │ -signature as other device kern... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_1_0_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ -*patchTable, MTLContext *context) const │ │ │ │ │ -Generic limit eval function with derivatives. This function has a same │ │ │ │ │ -signature as other device kern... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_0_2_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ -*patchTable, MTLContext *deviceContext) const │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_4_0_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext │ │ │ │ │ -*deviceContext) const │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_2_5_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_r_e_a_t_e │ │ │ │ │ -static MTLComputeEvaluator * Create(BufferDescriptor const &srcDesc, │ │ │ │ │ -BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, │ │ │ │ │ -BufferDescriptor const &dvDesc, MTLContext *context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_r_e_a_t_e │ │ │ │ │ -static MTLComputeEvaluator * Create(BufferDescriptor const &srcDesc, │ │ │ │ │ -BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, │ │ │ │ │ -BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, │ │ │ │ │ -BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, MTLContext │ │ │ │ │ -*context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_o_m_p_i_l_e │ │ │ │ │ -bool Compile(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, │ │ │ │ │ -BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, │ │ │ │ │ -BufferDescriptor const &duuDesc, BufferDescriptor const &duvDesc, │ │ │ │ │ -BufferDescriptor const &dvvDesc, MTLContext *context) │ │ │ │ │ -Configure compute pipline state. Returns false if it fails to create the │ │ │ │ │ -pipeline state. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -bool EvalPatches(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > │ │ │ │ │ -duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, int numPatchCoords, id< MTLBuffer > │ │ │ │ │ -patchCoordsBuffer, const PatchArrayVector &patchArrays, id< MTLBuffer > │ │ │ │ │ -patchIndexBuffer, id< MTLBuffer > patchParamsBuffer, MTLContext *context) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_4_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ +_G_e_t_Q_u_a_d_O_f_f_s_e_t_s_B_a_s_e │ │ │ │ │ +int GetQuadOffsetsBase(Far::PatchDescriptor::Type type) │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ +static MTLLegacyGregoryPatchTable * Create(Far::PatchTable const │ │ │ │ │ +*farPatchTable, DEVICE_CONTEXT context) │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_4_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ +_G_e_t_V_e_r_t_e_x_V_a_l_e_n_c_e_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetVertexValenceBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ +_G_e_t_Q_u_a_d_O_f_f_s_e_t_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetQuadOffsetsBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ +static MTLLegacyGregoryPatchTable * Create(Far::PatchTable const │ │ │ │ │ +*farPatchTable, MTLContext *context) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ +_U_p_d_a_t_e_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +void UpdateVertexBuffer(id< MTLBuffer > vbo, int numVertices, int │ │ │ │ │ +numVertexElements, MTLContext *context) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ +_~_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e │ │ │ │ │ +~MTLLegacyGregoryPatchTable() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_:_: │ │ │ │ │ +_G_e_t_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetVertexBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h_:_5_6 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ + * _m_t_l_L_e_g_a_c_y_G_r_e_g_o_r_y_P_a_t_c_h_T_a_b_l_e_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00824.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlVertexBuffer.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlComputeEvaluator.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,40 +90,46 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
mtlVertexBuffer.h File Reference
│ │ │ │ +
mtlComputeEvaluator.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ +#include "../osd/types.h"
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │ #include "../osd/mtlCommon.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  CPUMTLVertexBuffer
class  MTLStencilTable
 
class  MTLComputeEvaluator
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,23 +1,29 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -mtlVertexBuffer.h File Reference │ │ │ │ │ +mtlComputeEvaluator.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ +#include "_._._/_o_s_d_/_t_y_p_e_s_._h" │ │ │ │ │ +#include "_._._/_o_s_d_/_b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ #include "_._._/_o_s_d_/_m_t_l_C_o_m_m_o_n_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +class   _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +  │ │ │ │ │ +class   _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │ +  │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ + * _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00824.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,4 @@ │ │ │ │ │ var a00824 = [ │ │ │ │ │ - ["CPUMTLVertexBuffer", "a01309.html", "a01309"] │ │ │ │ │ + ["MTLStencilTable", "a01289.html", "a01289"], │ │ │ │ │ + ["MTLComputeEvaluator", "a01293.html", "a01293"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00824_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/mtlVertexBuffer.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/mtlComputeEvaluator.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
mtlVertexBuffer.h
│ │ │ │ +
mtlComputeEvaluator.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,97 +119,1138 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29#include "../osd/mtlCommon.h"
│ │ │ │ -
30
│ │ │ │ -
31@protocol MTLDevice;
│ │ │ │ -
32@protocol MTLBuffer;
│ │ │ │ +
29
│ │ │ │ +
30#include "../osd/types.h"
│ │ │ │ +
31#include "../osd/bufferDescriptor.h"
│ │ │ │ +
32#include "../osd/mtlCommon.h"
│ │ │ │
33
│ │ │ │ -
34namespace OpenSubdiv {
│ │ │ │ -
35namespace OPENSUBDIV_VERSION {
│ │ │ │ -
36
│ │ │ │ -
37namespace Osd {
│ │ │ │ +
34@protocol MTLDevice;
│ │ │ │ +
35@protocol MTLBuffer;
│ │ │ │ +
36@protocol MTLLibrary;
│ │ │ │ +
37@protocol MTLComputePipelineState;
│ │ │ │
38
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
40public:
│ │ │ │ -
41 static CPUMTLVertexBuffer* Create(int numElements, int numVertices, MTLContext* context);
│ │ │ │ -
42
│ │ │ │ -
43 void UpdateData(const float* src, int startVertex, int numVertices, MTLContext* context);
│ │ │ │ -
44
│ │ │ │ -
│ │ │ │ -
45 int GetNumElements() const
│ │ │ │ -
46 {
│ │ │ │ -
47 return _numElements;
│ │ │ │ -
48 }
│ │ │ │ -
│ │ │ │ +
39namespace OpenSubdiv {
│ │ │ │ +
40namespace OPENSUBDIV_VERSION {
│ │ │ │ +
41
│ │ │ │ +
42namespace Far {
│ │ │ │ +
43 class PatchTable;
│ │ │ │ +
44 class StencilTable;
│ │ │ │ +
45 class LimitStencilTable;
│ │ │ │ +
46}
│ │ │ │ +
47
│ │ │ │ +
48namespace Osd {
│ │ │ │
49
│ │ │ │ -
│ │ │ │ -
50 int GetNumVertices() const
│ │ │ │ -
51 {
│ │ │ │ -
52 return _numVertices;
│ │ │ │ -
53 }
│ │ │ │ -
│ │ │ │ -
54
│ │ │ │ -
55 float* BindCpuBuffer();
│ │ │ │ -
56 id<MTLBuffer> BindMTLBuffer(MTLContext* context);
│ │ │ │ -
57
│ │ │ │ -
│ │ │ │ -
58 id<MTLBuffer> BindVBO(MTLContext* context)
│ │ │ │ -
59 {
│ │ │ │ -
60 return BindMTLBuffer(context);
│ │ │ │ -
61 }
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
51{
│ │ │ │ +
52public:
│ │ │ │ +
53 template<typename STENCIL_TABLE, typename DEVICE_CONTEXT>
│ │ │ │ +
│ │ │ │ +
54 static MTLStencilTable* Create(STENCIL_TABLE* stencilTable,
│ │ │ │ +
55 DEVICE_CONTEXT context)
│ │ │ │ +
56 {
│ │ │ │ +
57 return new MTLStencilTable(stencilTable, context);
│ │ │ │ +
58 }
│ │ │ │
│ │ │ │ -
62
│ │ │ │ -
63protected:
│ │ │ │ +
59
│ │ │ │ +
60
│ │ │ │ +
61 MTLStencilTable(Far::StencilTable const* stencilTable, MTLContext* context);
│ │ │ │ +
62 MTLStencilTable(Far::LimitStencilTable const* stencilTable, MTLContext* context);
│ │ │ │ + │ │ │ │
64
│ │ │ │ -
65 CPUMTLVertexBuffer(int numElements, int numVertices);
│ │ │ │ -
66
│ │ │ │ -
67 bool allocate(MTLContext* context);
│ │ │ │ -
68
│ │ │ │ -
69private:
│ │ │ │ -
70 int _numElements;
│ │ │ │ -
71 int _numVertices;
│ │ │ │ -
72 id<MTLBuffer> _buffer;
│ │ │ │ -
73 bool _dirty;
│ │ │ │ -
74};
│ │ │ │ -
│ │ │ │ -
75
│ │ │ │ -
76} //end namespace Osd
│ │ │ │ -
77
│ │ │ │ -
78} //end namespace OPENSUBDIV_VERSION
│ │ │ │ -
79 using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
80
│ │ │ │ -
81} //end namespace OpenSubdiv
│ │ │ │ -
82
│ │ │ │ -
83#endif // OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H
│ │ │ │ - │ │ │ │ +
65 id<MTLBuffer> GetSizesBuffer() const { return _sizesBuffer; }
│ │ │ │ +
66 id<MTLBuffer> GetOffsetsBuffer() const { return _offsetsBuffer; }
│ │ │ │ +
67 id<MTLBuffer> GetIndicesBuffer() const { return _indicesBuffer; }
│ │ │ │ +
68 id<MTLBuffer> GetWeightsBuffer() const { return _weightsBuffer; }
│ │ │ │ +
69 id<MTLBuffer> GetDuWeightsBuffer() const { return _duWeightsBuffer; }
│ │ │ │ +
70 id<MTLBuffer> GetDvWeightsBuffer() const { return _dvWeightsBuffer; }
│ │ │ │ +
71 id<MTLBuffer> GetDuuWeightsBuffer() const { return _duuWeightsBuffer; }
│ │ │ │ +
72 id<MTLBuffer> GetDuvWeightsBuffer() const { return _duvWeightsBuffer; }
│ │ │ │ +
73 id<MTLBuffer> GetDvvWeightsBuffer() const { return _dvvWeightsBuffer; }
│ │ │ │ +
74
│ │ │ │ +
75 int GetNumStencils() const { return _numStencils; }
│ │ │ │ +
76
│ │ │ │ +
77private:
│ │ │ │ +
78 id<MTLBuffer> _sizesBuffer;
│ │ │ │ +
79 id<MTLBuffer> _offsetsBuffer;
│ │ │ │ +
80 id<MTLBuffer> _indicesBuffer;
│ │ │ │ +
81 id<MTLBuffer> _weightsBuffer;
│ │ │ │ +
82 id<MTLBuffer> _duWeightsBuffer;
│ │ │ │ +
83 id<MTLBuffer> _dvWeightsBuffer;
│ │ │ │ +
84 id<MTLBuffer> _duuWeightsBuffer;
│ │ │ │ +
85 id<MTLBuffer> _duvWeightsBuffer;
│ │ │ │ +
86 id<MTLBuffer> _dvvWeightsBuffer;
│ │ │ │ +
87
│ │ │ │ +
88 int _numStencils;
│ │ │ │ +
89};
│ │ │ │ +
│ │ │ │ +
90
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
92{
│ │ │ │ +
93public:
│ │ │ │ +
94 typedef bool Instantiatable;
│ │ │ │ +
95
│ │ │ │ + │ │ │ │ +
97 BufferDescriptor const &dstDesc,
│ │ │ │ +
98 BufferDescriptor const &duDesc,
│ │ │ │ +
99 BufferDescriptor const &dvDesc,
│ │ │ │ +
100 MTLContext* context);
│ │ │ │ +
101
│ │ │ │ + │ │ │ │ +
103 BufferDescriptor const &dstDesc,
│ │ │ │ +
104 BufferDescriptor const &duDesc,
│ │ │ │ +
105 BufferDescriptor const &dvDesc,
│ │ │ │ +
106 BufferDescriptor const &duuDesc,
│ │ │ │ +
107 BufferDescriptor const &duvDesc,
│ │ │ │ +
108 BufferDescriptor const &dvvDesc,
│ │ │ │ +
109 MTLContext* context);
│ │ │ │ +
110
│ │ │ │ + │ │ │ │ + │ │ │ │ +
113
│ │ │ │ +
119
│ │ │ │ +
148 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
149 static bool EvalStencils(
│ │ │ │ +
150 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
151 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
152 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
153 MTLComputeEvaluator const *instance,
│ │ │ │ +
154 MTLContext* context)
│ │ │ │ +
155 {
│ │ │ │ +
156 if (instance) {
│ │ │ │ +
157 return instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ +
158 dstBuffer, dstDesc,
│ │ │ │ +
159 stencilTable,
│ │ │ │ +
160 context);
│ │ │ │ +
161 } else {
│ │ │ │ +
162 // Create an instance on demand (slow)
│ │ │ │ +
163 instance = Create(srcDesc, dstDesc,
│ │ │ │ + │ │ │ │ + │ │ │ │ +
166 context);
│ │ │ │ +
167 if (instance) {
│ │ │ │ +
168 bool r = instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ +
169 dstBuffer, dstDesc,
│ │ │ │ +
170 stencilTable,
│ │ │ │ +
171 context);
│ │ │ │ +
172 delete instance;
│ │ │ │ +
173 return r;
│ │ │ │ +
174 }
│ │ │ │ +
175 return false;
│ │ │ │ +
176 }
│ │ │ │ +
177 }
│ │ │ │ +
│ │ │ │ +
178
│ │ │ │ +
219 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
220 static bool EvalStencils(
│ │ │ │ +
221 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
222 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
223 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
224 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
225 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
226 MTLComputeEvaluator const *instance,
│ │ │ │ +
227 MTLContext* context) {
│ │ │ │ +
228
│ │ │ │ +
229 if (instance) {
│ │ │ │ +
230 return instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ +
231 dstBuffer, dstDesc,
│ │ │ │ +
232 duBuffer, duDesc,
│ │ │ │ +
233 dvBuffer, dvDesc,
│ │ │ │ +
234 stencilTable,
│ │ │ │ +
235 context);
│ │ │ │ +
236 } else {
│ │ │ │ +
237 // Create an instance on demand (slow)
│ │ │ │ +
238 instance = Create(srcDesc, dstDesc, duDesc, dvDesc, context);
│ │ │ │ +
239 if (instance) {
│ │ │ │ +
240 bool r = instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ +
241 dstBuffer, dstDesc,
│ │ │ │ +
242 duBuffer, duDesc,
│ │ │ │ +
243 dvBuffer, dvDesc,
│ │ │ │ +
244 stencilTable,
│ │ │ │ +
245 context);
│ │ │ │ +
246 delete instance;
│ │ │ │ +
247 return r;
│ │ │ │ +
248 }
│ │ │ │ +
249 return false;
│ │ │ │ +
250 }
│ │ │ │ +
251 }
│ │ │ │ +
│ │ │ │ +
252
│ │ │ │ +
311 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
312 static bool EvalStencils(
│ │ │ │ +
313 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
314 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
315 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
316 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
317 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
318 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
319 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
320 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
321 MTLComputeEvaluator const *instance,
│ │ │ │ +
322 MTLContext* context) {
│ │ │ │ +
323
│ │ │ │ +
324 if (instance) {
│ │ │ │ +
325 return instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ +
326 dstBuffer, dstDesc,
│ │ │ │ +
327 duBuffer, duDesc,
│ │ │ │ +
328 dvBuffer, dvDesc,
│ │ │ │ +
329 duuBuffer, duuDesc,
│ │ │ │ +
330 duvBuffer, duvDesc,
│ │ │ │ +
331 dvvBuffer, dvvDesc,
│ │ │ │ +
332 stencilTable,
│ │ │ │ +
333 context);
│ │ │ │ +
334 } else {
│ │ │ │ +
335 // Create an instance on demand (slow)
│ │ │ │ +
336 instance = Create(srcDesc, dstDesc, duDesc, dvDesc,
│ │ │ │ +
337 duuDesc, duvDesc, dvvDesc, context);
│ │ │ │ +
338 if (instance) {
│ │ │ │ +
339 bool r = instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ +
340 dstBuffer, dstDesc,
│ │ │ │ +
341 duBuffer, duDesc,
│ │ │ │ +
342 dvBuffer, dvDesc,
│ │ │ │ +
343 duuBuffer, duuDesc,
│ │ │ │ +
344 duvBuffer, duvDesc,
│ │ │ │ +
345 dvvBuffer, dvvDesc,
│ │ │ │ +
346 stencilTable,
│ │ │ │ +
347 context);
│ │ │ │ +
348 delete instance;
│ │ │ │ +
349 return r;
│ │ │ │ +
350 }
│ │ │ │ +
351 return false;
│ │ │ │ +
352 }
│ │ │ │ +
353 }
│ │ │ │ +
│ │ │ │ +
354
│ │ │ │ +
375 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
377 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
378 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
379 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
380 MTLContext* context) const
│ │ │ │ +
381 {
│ │ │ │ +
382 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ +
383 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ +
384 0, BufferDescriptor(),
│ │ │ │ +
385 0, BufferDescriptor(),
│ │ │ │ +
386 stencilTable->GetSizesBuffer(),
│ │ │ │ +
387 stencilTable->GetOffsetsBuffer(),
│ │ │ │ +
388 stencilTable->GetIndicesBuffer(),
│ │ │ │ +
389 stencilTable->GetWeightsBuffer(),
│ │ │ │ +
390 0,
│ │ │ │ +
391 0,
│ │ │ │ +
392 /* start = */ 0,
│ │ │ │ +
393 /* end = */ stencilTable->GetNumStencils(),
│ │ │ │ +
394 context);
│ │ │ │ +
395 }
│ │ │ │ +
│ │ │ │ +
396
│ │ │ │ +
429 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
431 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
432 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
433 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
434 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
435 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
436 MTLContext* context) const
│ │ │ │ +
437 {
│ │ │ │ +
438 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ +
439 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ +
440 duBuffer->BindMTLBuffer(context), duDesc,
│ │ │ │ +
441 dvBuffer->BindMTLBuffer(context), dvDesc,
│ │ │ │ +
442 stencilTable->GetSizesBuffer(),
│ │ │ │ +
443 stencilTable->GetOffsetsBuffer(),
│ │ │ │ +
444 stencilTable->GetIndicesBuffer(),
│ │ │ │ +
445 stencilTable->GetWeightsBuffer(),
│ │ │ │ +
446 stencilTable->GetDuWeightsBuffer(),
│ │ │ │ +
447 stencilTable->GetDvWeightsBuffer(),
│ │ │ │ +
448 /* start = */ 0,
│ │ │ │ +
449 /* end = */ stencilTable->GetNumStencils(),
│ │ │ │ +
450 context);
│ │ │ │ +
451 }
│ │ │ │ +
│ │ │ │ +
452
│ │ │ │ +
503 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
505 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
506 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
507 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
508 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
509 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
510 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
511 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
512 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
513 MTLContext* context) const
│ │ │ │ +
514 {
│ │ │ │ +
515 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ +
516 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ +
517 duBuffer->BindMTLBuffer(context), duDesc,
│ │ │ │ +
518 dvBuffer->BindMTLBuffer(context), dvDesc,
│ │ │ │ +
519 duuBuffer->BindMTLBuffer(context), duuDesc,
│ │ │ │ +
520 duvBuffer->BindMTLBuffer(context), duvDesc,
│ │ │ │ +
521 dvvBuffer->BindMTLBuffer(context), dvvDesc,
│ │ │ │ +
522 stencilTable->GetSizesBuffer(),
│ │ │ │ +
523 stencilTable->GetOffsetsBuffer(),
│ │ │ │ +
524 stencilTable->GetIndicesBuffer(),
│ │ │ │ +
525 stencilTable->GetWeightsBuffer(),
│ │ │ │ +
526 stencilTable->GetDuWeightsBuffer(),
│ │ │ │ +
527 stencilTable->GetDvWeightsBuffer(),
│ │ │ │ +
528 stencilTable->GetDuuWeightsBuffer(),
│ │ │ │ +
529 stencilTable->GetDuvWeightsBuffer(),
│ │ │ │ +
530 stencilTable->GetDvvWeightsBuffer(),
│ │ │ │ +
531 /* start = */ 0,
│ │ │ │ +
532 /* end = */ stencilTable->GetNumStencils(),
│ │ │ │ +
533 context);
│ │ │ │ +
534 }
│ │ │ │ +
│ │ │ │ +
535
│ │ │ │ +
574 bool EvalStencils(id<MTLBuffer> srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
575 id<MTLBuffer> dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
576 id<MTLBuffer> duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
577 id<MTLBuffer> dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
578 id<MTLBuffer> sizesBuffer,
│ │ │ │ +
579 id<MTLBuffer> offsetsBuffer,
│ │ │ │ +
580 id<MTLBuffer> indicesBuffer,
│ │ │ │ +
581 id<MTLBuffer> weightsBuffer,
│ │ │ │ +
582 id<MTLBuffer> duWeightsBuffer,
│ │ │ │ +
583 id<MTLBuffer> dvWeightsBuffer,
│ │ │ │ +
584 int start,
│ │ │ │ +
585 int end,
│ │ │ │ +
586 MTLContext* context) const;
│ │ │ │ +
587
│ │ │ │ +
644 bool EvalStencils(id<MTLBuffer> srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
645 id<MTLBuffer> dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
646 id<MTLBuffer> duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
647 id<MTLBuffer> dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
648 id<MTLBuffer> duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
649 id<MTLBuffer> duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
650 id<MTLBuffer> dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
651 id<MTLBuffer> sizesBuffer,
│ │ │ │ +
652 id<MTLBuffer> offsetsBuffer,
│ │ │ │ +
653 id<MTLBuffer> indicesBuffer,
│ │ │ │ +
654 id<MTLBuffer> weightsBuffer,
│ │ │ │ +
655 id<MTLBuffer> duWeightsBuffer,
│ │ │ │ +
656 id<MTLBuffer> dvWeightsBuffer,
│ │ │ │ +
657 id<MTLBuffer> duuWeightsBuffer,
│ │ │ │ +
658 id<MTLBuffer> duvWeightsBuffer,
│ │ │ │ +
659 id<MTLBuffer> dvvWeightsBuffer,
│ │ │ │ +
660 int start,
│ │ │ │ +
661 int end,
│ │ │ │ +
662 MTLContext* context) const;
│ │ │ │ +
663
│ │ │ │ +
669
│ │ │ │ +
703 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
704 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
705 static bool EvalPatches(
│ │ │ │ +
706 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
707 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
708 int numPatchCoords,
│ │ │ │ +
709 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
710 PATCH_TABLE *patchTable,
│ │ │ │ +
711 MTLComputeEvaluator const *instance,
│ │ │ │ +
712 MTLContext* context) {
│ │ │ │ +
713
│ │ │ │ +
714 if (instance) {
│ │ │ │ +
715 return instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ +
716 dstBuffer, dstDesc,
│ │ │ │ +
717 numPatchCoords, patchCoords,
│ │ │ │ +
718 patchTable,
│ │ │ │ +
719 context);
│ │ │ │ +
720 } else {
│ │ │ │ +
721 // Create an instance on demand (slow)
│ │ │ │ +
722 instance = Create(srcDesc, dstDesc,
│ │ │ │ + │ │ │ │ + │ │ │ │ +
725 context);
│ │ │ │ +
726 if (instance) {
│ │ │ │ +
727 bool r = instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ +
728 dstBuffer, dstDesc,
│ │ │ │ +
729 numPatchCoords, patchCoords,
│ │ │ │ +
730 patchTable,
│ │ │ │ +
731 context);
│ │ │ │ +
732 delete instance;
│ │ │ │ +
733 return r;
│ │ │ │ +
734 }
│ │ │ │ +
735 return false;
│ │ │ │ +
736 }
│ │ │ │ +
737 }
│ │ │ │ +
│ │ │ │ +
738
│ │ │ │ +
784 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
785 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
786 static bool EvalPatches(
│ │ │ │ +
787 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
788 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
789 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
790 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
791 int numPatchCoords,
│ │ │ │ +
792 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
793 PATCH_TABLE *patchTable,
│ │ │ │ +
794 MTLComputeEvaluator* instance,
│ │ │ │ +
795 MTLContext* context) {
│ │ │ │ +
796
│ │ │ │ +
797 if (instance) {
│ │ │ │ +
798 return instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ +
799 dstBuffer, dstDesc,
│ │ │ │ +
800 duBuffer, duDesc,
│ │ │ │ +
801 dvBuffer, dvDesc,
│ │ │ │ +
802 numPatchCoords, patchCoords,
│ │ │ │ +
803 patchTable,
│ │ │ │ +
804 context);
│ │ │ │ +
805 } else {
│ │ │ │ +
806 // Create an instance on demand (slow)
│ │ │ │ +
807 instance = Create(srcDesc, dstDesc,
│ │ │ │ +
808 duDesc, dvDesc, context);
│ │ │ │ +
809 if (instance) {
│ │ │ │ +
810 bool r = instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ +
811 dstBuffer, dstDesc,
│ │ │ │ +
812 duBuffer, duDesc,
│ │ │ │ +
813 dvBuffer, dvDesc,
│ │ │ │ +
814 numPatchCoords, patchCoords,
│ │ │ │ +
815 patchTable,
│ │ │ │ +
816 context);
│ │ │ │ +
817 delete instance;
│ │ │ │ +
818 return r;
│ │ │ │ +
819 }
│ │ │ │ +
820 return false;
│ │ │ │ +
821 }
│ │ │ │ +
822 }
│ │ │ │ +
│ │ │ │ +
823
│ │ │ │ +
887 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
888 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
889 static bool EvalPatches(
│ │ │ │ +
890 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
891 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
892 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
893 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
894 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
895 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
896 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
897 int numPatchCoords,
│ │ │ │ +
898 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
899 PATCH_TABLE *patchTable,
│ │ │ │ +
900 MTLComputeEvaluator* instance,
│ │ │ │ +
901 MTLContext* context) {
│ │ │ │ +
902
│ │ │ │ +
903 if (instance) {
│ │ │ │ +
904 return instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ +
905 dstBuffer, dstDesc,
│ │ │ │ +
906 duBuffer, duDesc,
│ │ │ │ +
907 dvBuffer, dvDesc,
│ │ │ │ +
908 duuBuffer, duuDesc,
│ │ │ │ +
909 duvBuffer, duvDesc,
│ │ │ │ +
910 dvvBuffer, dvvDesc,
│ │ │ │ +
911 numPatchCoords, patchCoords,
│ │ │ │ +
912 patchTable,
│ │ │ │ +
913 context);
│ │ │ │ +
914 } else {
│ │ │ │ +
915 // Create an instance on demand (slow)
│ │ │ │ +
916 instance = Create(srcDesc, dstDesc,
│ │ │ │ +
917 duDesc, dvDesc,
│ │ │ │ +
918 duuDesc, duvDesc, dvvDesc, context);
│ │ │ │ +
919 if (instance) {
│ │ │ │ +
920 bool r = instance->EvalPatches(srcBuffer, srcDesc,
│ │ │ │ +
921 dstBuffer, dstDesc,
│ │ │ │ +
922 duBuffer, duDesc,
│ │ │ │ +
923 dvBuffer, dvDesc,
│ │ │ │ +
924 duuBuffer, duuDesc,
│ │ │ │ +
925 duvBuffer, duvDesc,
│ │ │ │ +
926 dvvBuffer, dvvDesc,
│ │ │ │ +
927 numPatchCoords, patchCoords,
│ │ │ │ +
928 patchTable,
│ │ │ │ +
929 context);
│ │ │ │ +
930 delete instance;
│ │ │ │ +
931 return r;
│ │ │ │ +
932 }
│ │ │ │ +
933 return false;
│ │ │ │ +
934 }
│ │ │ │ +
935 }
│ │ │ │ +
│ │ │ │ +
936
│ │ │ │ +
964 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
965 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
967 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
968 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
969 int numPatchCoords,
│ │ │ │ +
970 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
971 PATCH_TABLE *patchTable,
│ │ │ │ +
972 MTLContext* context) const {
│ │ │ │ +
973
│ │ │ │ +
974 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ +
975 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ +
976 0, BufferDescriptor(),
│ │ │ │ +
977 0, BufferDescriptor(),
│ │ │ │ +
978 numPatchCoords,
│ │ │ │ +
979 patchCoords->BindMTLBuffer(context),
│ │ │ │ +
980 patchTable->GetPatchArrays(),
│ │ │ │ +
981 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
982 patchTable->GetPatchParamBuffer(),
│ │ │ │ +
983 context);
│ │ │ │ +
984 }
│ │ │ │ +
│ │ │ │ +
985
│ │ │ │ +
1023 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1024 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1026 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1027 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1028 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1029 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1030 int numPatchCoords,
│ │ │ │ +
1031 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1032 PATCH_TABLE *patchTable,
│ │ │ │ +
1033 MTLContext* context) const {
│ │ │ │ +
1034
│ │ │ │ +
1035 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ +
1036 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ +
1037 duBuffer->BindMTLBuffer(context), duDesc,
│ │ │ │ +
1038 dvBuffer->BindMTLBuffer(context), dvDesc,
│ │ │ │ +
1039 numPatchCoords,
│ │ │ │ +
1040 patchCoords->BindMTLBuffer(context),
│ │ │ │ +
1041 patchTable->GetPatchArrays(),
│ │ │ │ +
1042 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
1043 patchTable->GetPatchParamBuffer(),
│ │ │ │ +
1044 context);
│ │ │ │ +
1045 }
│ │ │ │ +
│ │ │ │ +
1046
│ │ │ │ +
1102 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1103 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1105 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1106 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1107 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1108 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1109 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
1110 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
1111 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
1112 int numPatchCoords,
│ │ │ │ +
1113 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1114 PATCH_TABLE *patchTable,
│ │ │ │ +
1115 MTLContext* context) const {
│ │ │ │ +
1116
│ │ │ │ +
1117 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc,
│ │ │ │ +
1118 dstBuffer->BindMTLBuffer(context), dstDesc,
│ │ │ │ +
1119 duBuffer->BindMTLBuffer(context), duDesc,
│ │ │ │ +
1120 dvBuffer->BindMTLBuffer(context), dvDesc,
│ │ │ │ +
1121 duuBuffer->BindMTLBuffer(context), duuDesc,
│ │ │ │ +
1122 duvBuffer->BindMTLBuffer(context), duvDesc,
│ │ │ │ +
1123 dvvBuffer->BindMTLBuffer(context), dvvDesc,
│ │ │ │ +
1124 numPatchCoords,
│ │ │ │ +
1125 patchCoords->BindMTLBuffer(context),
│ │ │ │ +
1126 patchTable->GetPatchArrays(),
│ │ │ │ +
1127 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
1128 patchTable->GetPatchParamBuffer(),
│ │ │ │ +
1129 context);
│ │ │ │ +
1130 }
│ │ │ │ +
│ │ │ │ +
1131
│ │ │ │ +
1132 bool EvalPatches(id<MTLBuffer> srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1133 id<MTLBuffer> dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1134 id<MTLBuffer> duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1135 id<MTLBuffer> dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1136 int numPatchCoords,
│ │ │ │ +
1137 id<MTLBuffer> patchCoordsBuffer,
│ │ │ │ +
1138 const PatchArrayVector &patchArrays,
│ │ │ │ +
1139 id<MTLBuffer> patchIndexBuffer,
│ │ │ │ +
1140 id<MTLBuffer> patchParamsBuffer,
│ │ │ │ +
1141 MTLContext* context) const;
│ │ │ │ +
1142
│ │ │ │ +
1143 bool EvalPatches(id<MTLBuffer> srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1144 id<MTLBuffer> dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1145 id<MTLBuffer> duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1146 id<MTLBuffer> dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1147 id<MTLBuffer> duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
1148 id<MTLBuffer> duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
1149 id<MTLBuffer> dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
1150 int numPatchCoords,
│ │ │ │ +
1151 id<MTLBuffer> patchCoordsBuffer,
│ │ │ │ +
1152 const PatchArrayVector &patchArrays,
│ │ │ │ +
1153 id<MTLBuffer> patchIndexBuffer,
│ │ │ │ +
1154 id<MTLBuffer> patchParamsBuffer,
│ │ │ │ +
1155 MTLContext* context) const;
│ │ │ │ +
1156
│ │ │ │ +
1190 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1191 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1193 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1194 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1195 int numPatchCoords,
│ │ │ │ +
1196 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1197 PATCH_TABLE *patchTable,
│ │ │ │ +
1198 MTLComputeEvaluator const *instance,
│ │ │ │ +
1199 MTLContext* deviceContext) {
│ │ │ │ +
1200
│ │ │ │ +
1201 if (instance) {
│ │ │ │ +
1202 return instance->EvalPatchesVarying(
│ │ │ │ +
1203 srcBuffer, srcDesc,
│ │ │ │ +
1204 dstBuffer, dstDesc,
│ │ │ │ +
1205 numPatchCoords, patchCoords,
│ │ │ │ +
1206 patchTable,
│ │ │ │ +
1207 deviceContext);
│ │ │ │ +
1208 } else {
│ │ │ │ +
1209 // Create an instance on demand (slow)
│ │ │ │ +
1210 instance = Create(srcDesc, dstDesc,
│ │ │ │ + │ │ │ │ + │ │ │ │ +
1213 deviceContext);
│ │ │ │ +
1214 if (instance) {
│ │ │ │ +
1215 bool r = instance->EvalPatchesVarying(
│ │ │ │ +
1216 srcBuffer, srcDesc,
│ │ │ │ +
1217 dstBuffer, dstDesc,
│ │ │ │ +
1218 numPatchCoords, patchCoords,
│ │ │ │ +
1219 patchTable,
│ │ │ │ +
1220 deviceContext);
│ │ │ │ +
1221 delete instance;
│ │ │ │ +
1222 return r;
│ │ │ │ +
1223 }
│ │ │ │ +
1224 return false;
│ │ │ │ +
1225 }
│ │ │ │ +
1226 }
│ │ │ │ +
│ │ │ │ +
1227
│ │ │ │ +
1255 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1256 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1258 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1259 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1260 int numPatchCoords,
│ │ │ │ +
1261 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1262 PATCH_TABLE *patchTable,
│ │ │ │ +
1263 MTLContext* deviceContext) const {
│ │ │ │ +
1264
│ │ │ │ +
1265 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ +
1266 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ +
1267 0, BufferDescriptor(),
│ │ │ │ +
1268 0, BufferDescriptor(),
│ │ │ │ +
1269 numPatchCoords,
│ │ │ │ +
1270 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ +
1271 patchTable->GetVaryingPatchArrays(),
│ │ │ │ +
1272 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
1273 patchTable->GetPatchParamBuffer(),
│ │ │ │ +
1274 deviceContext
│ │ │ │ +
1275 );
│ │ │ │ +
1276 }
│ │ │ │ +
│ │ │ │ +
1277
│ │ │ │ +
1323 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1324 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1326 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1327 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1328 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1329 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1330 int numPatchCoords,
│ │ │ │ +
1331 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1332 PATCH_TABLE *patchTable,
│ │ │ │ +
1333 MTLComputeEvaluator const *instance,
│ │ │ │ +
1334 MTLContext* deviceContext) {
│ │ │ │ +
1335
│ │ │ │ +
1336 if (instance) {
│ │ │ │ +
1337 return instance->EvalPatchesVarying(
│ │ │ │ +
1338 srcBuffer, srcDesc,
│ │ │ │ +
1339 dstBuffer, dstDesc,
│ │ │ │ +
1340 duBuffer, duDesc,
│ │ │ │ +
1341 dvBuffer, dvDesc,
│ │ │ │ +
1342 numPatchCoords, patchCoords,
│ │ │ │ +
1343 patchTable,
│ │ │ │ +
1344 deviceContext);
│ │ │ │ +
1345 } else {
│ │ │ │ +
1346 // Create an instance on demand (slow)
│ │ │ │ +
1347 instance = Create(srcDesc, dstDesc,
│ │ │ │ +
1348 duDesc, dvDesc,
│ │ │ │ +
1349 deviceContext);
│ │ │ │ +
1350 if (instance) {
│ │ │ │ +
1351 bool r = instance->EvalPatchesVarying(
│ │ │ │ +
1352 srcBuffer, srcDesc,
│ │ │ │ +
1353 dstBuffer, dstDesc,
│ │ │ │ +
1354 duBuffer, duDesc,
│ │ │ │ +
1355 dvBuffer, dvDesc,
│ │ │ │ +
1356 numPatchCoords, patchCoords,
│ │ │ │ +
1357 patchTable,
│ │ │ │ +
1358 deviceContext);
│ │ │ │ +
1359 delete instance;
│ │ │ │ +
1360 return r;
│ │ │ │ +
1361 }
│ │ │ │ +
1362 return false;
│ │ │ │ +
1363 }
│ │ │ │ +
1364 }
│ │ │ │ +
│ │ │ │ +
1365
│ │ │ │ +
1405 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1406 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1408 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1409 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1410 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1411 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1412 int numPatchCoords,
│ │ │ │ +
1413 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1414 PATCH_TABLE *patchTable,
│ │ │ │ +
1415 MTLContext* deviceContext) const {
│ │ │ │ +
1416
│ │ │ │ +
1417 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ +
1418 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ +
1419 duBuffer->BindMTLBuffer(deviceContext), duDesc,
│ │ │ │ +
1420 dvBuffer->BindMTLBuffer(deviceContext), dvDesc,
│ │ │ │ +
1421 numPatchCoords,
│ │ │ │ +
1422 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ +
1423 patchTable->GetVaryingPatchArrays(),
│ │ │ │ +
1424 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
1425 patchTable->GetPatchParamBuffer(),
│ │ │ │ +
1426 deviceContext
│ │ │ │ +
1427 );
│ │ │ │ +
1428 }
│ │ │ │ +
│ │ │ │ +
1429
│ │ │ │ +
1430
│ │ │ │ +
1494 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1495 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1497 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1498 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1499 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1500 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1501 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
1502 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
1503 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
1504 int numPatchCoords,
│ │ │ │ +
1505 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1506 PATCH_TABLE *patchTable,
│ │ │ │ +
1507 MTLComputeEvaluator const *instance,
│ │ │ │ +
1508 MTLContext* deviceContext) {
│ │ │ │ +
1509
│ │ │ │ +
1510 if (instance) {
│ │ │ │ +
1511 return instance->EvalPatchesVarying(
│ │ │ │ +
1512 srcBuffer, srcDesc,
│ │ │ │ +
1513 dstBuffer, dstDesc,
│ │ │ │ +
1514 duBuffer, duDesc,
│ │ │ │ +
1515 dvBuffer, dvDesc,
│ │ │ │ +
1516 duuBuffer, duuDesc,
│ │ │ │ +
1517 duvBuffer, duvDesc,
│ │ │ │ +
1518 dvvBuffer, dvvDesc,
│ │ │ │ +
1519 numPatchCoords, patchCoords,
│ │ │ │ +
1520 patchTable,
│ │ │ │ +
1521 deviceContext);
│ │ │ │ +
1522 } else {
│ │ │ │ +
1523 // Create an instance on demand (slow)
│ │ │ │ +
1524 instance = Create(srcDesc, dstDesc,
│ │ │ │ +
1525 duDesc, dvDesc,
│ │ │ │ +
1526 duuDesc, duvDesc, dvvDesc,
│ │ │ │ +
1527 deviceContext);
│ │ │ │ +
1528 if (instance) {
│ │ │ │ +
1529 bool r = instance->EvalPatchesVarying(
│ │ │ │ +
1530 srcBuffer, srcDesc,
│ │ │ │ +
1531 dstBuffer, dstDesc,
│ │ │ │ +
1532 duBuffer, duDesc,
│ │ │ │ +
1533 dvBuffer, dvDesc,
│ │ │ │ +
1534 duuBuffer, duuDesc,
│ │ │ │ +
1535 duvBuffer, duvDesc,
│ │ │ │ +
1536 dvvBuffer, dvvDesc,
│ │ │ │ +
1537 numPatchCoords, patchCoords,
│ │ │ │ +
1538 patchTable,
│ │ │ │ +
1539 deviceContext);
│ │ │ │ +
1540 delete instance;
│ │ │ │ +
1541 return r;
│ │ │ │ +
1542 }
│ │ │ │ +
1543 return false;
│ │ │ │ +
1544 }
│ │ │ │ +
1545 }
│ │ │ │ +
│ │ │ │ +
1546
│ │ │ │ +
1604 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1605 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1607 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1608 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1609 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1610 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1611 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
1612 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
1613 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
1614 int numPatchCoords,
│ │ │ │ +
1615 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1616 PATCH_TABLE *patchTable,
│ │ │ │ +
1617 MTLContext* deviceContext) const {
│ │ │ │ +
1618
│ │ │ │ +
1619 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ +
1620 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ +
1621 duBuffer->BindMTLBuffer(deviceContext), duDesc,
│ │ │ │ +
1622 dvBuffer->BindMTLBuffer(deviceContext), dvDesc,
│ │ │ │ +
1623 duuBuffer->BindMTLBuffer(deviceContext), duuDesc,
│ │ │ │ +
1624 duvBuffer->BindMTLBuffer(deviceContext), duvDesc,
│ │ │ │ +
1625 dvvBuffer->BindMTLBuffer(deviceContext), dvvDesc,
│ │ │ │ +
1626 numPatchCoords,
│ │ │ │ +
1627 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ +
1628 patchTable->GetVaryingPatchArrays(),
│ │ │ │ +
1629 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
1630 patchTable->GetPatchParamBuffer(),
│ │ │ │ +
1631 deviceContext
│ │ │ │ +
1632 );
│ │ │ │ +
1633 }
│ │ │ │ +
│ │ │ │ +
1634
│ │ │ │ +
1670 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1671 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1673 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1674 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1675 int numPatchCoords,
│ │ │ │ +
1676 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1677 PATCH_TABLE *patchTable,
│ │ │ │ +
1678 int fvarChannel,
│ │ │ │ +
1679 MTLComputeEvaluator const *instance,
│ │ │ │ +
1680 MTLContext* deviceContext) {
│ │ │ │ +
1681
│ │ │ │ +
1682 if (instance) {
│ │ │ │ +
1683 return instance->EvalPatchesFaceVarying(
│ │ │ │ +
1684 srcBuffer, srcDesc,
│ │ │ │ +
1685 dstBuffer, dstDesc,
│ │ │ │ +
1686 numPatchCoords, patchCoords,
│ │ │ │ +
1687 patchTable,
│ │ │ │ +
1688 fvarChannel,
│ │ │ │ +
1689 deviceContext);
│ │ │ │ +
1690 } else {
│ │ │ │ +
1691 // Create an instance on demand (slow)
│ │ │ │ +
1692 instance = Create(srcDesc, dstDesc,
│ │ │ │ + │ │ │ │ + │ │ │ │ +
1695 deviceContext);
│ │ │ │ +
1696 if (instance) {
│ │ │ │ +
1697 bool r = instance->EvalPatchesFaceVarying(
│ │ │ │ +
1698 srcBuffer, srcDesc,
│ │ │ │ +
1699 dstBuffer, dstDesc,
│ │ │ │ +
1700 numPatchCoords, patchCoords,
│ │ │ │ +
1701 patchTable,
│ │ │ │ +
1702 fvarChannel,
│ │ │ │ +
1703 deviceContext);
│ │ │ │ +
1704 delete instance;
│ │ │ │ +
1705 return r;
│ │ │ │ +
1706 }
│ │ │ │ +
1707 return false;
│ │ │ │ +
1708 }
│ │ │ │ +
1709 }
│ │ │ │ +
│ │ │ │ +
1710
│ │ │ │ +
1740 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1741 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1743 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1744 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1745 int numPatchCoords,
│ │ │ │ +
1746 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1747 PATCH_TABLE *patchTable,
│ │ │ │ +
1748 int fvarChannel,
│ │ │ │ +
1749 MTLContext* deviceContext) const {
│ │ │ │ +
1750
│ │ │ │ +
1751 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ +
1752 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ +
1753 0, BufferDescriptor(),
│ │ │ │ +
1754 0, BufferDescriptor(),
│ │ │ │ +
1755 numPatchCoords,
│ │ │ │ +
1756 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ +
1757 patchTable->GetFVarPatchArrays(fvarChannel),
│ │ │ │ +
1758 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
1759 patchTable->GetFVarPatchParamBuffer(fvarChannel),
│ │ │ │ +
1760 deviceContext
│ │ │ │ +
1761 );
│ │ │ │ +
1762 }
│ │ │ │ +
│ │ │ │ +
1763
│ │ │ │ +
1811 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1812 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1814 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1815 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1816 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1817 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1818 int numPatchCoords,
│ │ │ │ +
1819 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1820 PATCH_TABLE *patchTable,
│ │ │ │ +
1821 int fvarChannel,
│ │ │ │ +
1822 MTLComputeEvaluator const *instance,
│ │ │ │ +
1823 MTLContext* deviceContext) {
│ │ │ │ +
1824
│ │ │ │ +
1825 if (instance) {
│ │ │ │ +
1826 return instance->EvalPatchesFaceVarying(
│ │ │ │ +
1827 srcBuffer, srcDesc,
│ │ │ │ +
1828 dstBuffer, dstDesc,
│ │ │ │ +
1829 duBuffer, duDesc,
│ │ │ │ +
1830 dvBuffer, dvDesc,
│ │ │ │ +
1831 numPatchCoords, patchCoords,
│ │ │ │ +
1832 patchTable,
│ │ │ │ +
1833 fvarChannel,
│ │ │ │ +
1834 deviceContext);
│ │ │ │ +
1835 } else {
│ │ │ │ +
1836 // Create an instance on demand (slow)
│ │ │ │ +
1837 instance = Create(srcDesc, dstDesc,
│ │ │ │ +
1838 duDesc, dvDesc,
│ │ │ │ +
1839 deviceContext);
│ │ │ │ +
1840 if (instance) {
│ │ │ │ +
1841 bool r = instance->EvalPatchesFaceVarying(
│ │ │ │ +
1842 srcBuffer, srcDesc,
│ │ │ │ +
1843 dstBuffer, dstDesc,
│ │ │ │ +
1844 duBuffer, duDesc,
│ │ │ │ +
1845 dvBuffer, dvDesc,
│ │ │ │ +
1846 numPatchCoords, patchCoords,
│ │ │ │ +
1847 patchTable,
│ │ │ │ +
1848 fvarChannel,
│ │ │ │ +
1849 deviceContext);
│ │ │ │ +
1850 delete instance;
│ │ │ │ +
1851 return r;
│ │ │ │ +
1852 }
│ │ │ │ +
1853 return false;
│ │ │ │ +
1854 }
│ │ │ │ +
1855 }
│ │ │ │ +
│ │ │ │ +
1856
│ │ │ │ +
1898 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1899 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1901 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1902 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1903 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1904 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1905 int numPatchCoords,
│ │ │ │ +
1906 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1907 PATCH_TABLE *patchTable,
│ │ │ │ +
1908 int fvarChannel,
│ │ │ │ +
1909 MTLContext* deviceContext) const {
│ │ │ │ +
1910
│ │ │ │ +
1911 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ +
1912 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ +
1913 duBuffer->BindMTLBuffer(deviceContext), duDesc,
│ │ │ │ +
1914 dvBuffer->BindMTLBuffer(deviceContext), dvDesc,
│ │ │ │ +
1915 numPatchCoords,
│ │ │ │ +
1916 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ +
1917 patchTable->GetFVarPatchArrays(fvarChannel),
│ │ │ │ +
1918 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
1919 patchTable->GetFVarPatchParamBuffer(fvarChannel),
│ │ │ │ +
1920 deviceContext
│ │ │ │ +
1921 );
│ │ │ │ +
1922 }
│ │ │ │ +
│ │ │ │ +
1923
│ │ │ │ +
1989 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1990 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1992 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1993 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1994 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1995 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1996 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
1997 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
1998 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
1999 int numPatchCoords,
│ │ │ │ +
2000 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
2001 PATCH_TABLE *patchTable,
│ │ │ │ +
2002 int fvarChannel,
│ │ │ │ +
2003 MTLComputeEvaluator const *instance,
│ │ │ │ +
2004 MTLContext* deviceContext) {
│ │ │ │ +
2005
│ │ │ │ +
2006 if (instance) {
│ │ │ │ +
2007 return instance->EvalPatchesFaceVarying(
│ │ │ │ +
2008 srcBuffer, srcDesc,
│ │ │ │ +
2009 dstBuffer, dstDesc,
│ │ │ │ +
2010 duBuffer, duDesc,
│ │ │ │ +
2011 dvBuffer, dvDesc,
│ │ │ │ +
2012 duuBuffer, duuDesc,
│ │ │ │ +
2013 duvBuffer, duvDesc,
│ │ │ │ +
2014 dvvBuffer, dvvDesc,
│ │ │ │ +
2015 numPatchCoords, patchCoords,
│ │ │ │ +
2016 patchTable,
│ │ │ │ +
2017 fvarChannel,
│ │ │ │ +
2018 deviceContext);
│ │ │ │ +
2019 } else {
│ │ │ │ +
2020 // Create an instance on demand (slow)
│ │ │ │ +
2021 instance = Create(srcDesc, dstDesc,
│ │ │ │ +
2022 duDesc, dvDesc,
│ │ │ │ +
2023 duuDesc, duvDesc, dvvDesc,
│ │ │ │ +
2024 deviceContext);
│ │ │ │ +
2025 if (instance) {
│ │ │ │ +
2026 bool r = instance->EvalPatchesFaceVarying(
│ │ │ │ +
2027 srcBuffer, srcDesc,
│ │ │ │ +
2028 dstBuffer, dstDesc,
│ │ │ │ +
2029 duBuffer, duDesc,
│ │ │ │ +
2030 dvBuffer, dvDesc,
│ │ │ │ +
2031 duuBuffer, duuDesc,
│ │ │ │ +
2032 duvBuffer, duvDesc,
│ │ │ │ +
2033 dvvBuffer, dvvDesc,
│ │ │ │ +
2034 numPatchCoords, patchCoords,
│ │ │ │ +
2035 patchTable,
│ │ │ │ +
2036 fvarChannel,
│ │ │ │ +
2037 deviceContext);
│ │ │ │ +
2038 delete instance;
│ │ │ │ +
2039 return r;
│ │ │ │ +
2040 }
│ │ │ │ +
2041 return false;
│ │ │ │ +
2042 }
│ │ │ │ +
2043 }
│ │ │ │ +
│ │ │ │ +
2044
│ │ │ │ +
2104 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
2105 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
2107 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
2108 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
2109 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
2110 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
2111 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
2112 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
2113 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
2114 int numPatchCoords,
│ │ │ │ +
2115 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
2116 PATCH_TABLE *patchTable,
│ │ │ │ +
2117 int fvarChannel,
│ │ │ │ +
2118 MTLContext* deviceContext) const {
│ │ │ │ +
2119
│ │ │ │ +
2120 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc,
│ │ │ │ +
2121 dstBuffer->BindMTLBuffer(deviceContext), dstDesc,
│ │ │ │ +
2122 duBuffer->BindMTLBuffer(deviceContext), duDesc,
│ │ │ │ +
2123 dvBuffer->BindMTLBuffer(deviceContext), dvDesc,
│ │ │ │ +
2124 duuBuffer->BindMTLBuffer(deviceContext), duuDesc,
│ │ │ │ +
2125 duvBuffer->BindMTLBuffer(deviceContext), duvDesc,
│ │ │ │ +
2126 dvvBuffer->BindMTLBuffer(deviceContext), dvvDesc,
│ │ │ │ +
2127 numPatchCoords,
│ │ │ │ +
2128 patchCoords->BindMTLBuffer(deviceContext),
│ │ │ │ +
2129 patchTable->GetFVarPatchArrays(fvarChannel),
│ │ │ │ +
2130 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
2131 patchTable->GetFVarPatchParamBuffer(fvarChannel),
│ │ │ │ +
2132 fvarChannel,
│ │ │ │ +
2133 deviceContext
│ │ │ │ +
2134 );
│ │ │ │ +
2135 }
│ │ │ │ +
│ │ │ │ +
2136
│ │ │ │ +
2138 bool Compile(BufferDescriptor const &srcDesc,
│ │ │ │ +
2139 BufferDescriptor const &dstDesc,
│ │ │ │ +
2140 BufferDescriptor const &duDesc,
│ │ │ │ +
2141 BufferDescriptor const &dvDesc,
│ │ │ │ +
2142 BufferDescriptor const &duuDesc,
│ │ │ │ +
2143 BufferDescriptor const &duvDesc,
│ │ │ │ +
2144 BufferDescriptor const &dvvDesc,
│ │ │ │ +
2145 MTLContext* context);
│ │ │ │ +
2146
│ │ │ │ +
2148 static void Synchronize(MTLContext* context);
│ │ │ │ +
2149
│ │ │ │ +
2150 private:
│ │ │ │ +
2151
│ │ │ │ +
2152 id<MTLLibrary> _computeLibrary;
│ │ │ │ +
2153 id<MTLComputePipelineState> _evalStencils;
│ │ │ │ +
2154 id<MTLComputePipelineState> _evalPatches;
│ │ │ │ +
2155 id<MTLBuffer> _parameterBuffer;
│ │ │ │ +
2156
│ │ │ │ +
2157 int _workGroupSize;
│ │ │ │ +
2158};
│ │ │ │ +
│ │ │ │ +
2159
│ │ │ │ +
2160} //end namespace Osd
│ │ │ │ +
2161
│ │ │ │ +
2162} //end namespace OPENSUBDIV_VERSION
│ │ │ │ +
2163using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
2164
│ │ │ │ +
2165} //end namespace OpenSubdiv
│ │ │ │ +
2166
│ │ │ │ +
2167#endif // OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H
│ │ │ │ + │ │ │ │ +
std::vector< PatchArray > PatchArrayVector
Definition types.h:132
│ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ +
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ -
CPUMTLVertexBuffer(int numElements, int numVertices)
│ │ │ │ -
static CPUMTLVertexBuffer * Create(int numElements, int numVertices, MTLContext *context)
│ │ │ │ - │ │ │ │ -
void UpdateData(const float *src, int startVertex, int numVertices, MTLContext *context)
│ │ │ │ - │ │ │ │ -
id< MTLBuffer > BindMTLBuffer(MTLContext *context)
│ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ +
MTLStencilTable(Far::LimitStencilTable const *stencilTable, MTLContext *context)
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
MTLStencilTable(Far::StencilTable const *stencilTable, MTLContext *context)
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
static MTLStencilTable * Create(STENCIL_TABLE *stencilTable, DEVICE_CONTEXT context)
│ │ │ │ + │ │ │ │ + │ │ │ │ +
bool EvalStencils(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, BufferDescriptor const &dvDesc, id< MTLBuffer > duuBuffer, BufferDescriptor const &duuDesc, id< MTLBuffer > duvBuffer, BufferDescriptor const &duvDesc, id< MTLBuffer > dvvBuffer, BufferDescriptor const &dvvDesc, id< MTLBuffer > sizesBuffer, id< MTLBuffer > offsetsBuffer, id< MTLBuffer > indicesBuffer, id< MTLBuffer > weightsBuffer, id< MTLBuffer > duWeightsBuffer, id< MTLBuffer > dvWeightsBuffer, id< MTLBuffer > duuWeightsBuffer, id< MTLBuffer > duvWeightsBuffer, id< MTLBuffer > dvvWeightsBuffer, int start, int end, MTLContext *context) const
Dispatch the MTL compute kernel on GPU asynchronously returns false if the kernel hasn't been compile...
│ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator *instance, MTLContext *context)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, MTLComputeEvaluator const *instance, MTLContext *context)
Generic static stencil function. This function has a same signature as other device kernels have so t...
│ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ + │ │ │ │ + │ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, MTLContext *context)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ + │ │ │ │ +
bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, MTLComputeEvaluator const *instance, MTLContext *context)
Generic static stencil function. This function has a same signature as other device kernels have so t...
│ │ │ │ +
bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, MTLContext *context) const
Generic stencil function.
│ │ │ │ +
bool EvalPatches(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, BufferDescriptor const &dvDesc, id< MTLBuffer > duuBuffer, BufferDescriptor const &duuDesc, id< MTLBuffer > duvBuffer, BufferDescriptor const &duvDesc, id< MTLBuffer > dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, id< MTLBuffer > patchCoordsBuffer, const PatchArrayVector &patchArrays, id< MTLBuffer > patchIndexBuffer, id< MTLBuffer > patchParamsBuffer, MTLContext *context) const
│ │ │ │ +
bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static void Synchronize(MTLContext *context)
Wait for the dispatched kernel to finish.
│ │ │ │ +
bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, MTLContext *context) const
Generic stencil function.
│ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator *instance, MTLContext *context)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, MTLContext *context) const
Generic stencil function.
│ │ │ │ +
bool EvalStencils(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, BufferDescriptor const &dvDesc, id< MTLBuffer > sizesBuffer, id< MTLBuffer > offsetsBuffer, id< MTLBuffer > indicesBuffer, id< MTLBuffer > weightsBuffer, id< MTLBuffer > duWeightsBuffer, id< MTLBuffer > dvWeightsBuffer, int start, int end, MTLContext *context) const
Dispatch the MTL compute kernel on GPU asynchronously returns false if the kernel hasn't been compile...
│ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *context) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, MTLComputeEvaluator const *instance, MTLContext *context)
Generic static stencil function. This function has a same signature as other device kernels have so t...
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, MTLContext *deviceContext)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *context) const
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ +
bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *context) const
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ +
bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *deviceContext) const
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static MTLComputeEvaluator * Create(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, MTLContext *context)
│ │ │ │ +
static MTLComputeEvaluator * Create(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, MTLContext *context)
│ │ │ │ +
bool Compile(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, MTLContext *context)
Configure compute pipline state. Returns false if it fails to create the pipeline state.
│ │ │ │ +
bool EvalPatches(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, id< MTLBuffer > patchCoordsBuffer, const PatchArrayVector &patchArrays, id< MTLBuffer > patchIndexBuffer, id< MTLBuffer > patchParamsBuffer, MTLContext *context) const
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -mtlVertexBuffer.h │ │ │ │ │ +mtlComputeEvaluator.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,101 +24,1382 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29#include "../osd/mtlCommon.h" │ │ │ │ │ -30 │ │ │ │ │ -31@protocol MTLDevice; │ │ │ │ │ -32@protocol MTLBuffer; │ │ │ │ │ +29 │ │ │ │ │ +30#include "../osd/types.h" │ │ │ │ │ +31#include "../osd/bufferDescriptor.h" │ │ │ │ │ +32#include "../osd/mtlCommon.h" │ │ │ │ │ 33 │ │ │ │ │ -34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -35namespace OPENSUBDIV_VERSION { │ │ │ │ │ -36 │ │ │ │ │ -37namespace Osd { │ │ │ │ │ +34@protocol MTLDevice; │ │ │ │ │ +35@protocol MTLBuffer; │ │ │ │ │ +36@protocol MTLLibrary; │ │ │ │ │ +37@protocol MTLComputePipelineState; │ │ │ │ │ 38 │ │ │ │ │ -_3_9class _C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r { │ │ │ │ │ -40public: │ │ │ │ │ -_4_1 static _C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r* _C_r_e_a_t_e(int numElements, int numVertices, │ │ │ │ │ -_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -42 │ │ │ │ │ -_4_3 void _U_p_d_a_t_e_D_a_t_a(const float* src, int startVertex, int numVertices, │ │ │ │ │ -_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -44 │ │ │ │ │ -_4_5 int _G_e_t_N_u_m_E_l_e_m_e_n_t_s() const │ │ │ │ │ -46 { │ │ │ │ │ -47 return _numElements; │ │ │ │ │ -48 } │ │ │ │ │ +39namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +40namespace OPENSUBDIV_VERSION { │ │ │ │ │ +41 │ │ │ │ │ +42namespace Far { │ │ │ │ │ +43 class PatchTable; │ │ │ │ │ +44 class StencilTable; │ │ │ │ │ +45 class LimitStencilTable; │ │ │ │ │ +46} │ │ │ │ │ +47 │ │ │ │ │ +48namespace Osd { │ │ │ │ │ 49 │ │ │ │ │ -_5_0 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s() const │ │ │ │ │ -51 { │ │ │ │ │ -52 return _numVertices; │ │ │ │ │ -53 } │ │ │ │ │ -54 │ │ │ │ │ -_5_5 float* _B_i_n_d_C_p_u_B_u_f_f_e_r(); │ │ │ │ │ -_5_6 id _B_i_n_d_M_T_L_B_u_f_f_e_r(_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -57 │ │ │ │ │ -_5_8 id _B_i_n_d_V_B_O(_M_T_L_C_o_n_t_e_x_t* context) │ │ │ │ │ -59 { │ │ │ │ │ -60 return _B_i_n_d_M_T_L_B_u_f_f_e_r(context); │ │ │ │ │ -61 } │ │ │ │ │ -62 │ │ │ │ │ -63protected: │ │ │ │ │ +_5_0class _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +51{ │ │ │ │ │ +52public: │ │ │ │ │ +53 template │ │ │ │ │ +_5_4 static _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e* _C_r_e_a_t_e(STENCIL_TABLE* stencilTable, │ │ │ │ │ +55 DEVICE_CONTEXT context) │ │ │ │ │ +56 { │ │ │ │ │ +57 return new _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e(stencilTable, context); │ │ │ │ │ +58 } │ │ │ │ │ +59 │ │ │ │ │ +60 │ │ │ │ │ +_6_1 _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e(_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e const* stencilTable, _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +_6_2 _M_T_L_S_t_e_n_c_i_l_T_a_b_l_e(_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e const* stencilTable, _M_T_L_C_o_n_t_e_x_t* │ │ │ │ │ +context); │ │ │ │ │ +_6_3 _~_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e(); │ │ │ │ │ 64 │ │ │ │ │ -_6_5 _C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r(int numElements, int numVertices); │ │ │ │ │ -66 │ │ │ │ │ -_6_7 bool _a_l_l_o_c_a_t_e(_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ -68 │ │ │ │ │ -69private: │ │ │ │ │ -70 int _numElements; │ │ │ │ │ -71 int _numVertices; │ │ │ │ │ -72 id _buffer; │ │ │ │ │ -73 bool _dirty; │ │ │ │ │ -74}; │ │ │ │ │ -75 │ │ │ │ │ -76} //end namespace Osd │ │ │ │ │ -77 │ │ │ │ │ -78} //end namespace OPENSUBDIV_VERSION │ │ │ │ │ -79 using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -80 │ │ │ │ │ -81} //end namespace OpenSubdiv │ │ │ │ │ -82 │ │ │ │ │ -83#endif // OPENSUBDIV3_OSD_MTL_VERTEX_BUFFER_H │ │ │ │ │ +_6_5 id _G_e_t_S_i_z_e_s_B_u_f_f_e_r() const { return _sizesBuffer; } │ │ │ │ │ +_6_6 id _G_e_t_O_f_f_s_e_t_s_B_u_f_f_e_r() const { return _offsetsBuffer; } │ │ │ │ │ +_6_7 id _G_e_t_I_n_d_i_c_e_s_B_u_f_f_e_r() const { return _indicesBuffer; } │ │ │ │ │ +_6_8 id _G_e_t_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _weightsBuffer; } │ │ │ │ │ +_6_9 id _G_e_t_D_u_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _duWeightsBuffer; } │ │ │ │ │ +_7_0 id _G_e_t_D_v_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _dvWeightsBuffer; } │ │ │ │ │ +_7_1 id _G_e_t_D_u_u_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _duuWeightsBuffer; } │ │ │ │ │ +_7_2 id _G_e_t_D_u_v_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _duvWeightsBuffer; } │ │ │ │ │ +_7_3 id _G_e_t_D_v_v_W_e_i_g_h_t_s_B_u_f_f_e_r() const { return _dvvWeightsBuffer; } │ │ │ │ │ +74 │ │ │ │ │ +_7_5 int _G_e_t_N_u_m_S_t_e_n_c_i_l_s() const { return _numStencils; } │ │ │ │ │ +76 │ │ │ │ │ +77private: │ │ │ │ │ +78 id _sizesBuffer; │ │ │ │ │ +79 id _offsetsBuffer; │ │ │ │ │ +80 id _indicesBuffer; │ │ │ │ │ +81 id _weightsBuffer; │ │ │ │ │ +82 id _duWeightsBuffer; │ │ │ │ │ +83 id _dvWeightsBuffer; │ │ │ │ │ +84 id _duuWeightsBuffer; │ │ │ │ │ +85 id _duvWeightsBuffer; │ │ │ │ │ +86 id _dvvWeightsBuffer; │ │ │ │ │ +87 │ │ │ │ │ +88 int _numStencils; │ │ │ │ │ +89}; │ │ │ │ │ +90 │ │ │ │ │ +_9_1class _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +92{ │ │ │ │ │ +93public: │ │ │ │ │ +_9_4 typedef bool _I_n_s_t_a_n_t_i_a_t_a_b_l_e; │ │ │ │ │ +95 │ │ │ │ │ +_9_6 static _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r * _C_r_e_a_t_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +97 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +98 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +99 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +100 _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +101 │ │ │ │ │ +_1_0_2 static _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r * _C_r_e_a_t_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +103 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +104 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +105 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +106 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +107 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +108 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +109 _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +110 │ │ │ │ │ +_1_1_1 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r(); │ │ │ │ │ +_1_1_2 _~_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r(); │ │ │ │ │ +113 │ │ │ │ │ +119 │ │ │ │ │ +148 template │ │ │ │ │ +_1_4_9 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +150 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +151 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +152 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +153 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +154 _M_T_L_C_o_n_t_e_x_t* context) │ │ │ │ │ +155 { │ │ │ │ │ +156 if (instance) { │ │ │ │ │ +157 return instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ +158 dstBuffer, dstDesc, │ │ │ │ │ +159 stencilTable, │ │ │ │ │ +160 context); │ │ │ │ │ +161 } else { │ │ │ │ │ +162 // Create an instance on demand (slow) │ │ │ │ │ +163 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +164 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +165 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +166 context); │ │ │ │ │ +167 if (instance) { │ │ │ │ │ +168 bool r = instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ +169 dstBuffer, dstDesc, │ │ │ │ │ +170 stencilTable, │ │ │ │ │ +171 context); │ │ │ │ │ +172 delete instance; │ │ │ │ │ +173 return r; │ │ │ │ │ +174 } │ │ │ │ │ +175 return false; │ │ │ │ │ +176 } │ │ │ │ │ +177 } │ │ │ │ │ +178 │ │ │ │ │ +219 template │ │ │ │ │ +_2_2_0 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +221 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +222 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +223 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +224 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +225 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +226 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +227 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ +228 │ │ │ │ │ +229 if (instance) { │ │ │ │ │ +230 return instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ +231 dstBuffer, dstDesc, │ │ │ │ │ +232 duBuffer, duDesc, │ │ │ │ │ +233 dvBuffer, dvDesc, │ │ │ │ │ +234 stencilTable, │ │ │ │ │ +235 context); │ │ │ │ │ +236 } else { │ │ │ │ │ +237 // Create an instance on demand (slow) │ │ │ │ │ +238 instance = Create(srcDesc, dstDesc, duDesc, dvDesc, context); │ │ │ │ │ +239 if (instance) { │ │ │ │ │ +240 bool r = instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ +241 dstBuffer, dstDesc, │ │ │ │ │ +242 duBuffer, duDesc, │ │ │ │ │ +243 dvBuffer, dvDesc, │ │ │ │ │ +244 stencilTable, │ │ │ │ │ +245 context); │ │ │ │ │ +246 delete instance; │ │ │ │ │ +247 return r; │ │ │ │ │ +248 } │ │ │ │ │ +249 return false; │ │ │ │ │ +250 } │ │ │ │ │ +251 } │ │ │ │ │ +252 │ │ │ │ │ +311 template │ │ │ │ │ +_3_1_2 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +313 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +314 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +315 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +316 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +317 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +318 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +319 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +320 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +321 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +322 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ +323 │ │ │ │ │ +324 if (instance) { │ │ │ │ │ +325 return instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ +326 dstBuffer, dstDesc, │ │ │ │ │ +327 duBuffer, duDesc, │ │ │ │ │ +328 dvBuffer, dvDesc, │ │ │ │ │ +329 duuBuffer, duuDesc, │ │ │ │ │ +330 duvBuffer, duvDesc, │ │ │ │ │ +331 dvvBuffer, dvvDesc, │ │ │ │ │ +332 stencilTable, │ │ │ │ │ +333 context); │ │ │ │ │ +334 } else { │ │ │ │ │ +335 // Create an instance on demand (slow) │ │ │ │ │ +336 instance = Create(srcDesc, dstDesc, duDesc, dvDesc, │ │ │ │ │ +337 duuDesc, duvDesc, dvvDesc, context); │ │ │ │ │ +338 if (instance) { │ │ │ │ │ +339 bool r = instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ +340 dstBuffer, dstDesc, │ │ │ │ │ +341 duBuffer, duDesc, │ │ │ │ │ +342 dvBuffer, dvDesc, │ │ │ │ │ +343 duuBuffer, duuDesc, │ │ │ │ │ +344 duvBuffer, duvDesc, │ │ │ │ │ +345 dvvBuffer, dvvDesc, │ │ │ │ │ +346 stencilTable, │ │ │ │ │ +347 context); │ │ │ │ │ +348 delete instance; │ │ │ │ │ +349 return r; │ │ │ │ │ +350 } │ │ │ │ │ +351 return false; │ │ │ │ │ +352 } │ │ │ │ │ +353 } │ │ │ │ │ +354 │ │ │ │ │ +375 template │ │ │ │ │ +_3_7_6 bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +377 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +378 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +379 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +380 _M_T_L_C_o_n_t_e_x_t* context) const │ │ │ │ │ +381 { │ │ │ │ │ +382 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ +383 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ +384 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +385 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +386 stencilTable->GetSizesBuffer(), │ │ │ │ │ +387 stencilTable->GetOffsetsBuffer(), │ │ │ │ │ +388 stencilTable->GetIndicesBuffer(), │ │ │ │ │ +389 stencilTable->GetWeightsBuffer(), │ │ │ │ │ +390 0, │ │ │ │ │ +391 0, │ │ │ │ │ +392 /* start = */ 0, │ │ │ │ │ +393 /* end = */ stencilTable->GetNumStencils(), │ │ │ │ │ +394 context); │ │ │ │ │ +395 } │ │ │ │ │ +396 │ │ │ │ │ +429 template │ │ │ │ │ +_4_3_0 bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +431 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +432 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +433 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +434 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +435 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +436 _M_T_L_C_o_n_t_e_x_t* context) const │ │ │ │ │ +437 { │ │ │ │ │ +438 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ +439 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ +440 duBuffer->BindMTLBuffer(context), duDesc, │ │ │ │ │ +441 dvBuffer->BindMTLBuffer(context), dvDesc, │ │ │ │ │ +442 stencilTable->GetSizesBuffer(), │ │ │ │ │ +443 stencilTable->GetOffsetsBuffer(), │ │ │ │ │ +444 stencilTable->GetIndicesBuffer(), │ │ │ │ │ +445 stencilTable->GetWeightsBuffer(), │ │ │ │ │ +446 stencilTable->GetDuWeightsBuffer(), │ │ │ │ │ +447 stencilTable->GetDvWeightsBuffer(), │ │ │ │ │ +448 /* start = */ 0, │ │ │ │ │ +449 /* end = */ stencilTable->GetNumStencils(), │ │ │ │ │ +450 context); │ │ │ │ │ +451 } │ │ │ │ │ +452 │ │ │ │ │ +503 template │ │ │ │ │ +_5_0_4 bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +505 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +506 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +507 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +508 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +509 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +510 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +511 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +512 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +513 _M_T_L_C_o_n_t_e_x_t* context) const │ │ │ │ │ +514 { │ │ │ │ │ +515 return EvalStencils(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ +516 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ +517 duBuffer->BindMTLBuffer(context), duDesc, │ │ │ │ │ +518 dvBuffer->BindMTLBuffer(context), dvDesc, │ │ │ │ │ +519 duuBuffer->BindMTLBuffer(context), duuDesc, │ │ │ │ │ +520 duvBuffer->BindMTLBuffer(context), duvDesc, │ │ │ │ │ +521 dvvBuffer->BindMTLBuffer(context), dvvDesc, │ │ │ │ │ +522 stencilTable->GetSizesBuffer(), │ │ │ │ │ +523 stencilTable->GetOffsetsBuffer(), │ │ │ │ │ +524 stencilTable->GetIndicesBuffer(), │ │ │ │ │ +525 stencilTable->GetWeightsBuffer(), │ │ │ │ │ +526 stencilTable->GetDuWeightsBuffer(), │ │ │ │ │ +527 stencilTable->GetDvWeightsBuffer(), │ │ │ │ │ +528 stencilTable->GetDuuWeightsBuffer(), │ │ │ │ │ +529 stencilTable->GetDuvWeightsBuffer(), │ │ │ │ │ +530 stencilTable->GetDvvWeightsBuffer(), │ │ │ │ │ +531 /* start = */ 0, │ │ │ │ │ +532 /* end = */ stencilTable->GetNumStencils(), │ │ │ │ │ +533 context); │ │ │ │ │ +534 } │ │ │ │ │ +535 │ │ │ │ │ +_5_7_4 bool _E_v_a_l_S_t_e_n_c_i_l_s(id srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +575 id dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +576 id duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +577 id dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +578 id sizesBuffer, │ │ │ │ │ +579 id offsetsBuffer, │ │ │ │ │ +580 id indicesBuffer, │ │ │ │ │ +581 id weightsBuffer, │ │ │ │ │ +582 id duWeightsBuffer, │ │ │ │ │ +583 id dvWeightsBuffer, │ │ │ │ │ +584 int start, │ │ │ │ │ +585 int end, │ │ │ │ │ +586 _M_T_L_C_o_n_t_e_x_t* context) const; │ │ │ │ │ +587 │ │ │ │ │ +_6_4_4 bool _E_v_a_l_S_t_e_n_c_i_l_s(id srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +645 id dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +646 id duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +647 id dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +648 id duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +649 id duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +650 id dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +651 id sizesBuffer, │ │ │ │ │ +652 id offsetsBuffer, │ │ │ │ │ +653 id indicesBuffer, │ │ │ │ │ +654 id weightsBuffer, │ │ │ │ │ +655 id duWeightsBuffer, │ │ │ │ │ +656 id dvWeightsBuffer, │ │ │ │ │ +657 id duuWeightsBuffer, │ │ │ │ │ +658 id duvWeightsBuffer, │ │ │ │ │ +659 id dvvWeightsBuffer, │ │ │ │ │ +660 int start, │ │ │ │ │ +661 int end, │ │ │ │ │ +662 _M_T_L_C_o_n_t_e_x_t* context) const; │ │ │ │ │ +663 │ │ │ │ │ +669 │ │ │ │ │ +703 template │ │ │ │ │ +_7_0_5 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +706 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +707 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +708 int numPatchCoords, │ │ │ │ │ +709 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +710 PATCH_TABLE *patchTable, │ │ │ │ │ +711 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +712 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ +713 │ │ │ │ │ +714 if (instance) { │ │ │ │ │ +715 return instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ +716 dstBuffer, dstDesc, │ │ │ │ │ +717 numPatchCoords, patchCoords, │ │ │ │ │ +718 patchTable, │ │ │ │ │ +719 context); │ │ │ │ │ +720 } else { │ │ │ │ │ +721 // Create an instance on demand (slow) │ │ │ │ │ +722 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +723 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +724 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +725 context); │ │ │ │ │ +726 if (instance) { │ │ │ │ │ +727 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ +728 dstBuffer, dstDesc, │ │ │ │ │ +729 numPatchCoords, patchCoords, │ │ │ │ │ +730 patchTable, │ │ │ │ │ +731 context); │ │ │ │ │ +732 delete instance; │ │ │ │ │ +733 return r; │ │ │ │ │ +734 } │ │ │ │ │ +735 return false; │ │ │ │ │ +736 } │ │ │ │ │ +737 } │ │ │ │ │ +738 │ │ │ │ │ +784 template │ │ │ │ │ +_7_8_6 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +787 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +788 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +789 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +790 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +791 int numPatchCoords, │ │ │ │ │ +792 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +793 PATCH_TABLE *patchTable, │ │ │ │ │ +794 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r* instance, │ │ │ │ │ +795 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ +796 │ │ │ │ │ +797 if (instance) { │ │ │ │ │ +798 return instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ +799 dstBuffer, dstDesc, │ │ │ │ │ +800 duBuffer, duDesc, │ │ │ │ │ +801 dvBuffer, dvDesc, │ │ │ │ │ +802 numPatchCoords, patchCoords, │ │ │ │ │ +803 patchTable, │ │ │ │ │ +804 context); │ │ │ │ │ +805 } else { │ │ │ │ │ +806 // Create an instance on demand (slow) │ │ │ │ │ +807 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +808 duDesc, dvDesc, context); │ │ │ │ │ +809 if (instance) { │ │ │ │ │ +810 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ +811 dstBuffer, dstDesc, │ │ │ │ │ +812 duBuffer, duDesc, │ │ │ │ │ +813 dvBuffer, dvDesc, │ │ │ │ │ +814 numPatchCoords, patchCoords, │ │ │ │ │ +815 patchTable, │ │ │ │ │ +816 context); │ │ │ │ │ +817 delete instance; │ │ │ │ │ +818 return r; │ │ │ │ │ +819 } │ │ │ │ │ +820 return false; │ │ │ │ │ +821 } │ │ │ │ │ +822 } │ │ │ │ │ +823 │ │ │ │ │ +887 template │ │ │ │ │ +_8_8_9 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +890 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +891 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +892 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +893 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +894 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +895 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +896 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +897 int numPatchCoords, │ │ │ │ │ +898 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +899 PATCH_TABLE *patchTable, │ │ │ │ │ +900 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r* instance, │ │ │ │ │ +901 _M_T_L_C_o_n_t_e_x_t* context) { │ │ │ │ │ +902 │ │ │ │ │ +903 if (instance) { │ │ │ │ │ +904 return instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ +905 dstBuffer, dstDesc, │ │ │ │ │ +906 duBuffer, duDesc, │ │ │ │ │ +907 dvBuffer, dvDesc, │ │ │ │ │ +908 duuBuffer, duuDesc, │ │ │ │ │ +909 duvBuffer, duvDesc, │ │ │ │ │ +910 dvvBuffer, dvvDesc, │ │ │ │ │ +911 numPatchCoords, patchCoords, │ │ │ │ │ +912 patchTable, │ │ │ │ │ +913 context); │ │ │ │ │ +914 } else { │ │ │ │ │ +915 // Create an instance on demand (slow) │ │ │ │ │ +916 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +917 duDesc, dvDesc, │ │ │ │ │ +918 duuDesc, duvDesc, dvvDesc, context); │ │ │ │ │ +919 if (instance) { │ │ │ │ │ +920 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s(srcBuffer, srcDesc, │ │ │ │ │ +921 dstBuffer, dstDesc, │ │ │ │ │ +922 duBuffer, duDesc, │ │ │ │ │ +923 dvBuffer, dvDesc, │ │ │ │ │ +924 duuBuffer, duuDesc, │ │ │ │ │ +925 duvBuffer, duvDesc, │ │ │ │ │ +926 dvvBuffer, dvvDesc, │ │ │ │ │ +927 numPatchCoords, patchCoords, │ │ │ │ │ +928 patchTable, │ │ │ │ │ +929 context); │ │ │ │ │ +930 delete instance; │ │ │ │ │ +931 return r; │ │ │ │ │ +932 } │ │ │ │ │ +933 return false; │ │ │ │ │ +934 } │ │ │ │ │ +935 } │ │ │ │ │ +936 │ │ │ │ │ +964 template │ │ │ │ │ +_9_6_6 bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +967 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +968 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +969 int numPatchCoords, │ │ │ │ │ +970 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +971 PATCH_TABLE *patchTable, │ │ │ │ │ +972 _M_T_L_C_o_n_t_e_x_t* context) const { │ │ │ │ │ +973 │ │ │ │ │ +974 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ +975 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ +976 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +977 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +978 numPatchCoords, │ │ │ │ │ +979 patchCoords->BindMTLBuffer(context), │ │ │ │ │ +980 patchTable->GetPatchArrays(), │ │ │ │ │ +981 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +982 patchTable->GetPatchParamBuffer(), │ │ │ │ │ +983 context); │ │ │ │ │ +984 } │ │ │ │ │ +985 │ │ │ │ │ +1023 template │ │ │ │ │ +_1_0_2_5 bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +1026 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1027 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1028 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1029 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1030 int numPatchCoords, │ │ │ │ │ +1031 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1032 PATCH_TABLE *patchTable, │ │ │ │ │ +1033 _M_T_L_C_o_n_t_e_x_t* context) const { │ │ │ │ │ +1034 │ │ │ │ │ +1035 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ +1036 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ +1037 duBuffer->BindMTLBuffer(context), duDesc, │ │ │ │ │ +1038 dvBuffer->BindMTLBuffer(context), dvDesc, │ │ │ │ │ +1039 numPatchCoords, │ │ │ │ │ +1040 patchCoords->BindMTLBuffer(context), │ │ │ │ │ +1041 patchTable->GetPatchArrays(), │ │ │ │ │ +1042 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +1043 patchTable->GetPatchParamBuffer(), │ │ │ │ │ +1044 context); │ │ │ │ │ +1045 } │ │ │ │ │ +1046 │ │ │ │ │ +1102 template │ │ │ │ │ +_1_1_0_4 bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +1105 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1106 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1107 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1108 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1109 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +1110 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +1111 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +1112 int numPatchCoords, │ │ │ │ │ +1113 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1114 PATCH_TABLE *patchTable, │ │ │ │ │ +1115 _M_T_L_C_o_n_t_e_x_t* context) const { │ │ │ │ │ +1116 │ │ │ │ │ +1117 return EvalPatches(srcBuffer->BindMTLBuffer(context), srcDesc, │ │ │ │ │ +1118 dstBuffer->BindMTLBuffer(context), dstDesc, │ │ │ │ │ +1119 duBuffer->BindMTLBuffer(context), duDesc, │ │ │ │ │ +1120 dvBuffer->BindMTLBuffer(context), dvDesc, │ │ │ │ │ +1121 duuBuffer->BindMTLBuffer(context), duuDesc, │ │ │ │ │ +1122 duvBuffer->BindMTLBuffer(context), duvDesc, │ │ │ │ │ +1123 dvvBuffer->BindMTLBuffer(context), dvvDesc, │ │ │ │ │ +1124 numPatchCoords, │ │ │ │ │ +1125 patchCoords->BindMTLBuffer(context), │ │ │ │ │ +1126 patchTable->GetPatchArrays(), │ │ │ │ │ +1127 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +1128 patchTable->GetPatchParamBuffer(), │ │ │ │ │ +1129 context); │ │ │ │ │ +1130 } │ │ │ │ │ +1131 │ │ │ │ │ +_1_1_3_2 bool _E_v_a_l_P_a_t_c_h_e_s(id srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1133 id dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1134 id duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1135 id dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1136 int numPatchCoords, │ │ │ │ │ +1137 id patchCoordsBuffer, │ │ │ │ │ +1138 const _P_a_t_c_h_A_r_r_a_y_V_e_c_t_o_r &patchArrays, │ │ │ │ │ +1139 id patchIndexBuffer, │ │ │ │ │ +1140 id patchParamsBuffer, │ │ │ │ │ +1141 _M_T_L_C_o_n_t_e_x_t* context) const; │ │ │ │ │ +1142 │ │ │ │ │ +_1_1_4_3 bool _E_v_a_l_P_a_t_c_h_e_s(id srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1144 id dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1145 id duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1146 id dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1147 id duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +1148 id duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +1149 id dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +1150 int numPatchCoords, │ │ │ │ │ +1151 id patchCoordsBuffer, │ │ │ │ │ +1152 const _P_a_t_c_h_A_r_r_a_y_V_e_c_t_o_r &patchArrays, │ │ │ │ │ +1153 id patchIndexBuffer, │ │ │ │ │ +1154 id patchParamsBuffer, │ │ │ │ │ +1155 _M_T_L_C_o_n_t_e_x_t* context) const; │ │ │ │ │ +1156 │ │ │ │ │ +1190 template │ │ │ │ │ +_1_1_9_2 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1193 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1194 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1195 int numPatchCoords, │ │ │ │ │ +1196 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1197 PATCH_TABLE *patchTable, │ │ │ │ │ +1198 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +1199 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ +1200 │ │ │ │ │ +1201 if (instance) { │ │ │ │ │ +1202 return instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1203 srcBuffer, srcDesc, │ │ │ │ │ +1204 dstBuffer, dstDesc, │ │ │ │ │ +1205 numPatchCoords, patchCoords, │ │ │ │ │ +1206 patchTable, │ │ │ │ │ +1207 deviceContext); │ │ │ │ │ +1208 } else { │ │ │ │ │ +1209 // Create an instance on demand (slow) │ │ │ │ │ +1210 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +1211 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +1212 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +1213 deviceContext); │ │ │ │ │ +1214 if (instance) { │ │ │ │ │ +1215 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1216 srcBuffer, srcDesc, │ │ │ │ │ +1217 dstBuffer, dstDesc, │ │ │ │ │ +1218 numPatchCoords, patchCoords, │ │ │ │ │ +1219 patchTable, │ │ │ │ │ +1220 deviceContext); │ │ │ │ │ +1221 delete instance; │ │ │ │ │ +1222 return r; │ │ │ │ │ +1223 } │ │ │ │ │ +1224 return false; │ │ │ │ │ +1225 } │ │ │ │ │ +1226 } │ │ │ │ │ +1227 │ │ │ │ │ +1255 template │ │ │ │ │ +_1_2_5_7 bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1258 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1259 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1260 int numPatchCoords, │ │ │ │ │ +1261 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1262 PATCH_TABLE *patchTable, │ │ │ │ │ +1263 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ +1264 │ │ │ │ │ +1265 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ +1266 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ +1267 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +1268 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +1269 numPatchCoords, │ │ │ │ │ +1270 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ +1271 patchTable->GetVaryingPatchArrays(), │ │ │ │ │ +1272 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +1273 patchTable->GetPatchParamBuffer(), │ │ │ │ │ +1274 deviceContext │ │ │ │ │ +1275 ); │ │ │ │ │ +1276 } │ │ │ │ │ +1277 │ │ │ │ │ +1323 template │ │ │ │ │ +_1_3_2_5 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1326 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1327 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1328 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1329 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1330 int numPatchCoords, │ │ │ │ │ +1331 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1332 PATCH_TABLE *patchTable, │ │ │ │ │ +1333 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +1334 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ +1335 │ │ │ │ │ +1336 if (instance) { │ │ │ │ │ +1337 return instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1338 srcBuffer, srcDesc, │ │ │ │ │ +1339 dstBuffer, dstDesc, │ │ │ │ │ +1340 duBuffer, duDesc, │ │ │ │ │ +1341 dvBuffer, dvDesc, │ │ │ │ │ +1342 numPatchCoords, patchCoords, │ │ │ │ │ +1343 patchTable, │ │ │ │ │ +1344 deviceContext); │ │ │ │ │ +1345 } else { │ │ │ │ │ +1346 // Create an instance on demand (slow) │ │ │ │ │ +1347 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +1348 duDesc, dvDesc, │ │ │ │ │ +1349 deviceContext); │ │ │ │ │ +1350 if (instance) { │ │ │ │ │ +1351 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1352 srcBuffer, srcDesc, │ │ │ │ │ +1353 dstBuffer, dstDesc, │ │ │ │ │ +1354 duBuffer, duDesc, │ │ │ │ │ +1355 dvBuffer, dvDesc, │ │ │ │ │ +1356 numPatchCoords, patchCoords, │ │ │ │ │ +1357 patchTable, │ │ │ │ │ +1358 deviceContext); │ │ │ │ │ +1359 delete instance; │ │ │ │ │ +1360 return r; │ │ │ │ │ +1361 } │ │ │ │ │ +1362 return false; │ │ │ │ │ +1363 } │ │ │ │ │ +1364 } │ │ │ │ │ +1365 │ │ │ │ │ +1405 template │ │ │ │ │ +_1_4_0_7 bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1408 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1409 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1410 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1411 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1412 int numPatchCoords, │ │ │ │ │ +1413 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1414 PATCH_TABLE *patchTable, │ │ │ │ │ +1415 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ +1416 │ │ │ │ │ +1417 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ +1418 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ +1419 duBuffer->BindMTLBuffer(deviceContext), duDesc, │ │ │ │ │ +1420 dvBuffer->BindMTLBuffer(deviceContext), dvDesc, │ │ │ │ │ +1421 numPatchCoords, │ │ │ │ │ +1422 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ +1423 patchTable->GetVaryingPatchArrays(), │ │ │ │ │ +1424 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +1425 patchTable->GetPatchParamBuffer(), │ │ │ │ │ +1426 deviceContext │ │ │ │ │ +1427 ); │ │ │ │ │ +1428 } │ │ │ │ │ +1429 │ │ │ │ │ +1430 │ │ │ │ │ +1494 template │ │ │ │ │ +_1_4_9_6 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1497 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1498 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1499 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1500 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1501 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +1502 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +1503 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +1504 int numPatchCoords, │ │ │ │ │ +1505 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1506 PATCH_TABLE *patchTable, │ │ │ │ │ +1507 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +1508 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ +1509 │ │ │ │ │ +1510 if (instance) { │ │ │ │ │ +1511 return instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1512 srcBuffer, srcDesc, │ │ │ │ │ +1513 dstBuffer, dstDesc, │ │ │ │ │ +1514 duBuffer, duDesc, │ │ │ │ │ +1515 dvBuffer, dvDesc, │ │ │ │ │ +1516 duuBuffer, duuDesc, │ │ │ │ │ +1517 duvBuffer, duvDesc, │ │ │ │ │ +1518 dvvBuffer, dvvDesc, │ │ │ │ │ +1519 numPatchCoords, patchCoords, │ │ │ │ │ +1520 patchTable, │ │ │ │ │ +1521 deviceContext); │ │ │ │ │ +1522 } else { │ │ │ │ │ +1523 // Create an instance on demand (slow) │ │ │ │ │ +1524 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +1525 duDesc, dvDesc, │ │ │ │ │ +1526 duuDesc, duvDesc, dvvDesc, │ │ │ │ │ +1527 deviceContext); │ │ │ │ │ +1528 if (instance) { │ │ │ │ │ +1529 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1530 srcBuffer, srcDesc, │ │ │ │ │ +1531 dstBuffer, dstDesc, │ │ │ │ │ +1532 duBuffer, duDesc, │ │ │ │ │ +1533 dvBuffer, dvDesc, │ │ │ │ │ +1534 duuBuffer, duuDesc, │ │ │ │ │ +1535 duvBuffer, duvDesc, │ │ │ │ │ +1536 dvvBuffer, dvvDesc, │ │ │ │ │ +1537 numPatchCoords, patchCoords, │ │ │ │ │ +1538 patchTable, │ │ │ │ │ +1539 deviceContext); │ │ │ │ │ +1540 delete instance; │ │ │ │ │ +1541 return r; │ │ │ │ │ +1542 } │ │ │ │ │ +1543 return false; │ │ │ │ │ +1544 } │ │ │ │ │ +1545 } │ │ │ │ │ +1546 │ │ │ │ │ +1604 template │ │ │ │ │ +_1_6_0_6 bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +1607 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1608 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1609 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1610 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1611 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +1612 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +1613 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +1614 int numPatchCoords, │ │ │ │ │ +1615 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1616 PATCH_TABLE *patchTable, │ │ │ │ │ +1617 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ +1618 │ │ │ │ │ +1619 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ +1620 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ +1621 duBuffer->BindMTLBuffer(deviceContext), duDesc, │ │ │ │ │ +1622 dvBuffer->BindMTLBuffer(deviceContext), dvDesc, │ │ │ │ │ +1623 duuBuffer->BindMTLBuffer(deviceContext), duuDesc, │ │ │ │ │ +1624 duvBuffer->BindMTLBuffer(deviceContext), duvDesc, │ │ │ │ │ +1625 dvvBuffer->BindMTLBuffer(deviceContext), dvvDesc, │ │ │ │ │ +1626 numPatchCoords, │ │ │ │ │ +1627 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ +1628 patchTable->GetVaryingPatchArrays(), │ │ │ │ │ +1629 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +1630 patchTable->GetPatchParamBuffer(), │ │ │ │ │ +1631 deviceContext │ │ │ │ │ +1632 ); │ │ │ │ │ +1633 } │ │ │ │ │ +1634 │ │ │ │ │ +1670 template │ │ │ │ │ +_1_6_7_2 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1673 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1674 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1675 int numPatchCoords, │ │ │ │ │ +1676 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1677 PATCH_TABLE *patchTable, │ │ │ │ │ +1678 int fvarChannel, │ │ │ │ │ +1679 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +1680 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ +1681 │ │ │ │ │ +1682 if (instance) { │ │ │ │ │ +1683 return instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1684 srcBuffer, srcDesc, │ │ │ │ │ +1685 dstBuffer, dstDesc, │ │ │ │ │ +1686 numPatchCoords, patchCoords, │ │ │ │ │ +1687 patchTable, │ │ │ │ │ +1688 fvarChannel, │ │ │ │ │ +1689 deviceContext); │ │ │ │ │ +1690 } else { │ │ │ │ │ +1691 // Create an instance on demand (slow) │ │ │ │ │ +1692 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +1693 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +1694 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +1695 deviceContext); │ │ │ │ │ +1696 if (instance) { │ │ │ │ │ +1697 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1698 srcBuffer, srcDesc, │ │ │ │ │ +1699 dstBuffer, dstDesc, │ │ │ │ │ +1700 numPatchCoords, patchCoords, │ │ │ │ │ +1701 patchTable, │ │ │ │ │ +1702 fvarChannel, │ │ │ │ │ +1703 deviceContext); │ │ │ │ │ +1704 delete instance; │ │ │ │ │ +1705 return r; │ │ │ │ │ +1706 } │ │ │ │ │ +1707 return false; │ │ │ │ │ +1708 } │ │ │ │ │ +1709 } │ │ │ │ │ +1710 │ │ │ │ │ +1740 template │ │ │ │ │ +_1_7_4_2 bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1743 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1744 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1745 int numPatchCoords, │ │ │ │ │ +1746 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1747 PATCH_TABLE *patchTable, │ │ │ │ │ +1748 int fvarChannel, │ │ │ │ │ +1749 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ +1750 │ │ │ │ │ +1751 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ +1752 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ +1753 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +1754 0, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +1755 numPatchCoords, │ │ │ │ │ +1756 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ +1757 patchTable->GetFVarPatchArrays(fvarChannel), │ │ │ │ │ +1758 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +1759 patchTable->GetFVarPatchParamBuffer(fvarChannel), │ │ │ │ │ +1760 deviceContext │ │ │ │ │ +1761 ); │ │ │ │ │ +1762 } │ │ │ │ │ +1763 │ │ │ │ │ +1811 template │ │ │ │ │ +_1_8_1_3 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1814 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1815 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1816 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1817 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1818 int numPatchCoords, │ │ │ │ │ +1819 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1820 PATCH_TABLE *patchTable, │ │ │ │ │ +1821 int fvarChannel, │ │ │ │ │ +1822 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +1823 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ +1824 │ │ │ │ │ +1825 if (instance) { │ │ │ │ │ +1826 return instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1827 srcBuffer, srcDesc, │ │ │ │ │ +1828 dstBuffer, dstDesc, │ │ │ │ │ +1829 duBuffer, duDesc, │ │ │ │ │ +1830 dvBuffer, dvDesc, │ │ │ │ │ +1831 numPatchCoords, patchCoords, │ │ │ │ │ +1832 patchTable, │ │ │ │ │ +1833 fvarChannel, │ │ │ │ │ +1834 deviceContext); │ │ │ │ │ +1835 } else { │ │ │ │ │ +1836 // Create an instance on demand (slow) │ │ │ │ │ +1837 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +1838 duDesc, dvDesc, │ │ │ │ │ +1839 deviceContext); │ │ │ │ │ +1840 if (instance) { │ │ │ │ │ +1841 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1842 srcBuffer, srcDesc, │ │ │ │ │ +1843 dstBuffer, dstDesc, │ │ │ │ │ +1844 duBuffer, duDesc, │ │ │ │ │ +1845 dvBuffer, dvDesc, │ │ │ │ │ +1846 numPatchCoords, patchCoords, │ │ │ │ │ +1847 patchTable, │ │ │ │ │ +1848 fvarChannel, │ │ │ │ │ +1849 deviceContext); │ │ │ │ │ +1850 delete instance; │ │ │ │ │ +1851 return r; │ │ │ │ │ +1852 } │ │ │ │ │ +1853 return false; │ │ │ │ │ +1854 } │ │ │ │ │ +1855 } │ │ │ │ │ +1856 │ │ │ │ │ +1898 template │ │ │ │ │ +_1_9_0_0 bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1901 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1902 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1903 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1904 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1905 int numPatchCoords, │ │ │ │ │ +1906 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1907 PATCH_TABLE *patchTable, │ │ │ │ │ +1908 int fvarChannel, │ │ │ │ │ +1909 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ +1910 │ │ │ │ │ +1911 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ +1912 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ +1913 duBuffer->BindMTLBuffer(deviceContext), duDesc, │ │ │ │ │ +1914 dvBuffer->BindMTLBuffer(deviceContext), dvDesc, │ │ │ │ │ +1915 numPatchCoords, │ │ │ │ │ +1916 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ +1917 patchTable->GetFVarPatchArrays(fvarChannel), │ │ │ │ │ +1918 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +1919 patchTable->GetFVarPatchParamBuffer(fvarChannel), │ │ │ │ │ +1920 deviceContext │ │ │ │ │ +1921 ); │ │ │ │ │ +1922 } │ │ │ │ │ +1923 │ │ │ │ │ +1989 template │ │ │ │ │ +_1_9_9_1 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1992 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1993 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1994 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1995 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1996 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +1997 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +1998 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +1999 int numPatchCoords, │ │ │ │ │ +2000 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +2001 PATCH_TABLE *patchTable, │ │ │ │ │ +2002 int fvarChannel, │ │ │ │ │ +2003 _M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +2004 _M_T_L_C_o_n_t_e_x_t* deviceContext) { │ │ │ │ │ +2005 │ │ │ │ │ +2006 if (instance) { │ │ │ │ │ +2007 return instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +2008 srcBuffer, srcDesc, │ │ │ │ │ +2009 dstBuffer, dstDesc, │ │ │ │ │ +2010 duBuffer, duDesc, │ │ │ │ │ +2011 dvBuffer, dvDesc, │ │ │ │ │ +2012 duuBuffer, duuDesc, │ │ │ │ │ +2013 duvBuffer, duvDesc, │ │ │ │ │ +2014 dvvBuffer, dvvDesc, │ │ │ │ │ +2015 numPatchCoords, patchCoords, │ │ │ │ │ +2016 patchTable, │ │ │ │ │ +2017 fvarChannel, │ │ │ │ │ +2018 deviceContext); │ │ │ │ │ +2019 } else { │ │ │ │ │ +2020 // Create an instance on demand (slow) │ │ │ │ │ +2021 instance = Create(srcDesc, dstDesc, │ │ │ │ │ +2022 duDesc, dvDesc, │ │ │ │ │ +2023 duuDesc, duvDesc, dvvDesc, │ │ │ │ │ +2024 deviceContext); │ │ │ │ │ +2025 if (instance) { │ │ │ │ │ +2026 bool r = instance->_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +2027 srcBuffer, srcDesc, │ │ │ │ │ +2028 dstBuffer, dstDesc, │ │ │ │ │ +2029 duBuffer, duDesc, │ │ │ │ │ +2030 dvBuffer, dvDesc, │ │ │ │ │ +2031 duuBuffer, duuDesc, │ │ │ │ │ +2032 duvBuffer, duvDesc, │ │ │ │ │ +2033 dvvBuffer, dvvDesc, │ │ │ │ │ +2034 numPatchCoords, patchCoords, │ │ │ │ │ +2035 patchTable, │ │ │ │ │ +2036 fvarChannel, │ │ │ │ │ +2037 deviceContext); │ │ │ │ │ +2038 delete instance; │ │ │ │ │ +2039 return r; │ │ │ │ │ +2040 } │ │ │ │ │ +2041 return false; │ │ │ │ │ +2042 } │ │ │ │ │ +2043 } │ │ │ │ │ +2044 │ │ │ │ │ +2104 template │ │ │ │ │ +_2_1_0_6 bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +2107 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +2108 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +2109 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +2110 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +2111 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +2112 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +2113 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +2114 int numPatchCoords, │ │ │ │ │ +2115 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +2116 PATCH_TABLE *patchTable, │ │ │ │ │ +2117 int fvarChannel, │ │ │ │ │ +2118 _M_T_L_C_o_n_t_e_x_t* deviceContext) const { │ │ │ │ │ +2119 │ │ │ │ │ +2120 return EvalPatches(srcBuffer->BindMTLBuffer(deviceContext), srcDesc, │ │ │ │ │ +2121 dstBuffer->BindMTLBuffer(deviceContext), dstDesc, │ │ │ │ │ +2122 duBuffer->BindMTLBuffer(deviceContext), duDesc, │ │ │ │ │ +2123 dvBuffer->BindMTLBuffer(deviceContext), dvDesc, │ │ │ │ │ +2124 duuBuffer->BindMTLBuffer(deviceContext), duuDesc, │ │ │ │ │ +2125 duvBuffer->BindMTLBuffer(deviceContext), duvDesc, │ │ │ │ │ +2126 dvvBuffer->BindMTLBuffer(deviceContext), dvvDesc, │ │ │ │ │ +2127 numPatchCoords, │ │ │ │ │ +2128 patchCoords->BindMTLBuffer(deviceContext), │ │ │ │ │ +2129 patchTable->GetFVarPatchArrays(fvarChannel), │ │ │ │ │ +2130 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +2131 patchTable->GetFVarPatchParamBuffer(fvarChannel), │ │ │ │ │ +2132 fvarChannel, │ │ │ │ │ +2133 deviceContext │ │ │ │ │ +2134 ); │ │ │ │ │ +2135 } │ │ │ │ │ +2136 │ │ │ │ │ +_2_1_3_8 bool _C_o_m_p_i_l_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +2139 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +2140 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +2141 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +2142 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +2143 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +2144 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +2145 _M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +2146 │ │ │ │ │ +_2_1_4_8 static void _S_y_n_c_h_r_o_n_i_z_e(_M_T_L_C_o_n_t_e_x_t* context); │ │ │ │ │ +2149 │ │ │ │ │ +2150 private: │ │ │ │ │ +2151 │ │ │ │ │ +2152 id _computeLibrary; │ │ │ │ │ +2153 id _evalStencils; │ │ │ │ │ +2154 id _evalPatches; │ │ │ │ │ +2155 id _parameterBuffer; │ │ │ │ │ +2156 │ │ │ │ │ +2157 int _workGroupSize; │ │ │ │ │ +2158}; │ │ │ │ │ +2159 │ │ │ │ │ +2160} //end namespace Osd │ │ │ │ │ +2161 │ │ │ │ │ +2162} //end namespace OPENSUBDIV_VERSION │ │ │ │ │ +2163using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +2164 │ │ │ │ │ +2165} //end namespace OpenSubdiv │ │ │ │ │ +2166 │ │ │ │ │ +2167#endif // OPENSUBDIV3_OSD_MTL_COMPUTE_EVALUATOR_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_A_r_r_a_y_V_e_c_t_o_r │ │ │ │ │ +std::vector< PatchArray > PatchArrayVector │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_1_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +Stencil table class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_L_i_m_i_t_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +Limit stencil table class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_5_8_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ +data buffers.... │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_n_t_e_x_t │ │ │ │ │ DDeeffiinniittiioonn _m_t_l_C_o_m_m_o_n_._h_:_4_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_3_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_V_B_O │ │ │ │ │ -id< MTLBuffer > BindVBO(MTLContext *context) │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_5_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -CPUMTLVertexBuffer(int numElements, int numVertices) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_r_e_a_t_e │ │ │ │ │ -static CPUMTLVertexBuffer * Create(int numElements, int numVertices, MTLContext │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +MTLStencilTable(Far::LimitStencilTable const *stencilTable, MTLContext │ │ │ │ │ *context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_E_l_e_m_e_n_t_s │ │ │ │ │ -int GetNumElements() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_4_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_U_p_d_a_t_e_D_a_t_a │ │ │ │ │ -void UpdateData(const float *src, int startVertex, int numVertices, MTLContext │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_u_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetDuWeightsBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_~_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +~MTLStencilTable() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_v_v_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetDvvWeightsBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +MTLStencilTable(Far::StencilTable const *stencilTable, MTLContext *context) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_u_u_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetDuuWeightsBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_u_v_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetDuvWeightsBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_N_u_m_S_t_e_n_c_i_l_s │ │ │ │ │ +int GetNumStencils() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_I_n_d_i_c_e_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetIndicesBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_S_i_z_e_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetSizesBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_O_f_f_s_e_t_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetOffsetsBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetWeightsBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ +static MTLStencilTable * Create(STENCIL_TABLE *stencilTable, DEVICE_CONTEXT │ │ │ │ │ +context) │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_D_v_W_e_i_g_h_t_s_B_u_f_f_e_r │ │ │ │ │ +id< MTLBuffer > GetDvWeightsBuffer() const │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +bool EvalStencils(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > │ │ │ │ │ +duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, id< MTLBuffer > duuBuffer, BufferDescriptor │ │ │ │ │ +const &duuDesc, id< MTLBuffer > duvBuffer, BufferDescriptor const &duvDesc, id< │ │ │ │ │ +MTLBuffer > dvvBuffer, BufferDescriptor const &dvvDesc, id< MTLBuffer > │ │ │ │ │ +sizesBuffer, id< MTLBuffer > offsetsBuffer, id< MTLBuffer > indicesBuffer, id< │ │ │ │ │ +MTLBuffer > weightsBuffer, id< MTLBuffer > duWeightsBuffer, id< MTLBuffer > │ │ │ │ │ +dvWeightsBuffer, id< MTLBuffer > duuWeightsBuffer, id< MTLBuffer > │ │ │ │ │ +duvWeightsBuffer, id< MTLBuffer > dvvWeightsBuffer, int start, int end, │ │ │ │ │ +MTLContext *context) const │ │ │ │ │ +Dispatch the MTL compute kernel on GPU asynchronously returns false if the │ │ │ │ │ +kernel hasn't been compile... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ +*patchTable, MTLComputeEvaluator *instance, MTLContext *context) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, │ │ │ │ │ +MTLComputeEvaluator const *instance, MTLContext *context) │ │ │ │ │ +Generic static stencil function. This function has a same signature as other │ │ │ │ │ +device kernels have so t... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_3_1_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ +_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ +DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, │ │ │ │ │ +MTLComputeEvaluator const *instance, MTLContext *deviceContext) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_9_9_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +MTLComputeEvaluator() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_~_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +~MTLComputeEvaluator() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator │ │ │ │ │ +const *instance, MTLContext *context) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_0_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_I_n_s_t_a_n_t_i_a_t_a_b_l_e │ │ │ │ │ +bool Instantiatable │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ +*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ +BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, MTLContext *deviceContext) const │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_6_0_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, │ │ │ │ │ +MTLComputeEvaluator const *instance, MTLContext *context) │ │ │ │ │ +Generic static stencil function. This function has a same signature as other │ │ │ │ │ +device kernels have so t... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_2_2_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ +_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLContext │ │ │ │ │ +*deviceContext) const │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_9_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ +_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ +numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int │ │ │ │ │ +fvarChannel, MTLComputeEvaluator const *instance, MTLContext *deviceContext) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_6_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator │ │ │ │ │ +const *instance, MTLContext *deviceContext) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_4_9_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const │ │ │ │ │ +*stencilTable, MTLContext *context) const │ │ │ │ │ +Generic stencil function. │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_3_7_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +bool EvalPatches(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > │ │ │ │ │ +duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, id< MTLBuffer > duuBuffer, BufferDescriptor │ │ │ │ │ +const &duuDesc, id< MTLBuffer > duvBuffer, BufferDescriptor const &duvDesc, id< │ │ │ │ │ +MTLBuffer > dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, id< │ │ │ │ │ +MTLBuffer > patchCoordsBuffer, const PatchArrayVector &patchArrays, id< │ │ │ │ │ +MTLBuffer > patchIndexBuffer, id< MTLBuffer > patchParamsBuffer, MTLContext │ │ │ │ │ +*context) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ +_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, │ │ │ │ │ +MTLContext *deviceContext) const │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_2_1_0_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_S_y_n_c_h_r_o_n_i_z_e │ │ │ │ │ +static void Synchronize(MTLContext *context) │ │ │ │ │ +Wait for the dispatched kernel to finish. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, STENCIL_TABLE const *stencilTable, MTLContext *context) const │ │ │ │ │ +Generic stencil function. │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_4_3_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ +*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ +BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator *instance, │ │ │ │ │ +MTLContext *context) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_8_8_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ +_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ +numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int │ │ │ │ │ +fvarChannel, MTLContext *deviceContext) const │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_7_4_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ +numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, │ │ │ │ │ +MTLComputeEvaluator const *instance, MTLContext *deviceContext) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_1_9_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ +*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ +BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, MTLContext │ │ │ │ │ +*context) const │ │ │ │ │ +Generic stencil function. │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_0_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +bool EvalStencils(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > │ │ │ │ │ +duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, id< MTLBuffer > sizesBuffer, id< MTLBuffer > │ │ │ │ │ +offsetsBuffer, id< MTLBuffer > indicesBuffer, id< MTLBuffer > weightsBuffer, │ │ │ │ │ +id< MTLBuffer > duWeightsBuffer, id< MTLBuffer > dvWeightsBuffer, int start, │ │ │ │ │ +int end, MTLContext *context) const │ │ │ │ │ +Dispatch the MTL compute kernel on GPU asynchronously returns false if the │ │ │ │ │ +kernel hasn't been compile... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ +_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ +DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, int fvarChannel, MTLComputeEvaluator │ │ │ │ │ +const *instance, MTLContext *deviceContext) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_8_1_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext *context) │ │ │ │ │ +const │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE │ │ │ │ │ +const *stencilTable, MTLComputeEvaluator const *instance, MTLContext *context) │ │ │ │ │ +Generic static stencil function. This function has a same signature as other │ │ │ │ │ +device kernels have so t... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_4_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, MTLComputeEvaluator const *instance, │ │ │ │ │ +MTLContext *deviceContext) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_3_2_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ +*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ +BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, MTLContext *context) const │ │ │ │ │ +Generic limit eval function with derivatives. This function has a same │ │ │ │ │ +signature as other device kern... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_1_0_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ +*patchTable, MTLContext *context) const │ │ │ │ │ +Generic limit eval function with derivatives. This function has a same │ │ │ │ │ +signature as other device kern... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_0_2_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ +*patchTable, MTLContext *deviceContext) const │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_4_0_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, MTLContext │ │ │ │ │ +*deviceContext) const │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_2_5_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_r_e_a_t_e │ │ │ │ │ +static MTLComputeEvaluator * Create(BufferDescriptor const &srcDesc, │ │ │ │ │ +BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, │ │ │ │ │ +BufferDescriptor const &dvDesc, MTLContext *context) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_r_e_a_t_e │ │ │ │ │ +static MTLComputeEvaluator * Create(BufferDescriptor const &srcDesc, │ │ │ │ │ +BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, │ │ │ │ │ +BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, │ │ │ │ │ +BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, MTLContext │ │ │ │ │ *context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s │ │ │ │ │ -int GetNumVertices() const │ │ │ │ │ -DDeeffiinniittiioonn _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_5_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_M_T_L_B_u_f_f_e_r │ │ │ │ │ -id< MTLBuffer > BindMTLBuffer(MTLContext *context) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_C_p_u_B_u_f_f_e_r │ │ │ │ │ -float * BindCpuBuffer() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_P_U_M_T_L_V_e_r_t_e_x_B_u_f_f_e_r_:_:_a_l_l_o_c_a_t_e │ │ │ │ │ -bool allocate(MTLContext *context) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_o_m_p_i_l_e │ │ │ │ │ +bool Compile(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, │ │ │ │ │ +BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, │ │ │ │ │ +BufferDescriptor const &duuDesc, BufferDescriptor const &duvDesc, │ │ │ │ │ +BufferDescriptor const &dvvDesc, MTLContext *context) │ │ │ │ │ +Configure compute pipline state. Returns false if it fails to create the │ │ │ │ │ +pipeline state. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_M_T_L_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +bool EvalPatches(id< MTLBuffer > srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +id< MTLBuffer > dstBuffer, BufferDescriptor const &dstDesc, id< MTLBuffer > │ │ │ │ │ +duBuffer, BufferDescriptor const &duDesc, id< MTLBuffer > dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, int numPatchCoords, id< MTLBuffer > │ │ │ │ │ +patchCoordsBuffer, const PatchArrayVector &patchArrays, id< MTLBuffer > │ │ │ │ │ +patchIndexBuffer, id< MTLBuffer > patchParamsBuffer, MTLContext *context) const │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _m_t_l_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ + * _m_t_l_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00827_source.html │ │ │ │ @@ -160,15 +160,15 @@ │ │ │ │
72
│ │ │ │
73} // end namespace OPENSUBDIV_VERSION
│ │ │ │
74using namespace OPENSUBDIV_VERSION;
│ │ │ │
75
│ │ │ │
76} // end namespace OpenSubdiv
│ │ │ │
77
│ │ │ │
78#endif // OPENSUBDIV3_OSD_HLSL_PATCH_SHADER_SOURCE_H
│ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │
Provides shader source which can be used by client code.
│ │ │ │
static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │
static std::string GetPatchDrawingShaderSource()
Returns shader source which can be used while drawing piecewise parametric patches resulting from sub...
│ │ │ │
static std::string GetDomainShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │
static std::string GetHullShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │
static std::string GetPatchBasisShaderSource()
Returns shader source which can be used to evaluate position and first and second derivatives on piec...
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00830_source.html │ │ │ │ @@ -143,15 +143,15 @@ │ │ │ │
42
│ │ │ │
43} // end namespace OPENSUBDIV_VERSION
│ │ │ │
44using namespace OPENSUBDIV_VERSION;
│ │ │ │
45
│ │ │ │
46} // end namespace OpenSubdiv
│ │ │ │
47
│ │ │ │
48#endif // OPENSUBDIV3_OSD_D3D11MESH_H
│ │ │ │ - │ │ │ │ + │ │ │ │
MeshInterface< D3D11PatchTable > D3D11MeshInterface
Definition d3d11Mesh.h:38
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
cpuD3D11VertexBuffer.h File Reference
│ │ │ │ +
d3d11ComputeEvaluator.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include <cstddef>
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  CpuD3D11VertexBuffer
 Concrete vertex buffer class for Cpu subdivision and DirectX drawing. More...
class  D3D11StencilTable
 D3D11 stencil table. More...
 
class  D3D11ComputeEvaluator
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,25 +1,28 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -cpuD3D11VertexBuffer.h File Reference │ │ │ │ │ +d3d11ComputeEvaluator.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include │ │ │ │ │ +#include "_._._/_o_s_d_/_b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -  Concrete vertex buffer class for Cpu subdivision and DirectX drawing. │ │ │ │ │ - _M_o_r_e_._._. │ │ │ │ │ +class   _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +  D3D11 stencil table. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +class   _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │ +  │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _c_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ + * _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00842.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,4 @@ │ │ │ │ │ var a00842 = [ │ │ │ │ │ - ["CpuD3D11VertexBuffer", "a01161.html", "a01161"] │ │ │ │ │ + ["D3D11StencilTable", "a01197.html", "a01197"], │ │ │ │ │ + ["D3D11ComputeEvaluator", "a01201.html", "a01201"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00842_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/cpuD3D11VertexBuffer.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/d3d11ComputeEvaluator.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
cpuD3D11VertexBuffer.h
│ │ │ │ +
d3d11ComputeEvaluator.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2013 Pixar
│ │ │ │ +
2// Copyright 2015 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -119,91 +119,225 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29#include <cstddef>
│ │ │ │ -
30
│ │ │ │ +
29
│ │ │ │ +
30struct ID3D11DeviceContext;
│ │ │ │
31struct ID3D11Buffer;
│ │ │ │ -
32struct ID3D11Device;
│ │ │ │ -
33struct ID3D11DeviceContext;
│ │ │ │ -
34
│ │ │ │ -
35namespace OpenSubdiv {
│ │ │ │ -
36namespace OPENSUBDIV_VERSION {
│ │ │ │ +
32struct ID3D11ComputeShader;
│ │ │ │ +
33struct ID3D11ClassLinkage;
│ │ │ │ +
34struct ID3D11ClassInstance;
│ │ │ │ +
35struct ID3D11ShaderResourceView;
│ │ │ │ +
36struct ID3D11UnorderedAccessView;
│ │ │ │
37
│ │ │ │ -
38namespace Osd {
│ │ │ │ +
38#include "../osd/bufferDescriptor.h"
│ │ │ │
39
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
49public:
│ │ │ │ -
51 static CpuD3D11VertexBuffer * Create(int numElements, int numVertices,
│ │ │ │ -
52 ID3D11DeviceContext *deviceContext);
│ │ │ │ -
53
│ │ │ │ - │ │ │ │ -
56
│ │ │ │ -
59 void UpdateData(const float *src, int startVertex, int numVertices,
│ │ │ │ -
60 void *deviceContext = NULL);
│ │ │ │ -
61
│ │ │ │ -
63 int GetNumElements() const;
│ │ │ │ -
64
│ │ │ │ -
66 int GetNumVertices() const;
│ │ │ │ -
67
│ │ │ │ -
69 float * BindCpuBuffer();
│ │ │ │ -
70
│ │ │ │ -
72 ID3D11Buffer *BindD3D11Buffer(ID3D11DeviceContext *deviceContext);
│ │ │ │ +
40namespace OpenSubdiv {
│ │ │ │ +
41namespace OPENSUBDIV_VERSION {
│ │ │ │ +
42
│ │ │ │ +
43namespace Far {
│ │ │ │ +
44 class StencilTable;
│ │ │ │ +
45}
│ │ │ │ +
46
│ │ │ │ +
47namespace Osd {
│ │ │ │ +
48
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
57public:
│ │ │ │ +
58 template <typename DEVICE_CONTEXT>
│ │ │ │ +
│ │ │ │ +
59 static D3D11StencilTable *Create(Far::StencilTable const *stencilTable,
│ │ │ │ +
60 DEVICE_CONTEXT context) {
│ │ │ │ +
61 return new D3D11StencilTable(stencilTable, context->GetDeviceContext());
│ │ │ │ +
62 }
│ │ │ │ +
│ │ │ │ +
63
│ │ │ │ +
│ │ │ │ +
64 static D3D11StencilTable *Create(Far::StencilTable const *stencilTable,
│ │ │ │ +
65 ID3D11DeviceContext *deviceContext) {
│ │ │ │ +
66 return new D3D11StencilTable(stencilTable, deviceContext);
│ │ │ │ +
67 }
│ │ │ │ +
│ │ │ │ +
68
│ │ │ │ + │ │ │ │ +
70 ID3D11DeviceContext *deviceContext);
│ │ │ │ +
71
│ │ │ │ + │ │ │ │
73
│ │ │ │ -
│ │ │ │ -
75 ID3D11Buffer *BindVBO(ID3D11DeviceContext *deviceContext) {
│ │ │ │ -
76 return BindD3D11Buffer(deviceContext);
│ │ │ │ -
77 }
│ │ │ │ -
│ │ │ │ -
78
│ │ │ │ -
79protected:
│ │ │ │ -
81 CpuD3D11VertexBuffer(int numElements, int numVertices);
│ │ │ │ -
82
│ │ │ │ -
83 bool allocate(ID3D11Device *device);
│ │ │ │ -
84
│ │ │ │ -
85private:
│ │ │ │ -
86 int _numElements;
│ │ │ │ -
87 int _numVertices;
│ │ │ │ -
88 ID3D11Buffer *_d3d11Buffer;
│ │ │ │ -
89 float *_cpuBuffer;
│ │ │ │ -
90};
│ │ │ │ +
74 // interfaces needed for D3D11ComputeEvaluator
│ │ │ │ +
75 ID3D11ShaderResourceView *GetSizesSRV() const { return _sizes; }
│ │ │ │ +
76 ID3D11ShaderResourceView *GetOffsetsSRV() const { return _offsets; }
│ │ │ │ +
77 ID3D11ShaderResourceView *GetIndicesSRV() const { return _indices; }
│ │ │ │ +
78 ID3D11ShaderResourceView *GetWeightsSRV() const { return _weights; }
│ │ │ │ +
79 int GetNumStencils() const { return _numStencils; }
│ │ │ │ +
80
│ │ │ │ +
81private:
│ │ │ │ +
82 ID3D11ShaderResourceView *_sizes;
│ │ │ │ +
83 ID3D11ShaderResourceView *_offsets;
│ │ │ │ +
84 ID3D11ShaderResourceView *_indices;
│ │ │ │ +
85 ID3D11ShaderResourceView *_weights;
│ │ │ │ +
86 ID3D11Buffer *_sizesBuffer;
│ │ │ │ +
87 ID3D11Buffer *_offsetsBuffer;
│ │ │ │ +
88 ID3D11Buffer *_indicesBuffer;
│ │ │ │ +
89 ID3D11Buffer *_weightsBuffer;
│ │ │ │ +
90
│ │ │ │ +
91 int _numStencils;
│ │ │ │ +
92};
│ │ │ │
│ │ │ │ -
91
│ │ │ │ -
92} // end namespace Osd
│ │ │ │
93
│ │ │ │ -
94} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
95using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
96
│ │ │ │ -
97} // end namespace OpenSubdiv
│ │ │ │ -
98
│ │ │ │ -
99#endif // OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H
│ │ │ │ - │ │ │ │ -
Concrete vertex buffer class for Cpu subdivision and DirectX drawing.
│ │ │ │ -
static CpuD3D11VertexBuffer * Create(int numElements, int numVertices, ID3D11DeviceContext *deviceContext)
Creator. Returns NULL if error.
│ │ │ │ -
CpuD3D11VertexBuffer(int numElements, int numVertices)
Constructor.
│ │ │ │ -
int GetNumElements() const
Returns how many elements defined in this vertex buffer.
│ │ │ │ -
void UpdateData(const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
│ │ │ │ -
int GetNumVertices() const
Returns how many vertices allocated in this vertex buffer.
│ │ │ │ -
ID3D11Buffer * BindD3D11Buffer(ID3D11DeviceContext *deviceContext)
Returns the D3D11 buffer object.
│ │ │ │ -
float * BindCpuBuffer()
Returns the address of CPU buffer.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
ID3D11Buffer * BindVBO(ID3D11DeviceContext *deviceContext)
Returns the D3D11 buffer object (for Osd::Mesh interface)
│ │ │ │ +
94// ---------------------------------------------------------------------------
│ │ │ │ +
95
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
97public:
│ │ │ │ +
98 typedef bool Instantiatable;
│ │ │ │ + │ │ │ │ +
100 BufferDescriptor const &dstDesc,
│ │ │ │ +
101 BufferDescriptor const &duDesc,
│ │ │ │ +
102 BufferDescriptor const &dvDesc,
│ │ │ │ +
103 ID3D11DeviceContext *deviceContext);
│ │ │ │ +
104
│ │ │ │ + │ │ │ │ +
106 BufferDescriptor const &dstDesc,
│ │ │ │ +
107 BufferDescriptor const &duDesc,
│ │ │ │ +
108 BufferDescriptor const &dvDesc,
│ │ │ │ +
109 BufferDescriptor const &duuDesc,
│ │ │ │ +
110 BufferDescriptor const &duvDesc,
│ │ │ │ +
111 BufferDescriptor const &dvvDesc,
│ │ │ │ +
112 ID3D11DeviceContext *deviceContext);
│ │ │ │ +
113
│ │ │ │ + │ │ │ │ +
116
│ │ │ │ + │ │ │ │ +
119
│ │ │ │ +
147 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
148 static bool EvalStencils(
│ │ │ │ +
149 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
150 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
151 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
152 D3D11ComputeEvaluator const *instance,
│ │ │ │ +
153 ID3D11DeviceContext * deviceContext) {
│ │ │ │ +
154 if (instance) {
│ │ │ │ +
155 return instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ +
156 dstBuffer, dstDesc,
│ │ │ │ +
157 stencilTable,
│ │ │ │ +
158 deviceContext);
│ │ │ │ +
159 } else {
│ │ │ │ +
160 // Create an instance on demand (slow)
│ │ │ │ +
161 (void)deviceContext; // unused
│ │ │ │ +
162 instance = Create(srcDesc, dstDesc,
│ │ │ │ + │ │ │ │ + │ │ │ │ +
165 deviceContext);
│ │ │ │ +
166 if (instance) {
│ │ │ │ +
167 bool r = instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ +
168 dstBuffer, dstDesc,
│ │ │ │ +
169 stencilTable,
│ │ │ │ +
170 deviceContext);
│ │ │ │ +
171 delete instance;
│ │ │ │ +
172 return r;
│ │ │ │ +
173 }
│ │ │ │ +
174 return false;
│ │ │ │ +
175 }
│ │ │ │ +
176 }
│ │ │ │ +
│ │ │ │ +
177
│ │ │ │ +
180 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
182 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
183 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
184 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
185 ID3D11DeviceContext *deviceContext) const {
│ │ │ │ +
186 return EvalStencils(srcBuffer->BindD3D11UAV(deviceContext), srcDesc,
│ │ │ │ +
187 dstBuffer->BindD3D11UAV(deviceContext), dstDesc,
│ │ │ │ +
188 stencilTable->GetSizesSRV(),
│ │ │ │ +
189 stencilTable->GetOffsetsSRV(),
│ │ │ │ +
190 stencilTable->GetIndicesSRV(),
│ │ │ │ +
191 stencilTable->GetWeightsSRV(),
│ │ │ │ +
192 /* start = */ 0,
│ │ │ │ +
193 /* end = */ stencilTable->GetNumStencils(),
│ │ │ │ +
194 deviceContext);
│ │ │ │ +
195 }
│ │ │ │ +
│ │ │ │ +
196
│ │ │ │ +
199 bool EvalStencils(ID3D11UnorderedAccessView *srcSRV,
│ │ │ │ +
200 BufferDescriptor const &srcDesc,
│ │ │ │ +
201 ID3D11UnorderedAccessView *dstUAV,
│ │ │ │ +
202 BufferDescriptor const &dstDesc,
│ │ │ │ +
203 ID3D11ShaderResourceView *sizesSRV,
│ │ │ │ +
204 ID3D11ShaderResourceView *offsetsSRV,
│ │ │ │ +
205 ID3D11ShaderResourceView *indicesSRV,
│ │ │ │ +
206 ID3D11ShaderResourceView *weightsSRV,
│ │ │ │ +
207 int start,
│ │ │ │ +
208 int end,
│ │ │ │ +
209 ID3D11DeviceContext *deviceContext) const;
│ │ │ │ +
210
│ │ │ │ +
212 bool Compile(BufferDescriptor const &srcDesc,
│ │ │ │ +
213 BufferDescriptor const &dstDesc,
│ │ │ │ +
214 ID3D11DeviceContext *deviceContext);
│ │ │ │ +
215
│ │ │ │ +
217 static void Synchronize(ID3D11DeviceContext *deviceContext);
│ │ │ │ +
218
│ │ │ │ +
219private:
│ │ │ │ +
220 ID3D11ComputeShader * _computeShader;
│ │ │ │ +
221 ID3D11ClassLinkage * _classLinkage;
│ │ │ │ +
222 ID3D11ClassInstance * _singleBufferKernel;
│ │ │ │ +
223 ID3D11ClassInstance * _separateBufferKernel;
│ │ │ │ +
224 ID3D11Buffer * _uniformArgs; // uniform parameters for kernels
│ │ │ │ +
225
│ │ │ │ +
226 int _workGroupSize;
│ │ │ │ +
227};
│ │ │ │ +
│ │ │ │ +
228
│ │ │ │ +
229} // end namespace Osd
│ │ │ │ +
230
│ │ │ │ +
231} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
232using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
233
│ │ │ │ +
234} // end namespace OpenSubdiv
│ │ │ │ +
235
│ │ │ │ +
236
│ │ │ │ +
237#endif // OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H
│ │ │ │ + │ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ + │ │ │ │ +
static D3D11StencilTable * Create(Far::StencilTable const *stencilTable, DEVICE_CONTEXT context)
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
D3D11StencilTable(Far::StencilTable const *stencilTable, ID3D11DeviceContext *deviceContext)
│ │ │ │ +
static D3D11StencilTable * Create(Far::StencilTable const *stencilTable, ID3D11DeviceContext *deviceContext)
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
static D3D11ComputeEvaluator * Create(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, ID3D11DeviceContext *deviceContext)
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, D3D11ComputeEvaluator const *instance, ID3D11DeviceContext *deviceContext)
Generic static compute function. This function has a same signature as other device kernels have so t...
│ │ │ │ +
static D3D11ComputeEvaluator * Create(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, ID3D11DeviceContext *deviceContext)
│ │ │ │ + │ │ │ │ +
static void Synchronize(ID3D11DeviceContext *deviceContext)
Wait the dispatched kernel finishes.
│ │ │ │ +
bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, ID3D11DeviceContext *deviceContext) const
│ │ │ │ +
bool Compile(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, ID3D11DeviceContext *deviceContext)
Configure DX kernel. Returns false if it fails to compile the kernel.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
bool EvalStencils(ID3D11UnorderedAccessView *srcSRV, BufferDescriptor const &srcDesc, ID3D11UnorderedAccessView *dstUAV, BufferDescriptor const &dstDesc, ID3D11ShaderResourceView *sizesSRV, ID3D11ShaderResourceView *offsetsSRV, ID3D11ShaderResourceView *indicesSRV, ID3D11ShaderResourceView *weightsSRV, int start, int end, ID3D11DeviceContext *deviceContext) const
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -cpuD3D11VertexBuffer.h │ │ │ │ │ +d3d11ComputeEvaluator.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2013 Pixar │ │ │ │ │ +2// Copyright 2015 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -24,105 +24,272 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29#include │ │ │ │ │ -30 │ │ │ │ │ +29 │ │ │ │ │ +30struct ID3D11DeviceContext; │ │ │ │ │ 31struct ID3D11Buffer; │ │ │ │ │ -32struct ID3D11Device; │ │ │ │ │ -33struct ID3D11DeviceContext; │ │ │ │ │ -34 │ │ │ │ │ -35namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -36namespace OPENSUBDIV_VERSION { │ │ │ │ │ +32struct ID3D11ComputeShader; │ │ │ │ │ +33struct ID3D11ClassLinkage; │ │ │ │ │ +34struct ID3D11ClassInstance; │ │ │ │ │ +35struct ID3D11ShaderResourceView; │ │ │ │ │ +36struct ID3D11UnorderedAccessView; │ │ │ │ │ 37 │ │ │ │ │ -38namespace Osd { │ │ │ │ │ +38#include "../osd/bufferDescriptor.h" │ │ │ │ │ 39 │ │ │ │ │ -_4_8class _C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r { │ │ │ │ │ -49public: │ │ │ │ │ -_5_1 static _C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r * _C_r_e_a_t_e(int numElements, int numVertices, │ │ │ │ │ -52 ID3D11DeviceContext *deviceContext); │ │ │ │ │ -53 │ │ │ │ │ -_5_5 virtual _~_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r(); │ │ │ │ │ -56 │ │ │ │ │ -_5_9 void _U_p_d_a_t_e_D_a_t_a(const float *src, int startVertex, int numVertices, │ │ │ │ │ -60 void *deviceContext = NULL); │ │ │ │ │ -61 │ │ │ │ │ -_6_3 int _G_e_t_N_u_m_E_l_e_m_e_n_t_s() const; │ │ │ │ │ -64 │ │ │ │ │ -_6_6 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s() const; │ │ │ │ │ -67 │ │ │ │ │ -_6_9 float * _B_i_n_d_C_p_u_B_u_f_f_e_r(); │ │ │ │ │ -70 │ │ │ │ │ -_7_2 ID3D11Buffer *_B_i_n_d_D_3_D_1_1_B_u_f_f_e_r(ID3D11DeviceContext *deviceContext); │ │ │ │ │ +40namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +41namespace OPENSUBDIV_VERSION { │ │ │ │ │ +42 │ │ │ │ │ +43namespace Far { │ │ │ │ │ +44 class StencilTable; │ │ │ │ │ +45} │ │ │ │ │ +46 │ │ │ │ │ +47namespace Osd { │ │ │ │ │ +48 │ │ │ │ │ +_5_6class _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e { │ │ │ │ │ +57public: │ │ │ │ │ +58 template │ │ │ │ │ +_5_9 static _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e *_C_r_e_a_t_e(_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e const *stencilTable, │ │ │ │ │ +60 DEVICE_CONTEXT context) { │ │ │ │ │ +61 return new _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e(stencilTable, context->GetDeviceContext()); │ │ │ │ │ +62 } │ │ │ │ │ +63 │ │ │ │ │ +_6_4 static _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e *_C_r_e_a_t_e(_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e const *stencilTable, │ │ │ │ │ +65 ID3D11DeviceContext *deviceContext) { │ │ │ │ │ +66 return new _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e(stencilTable, deviceContext); │ │ │ │ │ +67 } │ │ │ │ │ +68 │ │ │ │ │ +_6_9 _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e(_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e const *stencilTable, │ │ │ │ │ +70 ID3D11DeviceContext *deviceContext); │ │ │ │ │ +71 │ │ │ │ │ +_7_2 _~_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e(); │ │ │ │ │ 73 │ │ │ │ │ -_7_5 ID3D11Buffer *_B_i_n_d_V_B_O(ID3D11DeviceContext *deviceContext) { │ │ │ │ │ -76 return _B_i_n_d_D_3_D_1_1_B_u_f_f_e_r(deviceContext); │ │ │ │ │ -77 } │ │ │ │ │ -78 │ │ │ │ │ -79protected: │ │ │ │ │ -_8_1 _C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r(int numElements, int numVertices); │ │ │ │ │ -82 │ │ │ │ │ -_8_3 bool _a_l_l_o_c_a_t_e(ID3D11Device *device); │ │ │ │ │ -84 │ │ │ │ │ -85private: │ │ │ │ │ -86 int _numElements; │ │ │ │ │ -87 int _numVertices; │ │ │ │ │ -88 ID3D11Buffer *_d3d11Buffer; │ │ │ │ │ -89 float *_cpuBuffer; │ │ │ │ │ -90}; │ │ │ │ │ -91 │ │ │ │ │ -92} // end namespace Osd │ │ │ │ │ +74 // interfaces needed for D3D11ComputeEvaluator │ │ │ │ │ +_7_5 ID3D11ShaderResourceView *_G_e_t_S_i_z_e_s_S_R_V() const { return _sizes; } │ │ │ │ │ +_7_6 ID3D11ShaderResourceView *_G_e_t_O_f_f_s_e_t_s_S_R_V() const { return _offsets; } │ │ │ │ │ +_7_7 ID3D11ShaderResourceView *_G_e_t_I_n_d_i_c_e_s_S_R_V() const { return _indices; } │ │ │ │ │ +_7_8 ID3D11ShaderResourceView *_G_e_t_W_e_i_g_h_t_s_S_R_V() const { return _weights; } │ │ │ │ │ +_7_9 int _G_e_t_N_u_m_S_t_e_n_c_i_l_s() const { return _numStencils; } │ │ │ │ │ +80 │ │ │ │ │ +81private: │ │ │ │ │ +82 ID3D11ShaderResourceView *_sizes; │ │ │ │ │ +83 ID3D11ShaderResourceView *_offsets; │ │ │ │ │ +84 ID3D11ShaderResourceView *_indices; │ │ │ │ │ +85 ID3D11ShaderResourceView *_weights; │ │ │ │ │ +86 ID3D11Buffer *_sizesBuffer; │ │ │ │ │ +87 ID3D11Buffer *_offsetsBuffer; │ │ │ │ │ +88 ID3D11Buffer *_indicesBuffer; │ │ │ │ │ +89 ID3D11Buffer *_weightsBuffer; │ │ │ │ │ +90 │ │ │ │ │ +91 int _numStencils; │ │ │ │ │ +92}; │ │ │ │ │ 93 │ │ │ │ │ -94} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -95using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -96 │ │ │ │ │ -97} // end namespace OpenSubdiv │ │ │ │ │ -98 │ │ │ │ │ -99#endif // OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H │ │ │ │ │ +94// -------------------------------------------------------------------------- │ │ │ │ │ +- │ │ │ │ │ +95 │ │ │ │ │ +_9_6class _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r { │ │ │ │ │ +97public: │ │ │ │ │ +_9_8 typedef bool _I_n_s_t_a_n_t_i_a_t_a_b_l_e; │ │ │ │ │ +_9_9 static _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r * _C_r_e_a_t_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +100 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +101 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +102 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +103 ID3D11DeviceContext *deviceContext); │ │ │ │ │ +104 │ │ │ │ │ +_1_0_5 static _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r * _C_r_e_a_t_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +106 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +107 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +108 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +109 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +110 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +111 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +112 ID3D11DeviceContext *deviceContext); │ │ │ │ │ +113 │ │ │ │ │ +_1_1_5 _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r(); │ │ │ │ │ +116 │ │ │ │ │ +_1_1_8 _~_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r(); │ │ │ │ │ +119 │ │ │ │ │ +147 template │ │ │ │ │ +_1_4_8 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +149 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +150 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +151 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +152 _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ +153 ID3D11DeviceContext * deviceContext) { │ │ │ │ │ +154 if (instance) { │ │ │ │ │ +155 return instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ +156 dstBuffer, dstDesc, │ │ │ │ │ +157 stencilTable, │ │ │ │ │ +158 deviceContext); │ │ │ │ │ +159 } else { │ │ │ │ │ +160 // Create an instance on demand (slow) │ │ │ │ │ +161 (void)deviceContext; // unused │ │ │ │ │ +162 instance = _C_r_e_a_t_e(srcDesc, dstDesc, │ │ │ │ │ +163 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +164 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ +165 deviceContext); │ │ │ │ │ +166 if (instance) { │ │ │ │ │ +167 bool r = instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ +168 dstBuffer, dstDesc, │ │ │ │ │ +169 stencilTable, │ │ │ │ │ +170 deviceContext); │ │ │ │ │ +171 delete instance; │ │ │ │ │ +172 return r; │ │ │ │ │ +173 } │ │ │ │ │ +174 return false; │ │ │ │ │ +175 } │ │ │ │ │ +176 } │ │ │ │ │ +177 │ │ │ │ │ +180 template │ │ │ │ │ +_1_8_1 bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +182 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +183 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +184 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +185 ID3D11DeviceContext *deviceContext) const { │ │ │ │ │ +186 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindD3D11UAV(deviceContext), srcDesc, │ │ │ │ │ +187 dstBuffer->BindD3D11UAV(deviceContext), dstDesc, │ │ │ │ │ +188 stencilTable->GetSizesSRV(), │ │ │ │ │ +189 stencilTable->GetOffsetsSRV(), │ │ │ │ │ +190 stencilTable->GetIndicesSRV(), │ │ │ │ │ +191 stencilTable->GetWeightsSRV(), │ │ │ │ │ +192 /* start = */ 0, │ │ │ │ │ +193 /* end = */ stencilTable->GetNumStencils(), │ │ │ │ │ +194 deviceContext); │ │ │ │ │ +195 } │ │ │ │ │ +196 │ │ │ │ │ +_1_9_9 bool _E_v_a_l_S_t_e_n_c_i_l_s(ID3D11UnorderedAccessView *srcSRV, │ │ │ │ │ +200 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +201 ID3D11UnorderedAccessView *dstUAV, │ │ │ │ │ +202 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +203 ID3D11ShaderResourceView *sizesSRV, │ │ │ │ │ +204 ID3D11ShaderResourceView *offsetsSRV, │ │ │ │ │ +205 ID3D11ShaderResourceView *indicesSRV, │ │ │ │ │ +206 ID3D11ShaderResourceView *weightsSRV, │ │ │ │ │ +207 int start, │ │ │ │ │ +208 int end, │ │ │ │ │ +209 ID3D11DeviceContext *deviceContext) const; │ │ │ │ │ +210 │ │ │ │ │ +_2_1_2 bool _C_o_m_p_i_l_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +213 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +214 ID3D11DeviceContext *deviceContext); │ │ │ │ │ +215 │ │ │ │ │ +_2_1_7 static void _S_y_n_c_h_r_o_n_i_z_e(ID3D11DeviceContext *deviceContext); │ │ │ │ │ +218 │ │ │ │ │ +219private: │ │ │ │ │ +220 ID3D11ComputeShader * _computeShader; │ │ │ │ │ +221 ID3D11ClassLinkage * _classLinkage; │ │ │ │ │ +222 ID3D11ClassInstance * _singleBufferKernel; │ │ │ │ │ +223 ID3D11ClassInstance * _separateBufferKernel; │ │ │ │ │ +224 ID3D11Buffer * _uniformArgs; // uniform parameters for kernels │ │ │ │ │ +225 │ │ │ │ │ +226 int _workGroupSize; │ │ │ │ │ +227}; │ │ │ │ │ +228 │ │ │ │ │ +229} // end namespace Osd │ │ │ │ │ +230 │ │ │ │ │ +231} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +232using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +233 │ │ │ │ │ +234} // end namespace OpenSubdiv │ │ │ │ │ +235 │ │ │ │ │ +236 │ │ │ │ │ +237#endif // OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -Concrete vertex buffer class for Cpu subdivision and DirectX drawing. │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_r_e_a_t_e │ │ │ │ │ -static CpuD3D11VertexBuffer * Create(int numElements, int numVertices, │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +Stencil table class wrapping the template for compatibility. │ │ │ │ │ +DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ +data buffers.... │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +D3D11 stencil table. │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ +static D3D11StencilTable * Create(Far::StencilTable const *stencilTable, │ │ │ │ │ +DEVICE_CONTEXT context) │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_O_f_f_s_e_t_s_S_R_V │ │ │ │ │ +ID3D11ShaderResourceView * GetOffsetsSRV() const │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_N_u_m_S_t_e_n_c_i_l_s │ │ │ │ │ +int GetNumStencils() const │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_I_n_d_i_c_e_s_S_R_V │ │ │ │ │ +ID3D11ShaderResourceView * GetIndicesSRV() const │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_~_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +~D3D11StencilTable() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ +D3D11StencilTable(Far::StencilTable const *stencilTable, ID3D11DeviceContext │ │ │ │ │ +*deviceContext) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ +static D3D11StencilTable * Create(Far::StencilTable const *stencilTable, │ │ │ │ │ ID3D11DeviceContext *deviceContext) │ │ │ │ │ -Creator. Returns NULL if error. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -CpuD3D11VertexBuffer(int numElements, int numVertices) │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_S_i_z_e_s_S_R_V │ │ │ │ │ +ID3D11ShaderResourceView * GetSizesSRV() const │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_W_e_i_g_h_t_s_S_R_V │ │ │ │ │ +ID3D11ShaderResourceView * GetWeightsSRV() const │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_r_e_a_t_e │ │ │ │ │ +static D3D11ComputeEvaluator * Create(BufferDescriptor const &srcDesc, │ │ │ │ │ +BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, │ │ │ │ │ +BufferDescriptor const &dvDesc, ID3D11DeviceContext *deviceContext) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE │ │ │ │ │ +const *stencilTable, D3D11ComputeEvaluator const *instance, ID3D11DeviceContext │ │ │ │ │ +*deviceContext) │ │ │ │ │ +Generic static compute function. This function has a same signature as other │ │ │ │ │ +device kernels have so t... │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_4_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_r_e_a_t_e │ │ │ │ │ +static D3D11ComputeEvaluator * Create(BufferDescriptor const &srcDesc, │ │ │ │ │ +BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, │ │ │ │ │ +BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, │ │ │ │ │ +BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, │ │ │ │ │ +ID3D11DeviceContext *deviceContext) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_I_n_s_t_a_n_t_i_a_t_a_b_l_e │ │ │ │ │ +bool Instantiatable │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_S_y_n_c_h_r_o_n_i_z_e │ │ │ │ │ +static void Synchronize(ID3D11DeviceContext *deviceContext) │ │ │ │ │ +Wait the dispatched kernel finishes. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const │ │ │ │ │ +*stencilTable, ID3D11DeviceContext *deviceContext) const │ │ │ │ │ +DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_8_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_o_m_p_i_l_e │ │ │ │ │ +bool Compile(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, │ │ │ │ │ +ID3D11DeviceContext *deviceContext) │ │ │ │ │ +Configure DX kernel. Returns false if it fails to compile the kernel. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ +_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +D3D11ComputeEvaluator() │ │ │ │ │ Constructor. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_E_l_e_m_e_n_t_s │ │ │ │ │ -int GetNumElements() const │ │ │ │ │ -Returns how many elements defined in this vertex buffer. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_U_p_d_a_t_e_D_a_t_a │ │ │ │ │ -void UpdateData(const float *src, int startVertex, int numVertices, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s │ │ │ │ │ -int GetNumVertices() const │ │ │ │ │ -Returns how many vertices allocated in this vertex buffer. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_D_3_D_1_1_B_u_f_f_e_r │ │ │ │ │ -ID3D11Buffer * BindD3D11Buffer(ID3D11DeviceContext *deviceContext) │ │ │ │ │ -Returns the D3D11 buffer object. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_C_p_u_B_u_f_f_e_r │ │ │ │ │ -float * BindCpuBuffer() │ │ │ │ │ -Returns the address of CPU buffer. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_a_l_l_o_c_a_t_e │ │ │ │ │ -bool allocate(ID3D11Device *device) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_: │ │ │ │ │ -_~_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -virtual ~CpuD3D11VertexBuffer() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ +_~_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +~D3D11ComputeEvaluator() │ │ │ │ │ Destructor. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_V_B_O │ │ │ │ │ -ID3D11Buffer * BindVBO(ID3D11DeviceContext *deviceContext) │ │ │ │ │ -Returns the D3D11 buffer object (for Osd::Mesh interface) │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_7_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +bool EvalStencils(ID3D11UnorderedAccessView *srcSRV, BufferDescriptor const │ │ │ │ │ +&srcDesc, ID3D11UnorderedAccessView *dstUAV, BufferDescriptor const &dstDesc, │ │ │ │ │ +ID3D11ShaderResourceView *sizesSRV, ID3D11ShaderResourceView *offsetsSRV, │ │ │ │ │ +ID3D11ShaderResourceView *indicesSRV, ID3D11ShaderResourceView *weightsSRV, int │ │ │ │ │ +start, int end, ID3D11DeviceContext *deviceContext) const │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _c_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ + * _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00845.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/d3d11ComputeEvaluator.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/cpuD3D11VertexBuffer.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,45 +90,41 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
d3d11ComputeEvaluator.h File Reference
│ │ │ │ +
cpuD3D11VertexBuffer.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include <cstddef>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  D3D11StencilTable
 D3D11 stencil table. More...
 
class  D3D11ComputeEvaluator
class  CpuD3D11VertexBuffer
 Concrete vertex buffer class for Cpu subdivision and DirectX drawing. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Far
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,28 +1,25 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -d3d11ComputeEvaluator.h File Reference │ │ │ │ │ +cpuD3D11VertexBuffer.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_o_s_d_/_b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -  D3D11 stencil table. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -class   _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ +class   _C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +  Concrete vertex buffer class for Cpu subdivision and DirectX drawing. │ │ │ │ │ + _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r │ │ │ │ │ -  │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ + * _c_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00845.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,3 @@ │ │ │ │ │ var a00845 = [ │ │ │ │ │ - ["D3D11StencilTable", "a01197.html", "a01197"], │ │ │ │ │ - ["D3D11ComputeEvaluator", "a01201.html", "a01201"] │ │ │ │ │ + ["CpuD3D11VertexBuffer", "a01161.html", "a01161"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00845_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/d3d11ComputeEvaluator.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/cpuD3D11VertexBuffer.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
d3d11ComputeEvaluator.h
│ │ │ │ +
cpuD3D11VertexBuffer.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2015 Pixar
│ │ │ │ +
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -119,225 +119,91 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29
│ │ │ │ -
30struct ID3D11DeviceContext;
│ │ │ │ +
29#include <cstddef>
│ │ │ │ +
30
│ │ │ │
31struct ID3D11Buffer;
│ │ │ │ -
32struct ID3D11ComputeShader;
│ │ │ │ -
33struct ID3D11ClassLinkage;
│ │ │ │ -
34struct ID3D11ClassInstance;
│ │ │ │ -
35struct ID3D11ShaderResourceView;
│ │ │ │ -
36struct ID3D11UnorderedAccessView;
│ │ │ │ +
32struct ID3D11Device;
│ │ │ │ +
33struct ID3D11DeviceContext;
│ │ │ │ +
34
│ │ │ │ +
35namespace OpenSubdiv {
│ │ │ │ +
36namespace OPENSUBDIV_VERSION {
│ │ │ │
37
│ │ │ │ -
38#include "../osd/bufferDescriptor.h"
│ │ │ │ +
38namespace Osd {
│ │ │ │
39
│ │ │ │ -
40namespace OpenSubdiv {
│ │ │ │ -
41namespace OPENSUBDIV_VERSION {
│ │ │ │ -
42
│ │ │ │ -
43namespace Far {
│ │ │ │ -
44 class StencilTable;
│ │ │ │ -
45}
│ │ │ │ -
46
│ │ │ │ -
47namespace Osd {
│ │ │ │ -
48
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
57public:
│ │ │ │ -
58 template <typename DEVICE_CONTEXT>
│ │ │ │ -
│ │ │ │ -
59 static D3D11StencilTable *Create(Far::StencilTable const *stencilTable,
│ │ │ │ -
60 DEVICE_CONTEXT context) {
│ │ │ │ -
61 return new D3D11StencilTable(stencilTable, context->GetDeviceContext());
│ │ │ │ -
62 }
│ │ │ │ -
│ │ │ │ -
63
│ │ │ │ -
│ │ │ │ -
64 static D3D11StencilTable *Create(Far::StencilTable const *stencilTable,
│ │ │ │ -
65 ID3D11DeviceContext *deviceContext) {
│ │ │ │ -
66 return new D3D11StencilTable(stencilTable, deviceContext);
│ │ │ │ -
67 }
│ │ │ │ -
│ │ │ │ -
68
│ │ │ │ - │ │ │ │ -
70 ID3D11DeviceContext *deviceContext);
│ │ │ │ -
71
│ │ │ │ - │ │ │ │ +
│ │ │ │ + │ │ │ │ +
49public:
│ │ │ │ +
51 static CpuD3D11VertexBuffer * Create(int numElements, int numVertices,
│ │ │ │ +
52 ID3D11DeviceContext *deviceContext);
│ │ │ │ +
53
│ │ │ │ + │ │ │ │ +
56
│ │ │ │ +
59 void UpdateData(const float *src, int startVertex, int numVertices,
│ │ │ │ +
60 void *deviceContext = NULL);
│ │ │ │ +
61
│ │ │ │ +
63 int GetNumElements() const;
│ │ │ │ +
64
│ │ │ │ +
66 int GetNumVertices() const;
│ │ │ │ +
67
│ │ │ │ +
69 float * BindCpuBuffer();
│ │ │ │ +
70
│ │ │ │ +
72 ID3D11Buffer *BindD3D11Buffer(ID3D11DeviceContext *deviceContext);
│ │ │ │
73
│ │ │ │ -
74 // interfaces needed for D3D11ComputeEvaluator
│ │ │ │ -
75 ID3D11ShaderResourceView *GetSizesSRV() const { return _sizes; }
│ │ │ │ -
76 ID3D11ShaderResourceView *GetOffsetsSRV() const { return _offsets; }
│ │ │ │ -
77 ID3D11ShaderResourceView *GetIndicesSRV() const { return _indices; }
│ │ │ │ -
78 ID3D11ShaderResourceView *GetWeightsSRV() const { return _weights; }
│ │ │ │ -
79 int GetNumStencils() const { return _numStencils; }
│ │ │ │ -
80
│ │ │ │ -
81private:
│ │ │ │ -
82 ID3D11ShaderResourceView *_sizes;
│ │ │ │ -
83 ID3D11ShaderResourceView *_offsets;
│ │ │ │ -
84 ID3D11ShaderResourceView *_indices;
│ │ │ │ -
85 ID3D11ShaderResourceView *_weights;
│ │ │ │ -
86 ID3D11Buffer *_sizesBuffer;
│ │ │ │ -
87 ID3D11Buffer *_offsetsBuffer;
│ │ │ │ -
88 ID3D11Buffer *_indicesBuffer;
│ │ │ │ -
89 ID3D11Buffer *_weightsBuffer;
│ │ │ │ -
90
│ │ │ │ -
91 int _numStencils;
│ │ │ │ -
92};
│ │ │ │ +
│ │ │ │ +
75 ID3D11Buffer *BindVBO(ID3D11DeviceContext *deviceContext) {
│ │ │ │ +
76 return BindD3D11Buffer(deviceContext);
│ │ │ │ +
77 }
│ │ │ │ +
│ │ │ │ +
78
│ │ │ │ +
79protected:
│ │ │ │ +
81 CpuD3D11VertexBuffer(int numElements, int numVertices);
│ │ │ │ +
82
│ │ │ │ +
83 bool allocate(ID3D11Device *device);
│ │ │ │ +
84
│ │ │ │ +
85private:
│ │ │ │ +
86 int _numElements;
│ │ │ │ +
87 int _numVertices;
│ │ │ │ +
88 ID3D11Buffer *_d3d11Buffer;
│ │ │ │ +
89 float *_cpuBuffer;
│ │ │ │ +
90};
│ │ │ │
│ │ │ │ +
91
│ │ │ │ +
92} // end namespace Osd
│ │ │ │
93
│ │ │ │ -
94// ---------------------------------------------------------------------------
│ │ │ │ -
95
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
97public:
│ │ │ │ -
98 typedef bool Instantiatable;
│ │ │ │ - │ │ │ │ -
100 BufferDescriptor const &dstDesc,
│ │ │ │ -
101 BufferDescriptor const &duDesc,
│ │ │ │ -
102 BufferDescriptor const &dvDesc,
│ │ │ │ -
103 ID3D11DeviceContext *deviceContext);
│ │ │ │ -
104
│ │ │ │ - │ │ │ │ -
106 BufferDescriptor const &dstDesc,
│ │ │ │ -
107 BufferDescriptor const &duDesc,
│ │ │ │ -
108 BufferDescriptor const &dvDesc,
│ │ │ │ -
109 BufferDescriptor const &duuDesc,
│ │ │ │ -
110 BufferDescriptor const &duvDesc,
│ │ │ │ -
111 BufferDescriptor const &dvvDesc,
│ │ │ │ -
112 ID3D11DeviceContext *deviceContext);
│ │ │ │ -
113
│ │ │ │ - │ │ │ │ -
116
│ │ │ │ - │ │ │ │ -
119
│ │ │ │ -
147 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
148 static bool EvalStencils(
│ │ │ │ -
149 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
150 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
151 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
152 D3D11ComputeEvaluator const *instance,
│ │ │ │ -
153 ID3D11DeviceContext * deviceContext) {
│ │ │ │ -
154 if (instance) {
│ │ │ │ -
155 return instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ -
156 dstBuffer, dstDesc,
│ │ │ │ -
157 stencilTable,
│ │ │ │ -
158 deviceContext);
│ │ │ │ -
159 } else {
│ │ │ │ -
160 // Create an instance on demand (slow)
│ │ │ │ -
161 (void)deviceContext; // unused
│ │ │ │ -
162 instance = Create(srcDesc, dstDesc,
│ │ │ │ - │ │ │ │ - │ │ │ │ -
165 deviceContext);
│ │ │ │ -
166 if (instance) {
│ │ │ │ -
167 bool r = instance->EvalStencils(srcBuffer, srcDesc,
│ │ │ │ -
168 dstBuffer, dstDesc,
│ │ │ │ -
169 stencilTable,
│ │ │ │ -
170 deviceContext);
│ │ │ │ -
171 delete instance;
│ │ │ │ -
172 return r;
│ │ │ │ -
173 }
│ │ │ │ -
174 return false;
│ │ │ │ -
175 }
│ │ │ │ -
176 }
│ │ │ │ -
│ │ │ │ -
177
│ │ │ │ -
180 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
182 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
183 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
184 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
185 ID3D11DeviceContext *deviceContext) const {
│ │ │ │ -
186 return EvalStencils(srcBuffer->BindD3D11UAV(deviceContext), srcDesc,
│ │ │ │ -
187 dstBuffer->BindD3D11UAV(deviceContext), dstDesc,
│ │ │ │ -
188 stencilTable->GetSizesSRV(),
│ │ │ │ -
189 stencilTable->GetOffsetsSRV(),
│ │ │ │ -
190 stencilTable->GetIndicesSRV(),
│ │ │ │ -
191 stencilTable->GetWeightsSRV(),
│ │ │ │ -
192 /* start = */ 0,
│ │ │ │ -
193 /* end = */ stencilTable->GetNumStencils(),
│ │ │ │ -
194 deviceContext);
│ │ │ │ -
195 }
│ │ │ │ -
│ │ │ │ -
196
│ │ │ │ -
199 bool EvalStencils(ID3D11UnorderedAccessView *srcSRV,
│ │ │ │ -
200 BufferDescriptor const &srcDesc,
│ │ │ │ -
201 ID3D11UnorderedAccessView *dstUAV,
│ │ │ │ -
202 BufferDescriptor const &dstDesc,
│ │ │ │ -
203 ID3D11ShaderResourceView *sizesSRV,
│ │ │ │ -
204 ID3D11ShaderResourceView *offsetsSRV,
│ │ │ │ -
205 ID3D11ShaderResourceView *indicesSRV,
│ │ │ │ -
206 ID3D11ShaderResourceView *weightsSRV,
│ │ │ │ -
207 int start,
│ │ │ │ -
208 int end,
│ │ │ │ -
209 ID3D11DeviceContext *deviceContext) const;
│ │ │ │ -
210
│ │ │ │ -
212 bool Compile(BufferDescriptor const &srcDesc,
│ │ │ │ -
213 BufferDescriptor const &dstDesc,
│ │ │ │ -
214 ID3D11DeviceContext *deviceContext);
│ │ │ │ -
215
│ │ │ │ -
217 static void Synchronize(ID3D11DeviceContext *deviceContext);
│ │ │ │ -
218
│ │ │ │ -
219private:
│ │ │ │ -
220 ID3D11ComputeShader * _computeShader;
│ │ │ │ -
221 ID3D11ClassLinkage * _classLinkage;
│ │ │ │ -
222 ID3D11ClassInstance * _singleBufferKernel;
│ │ │ │ -
223 ID3D11ClassInstance * _separateBufferKernel;
│ │ │ │ -
224 ID3D11Buffer * _uniformArgs; // uniform parameters for kernels
│ │ │ │ -
225
│ │ │ │ -
226 int _workGroupSize;
│ │ │ │ -
227};
│ │ │ │ -
│ │ │ │ -
228
│ │ │ │ -
229} // end namespace Osd
│ │ │ │ -
230
│ │ │ │ -
231} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
232using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
233
│ │ │ │ -
234} // end namespace OpenSubdiv
│ │ │ │ -
235
│ │ │ │ -
236
│ │ │ │ -
237#endif // OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H
│ │ │ │ - │ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ - │ │ │ │ -
static D3D11StencilTable * Create(Far::StencilTable const *stencilTable, DEVICE_CONTEXT context)
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
D3D11StencilTable(Far::StencilTable const *stencilTable, ID3D11DeviceContext *deviceContext)
│ │ │ │ -
static D3D11StencilTable * Create(Far::StencilTable const *stencilTable, ID3D11DeviceContext *deviceContext)
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
static D3D11ComputeEvaluator * Create(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, ID3D11DeviceContext *deviceContext)
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, D3D11ComputeEvaluator const *instance, ID3D11DeviceContext *deviceContext)
Generic static compute function. This function has a same signature as other device kernels have so t...
│ │ │ │ -
static D3D11ComputeEvaluator * Create(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, ID3D11DeviceContext *deviceContext)
│ │ │ │ - │ │ │ │ -
static void Synchronize(ID3D11DeviceContext *deviceContext)
Wait the dispatched kernel finishes.
│ │ │ │ -
bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, ID3D11DeviceContext *deviceContext) const
│ │ │ │ -
bool Compile(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, ID3D11DeviceContext *deviceContext)
Configure DX kernel. Returns false if it fails to compile the kernel.
│ │ │ │ - │ │ │ │ - │ │ │ │ -
bool EvalStencils(ID3D11UnorderedAccessView *srcSRV, BufferDescriptor const &srcDesc, ID3D11UnorderedAccessView *dstUAV, BufferDescriptor const &dstDesc, ID3D11ShaderResourceView *sizesSRV, ID3D11ShaderResourceView *offsetsSRV, ID3D11ShaderResourceView *indicesSRV, ID3D11ShaderResourceView *weightsSRV, int start, int end, ID3D11DeviceContext *deviceContext) const
│ │ │ │ +
94} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
95using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
96
│ │ │ │ +
97} // end namespace OpenSubdiv
│ │ │ │ +
98
│ │ │ │ +
99#endif // OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H
│ │ │ │ + │ │ │ │ +
Concrete vertex buffer class for Cpu subdivision and DirectX drawing.
│ │ │ │ +
static CpuD3D11VertexBuffer * Create(int numElements, int numVertices, ID3D11DeviceContext *deviceContext)
Creator. Returns NULL if error.
│ │ │ │ +
CpuD3D11VertexBuffer(int numElements, int numVertices)
Constructor.
│ │ │ │ +
int GetNumElements() const
Returns how many elements defined in this vertex buffer.
│ │ │ │ +
void UpdateData(const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
│ │ │ │ +
int GetNumVertices() const
Returns how many vertices allocated in this vertex buffer.
│ │ │ │ +
ID3D11Buffer * BindD3D11Buffer(ID3D11DeviceContext *deviceContext)
Returns the D3D11 buffer object.
│ │ │ │ +
float * BindCpuBuffer()
Returns the address of CPU buffer.
│ │ │ │ + │ │ │ │ + │ │ │ │ +
ID3D11Buffer * BindVBO(ID3D11DeviceContext *deviceContext)
Returns the D3D11 buffer object (for Osd::Mesh interface)
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -d3d11ComputeEvaluator.h │ │ │ │ │ +cpuD3D11VertexBuffer.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2015 Pixar │ │ │ │ │ +2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -24,272 +24,105 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29 │ │ │ │ │ -30struct ID3D11DeviceContext; │ │ │ │ │ +29#include │ │ │ │ │ +30 │ │ │ │ │ 31struct ID3D11Buffer; │ │ │ │ │ -32struct ID3D11ComputeShader; │ │ │ │ │ -33struct ID3D11ClassLinkage; │ │ │ │ │ -34struct ID3D11ClassInstance; │ │ │ │ │ -35struct ID3D11ShaderResourceView; │ │ │ │ │ -36struct ID3D11UnorderedAccessView; │ │ │ │ │ +32struct ID3D11Device; │ │ │ │ │ +33struct ID3D11DeviceContext; │ │ │ │ │ +34 │ │ │ │ │ +35namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +36namespace OPENSUBDIV_VERSION { │ │ │ │ │ 37 │ │ │ │ │ -38#include "../osd/bufferDescriptor.h" │ │ │ │ │ +38namespace Osd { │ │ │ │ │ 39 │ │ │ │ │ -40namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -41namespace OPENSUBDIV_VERSION { │ │ │ │ │ -42 │ │ │ │ │ -43namespace Far { │ │ │ │ │ -44 class StencilTable; │ │ │ │ │ -45} │ │ │ │ │ -46 │ │ │ │ │ -47namespace Osd { │ │ │ │ │ -48 │ │ │ │ │ -_5_6class _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e { │ │ │ │ │ -57public: │ │ │ │ │ -58 template │ │ │ │ │ -_5_9 static _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e *_C_r_e_a_t_e(_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e const *stencilTable, │ │ │ │ │ -60 DEVICE_CONTEXT context) { │ │ │ │ │ -61 return new _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e(stencilTable, context->GetDeviceContext()); │ │ │ │ │ -62 } │ │ │ │ │ -63 │ │ │ │ │ -_6_4 static _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e *_C_r_e_a_t_e(_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e const *stencilTable, │ │ │ │ │ -65 ID3D11DeviceContext *deviceContext) { │ │ │ │ │ -66 return new _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e(stencilTable, deviceContext); │ │ │ │ │ -67 } │ │ │ │ │ -68 │ │ │ │ │ -_6_9 _D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e(_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e const *stencilTable, │ │ │ │ │ -70 ID3D11DeviceContext *deviceContext); │ │ │ │ │ -71 │ │ │ │ │ -_7_2 _~_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e(); │ │ │ │ │ +_4_8class _C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r { │ │ │ │ │ +49public: │ │ │ │ │ +_5_1 static _C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r * _C_r_e_a_t_e(int numElements, int numVertices, │ │ │ │ │ +52 ID3D11DeviceContext *deviceContext); │ │ │ │ │ +53 │ │ │ │ │ +_5_5 virtual _~_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r(); │ │ │ │ │ +56 │ │ │ │ │ +_5_9 void _U_p_d_a_t_e_D_a_t_a(const float *src, int startVertex, int numVertices, │ │ │ │ │ +60 void *deviceContext = NULL); │ │ │ │ │ +61 │ │ │ │ │ +_6_3 int _G_e_t_N_u_m_E_l_e_m_e_n_t_s() const; │ │ │ │ │ +64 │ │ │ │ │ +_6_6 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s() const; │ │ │ │ │ +67 │ │ │ │ │ +_6_9 float * _B_i_n_d_C_p_u_B_u_f_f_e_r(); │ │ │ │ │ +70 │ │ │ │ │ +_7_2 ID3D11Buffer *_B_i_n_d_D_3_D_1_1_B_u_f_f_e_r(ID3D11DeviceContext *deviceContext); │ │ │ │ │ 73 │ │ │ │ │ -74 // interfaces needed for D3D11ComputeEvaluator │ │ │ │ │ -_7_5 ID3D11ShaderResourceView *_G_e_t_S_i_z_e_s_S_R_V() const { return _sizes; } │ │ │ │ │ -_7_6 ID3D11ShaderResourceView *_G_e_t_O_f_f_s_e_t_s_S_R_V() const { return _offsets; } │ │ │ │ │ -_7_7 ID3D11ShaderResourceView *_G_e_t_I_n_d_i_c_e_s_S_R_V() const { return _indices; } │ │ │ │ │ -_7_8 ID3D11ShaderResourceView *_G_e_t_W_e_i_g_h_t_s_S_R_V() const { return _weights; } │ │ │ │ │ -_7_9 int _G_e_t_N_u_m_S_t_e_n_c_i_l_s() const { return _numStencils; } │ │ │ │ │ -80 │ │ │ │ │ -81private: │ │ │ │ │ -82 ID3D11ShaderResourceView *_sizes; │ │ │ │ │ -83 ID3D11ShaderResourceView *_offsets; │ │ │ │ │ -84 ID3D11ShaderResourceView *_indices; │ │ │ │ │ -85 ID3D11ShaderResourceView *_weights; │ │ │ │ │ -86 ID3D11Buffer *_sizesBuffer; │ │ │ │ │ -87 ID3D11Buffer *_offsetsBuffer; │ │ │ │ │ -88 ID3D11Buffer *_indicesBuffer; │ │ │ │ │ -89 ID3D11Buffer *_weightsBuffer; │ │ │ │ │ -90 │ │ │ │ │ -91 int _numStencils; │ │ │ │ │ -92}; │ │ │ │ │ +_7_5 ID3D11Buffer *_B_i_n_d_V_B_O(ID3D11DeviceContext *deviceContext) { │ │ │ │ │ +76 return _B_i_n_d_D_3_D_1_1_B_u_f_f_e_r(deviceContext); │ │ │ │ │ +77 } │ │ │ │ │ +78 │ │ │ │ │ +79protected: │ │ │ │ │ +_8_1 _C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r(int numElements, int numVertices); │ │ │ │ │ +82 │ │ │ │ │ +_8_3 bool _a_l_l_o_c_a_t_e(ID3D11Device *device); │ │ │ │ │ +84 │ │ │ │ │ +85private: │ │ │ │ │ +86 int _numElements; │ │ │ │ │ +87 int _numVertices; │ │ │ │ │ +88 ID3D11Buffer *_d3d11Buffer; │ │ │ │ │ +89 float *_cpuBuffer; │ │ │ │ │ +90}; │ │ │ │ │ +91 │ │ │ │ │ +92} // end namespace Osd │ │ │ │ │ 93 │ │ │ │ │ -94// -------------------------------------------------------------------------- │ │ │ │ │ -- │ │ │ │ │ -95 │ │ │ │ │ -_9_6class _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r { │ │ │ │ │ -97public: │ │ │ │ │ -_9_8 typedef bool _I_n_s_t_a_n_t_i_a_t_a_b_l_e; │ │ │ │ │ -_9_9 static _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r * _C_r_e_a_t_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -100 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -101 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -102 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -103 ID3D11DeviceContext *deviceContext); │ │ │ │ │ -104 │ │ │ │ │ -_1_0_5 static _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r * _C_r_e_a_t_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -106 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -107 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -108 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -109 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -110 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -111 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -112 ID3D11DeviceContext *deviceContext); │ │ │ │ │ -113 │ │ │ │ │ -_1_1_5 _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r(); │ │ │ │ │ -116 │ │ │ │ │ -_1_1_8 _~_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r(); │ │ │ │ │ -119 │ │ │ │ │ -147 template │ │ │ │ │ -_1_4_8 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -149 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -150 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -151 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -152 _D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r const *instance, │ │ │ │ │ -153 ID3D11DeviceContext * deviceContext) { │ │ │ │ │ -154 if (instance) { │ │ │ │ │ -155 return instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ -156 dstBuffer, dstDesc, │ │ │ │ │ -157 stencilTable, │ │ │ │ │ -158 deviceContext); │ │ │ │ │ -159 } else { │ │ │ │ │ -160 // Create an instance on demand (slow) │ │ │ │ │ -161 (void)deviceContext; // unused │ │ │ │ │ -162 instance = _C_r_e_a_t_e(srcDesc, dstDesc, │ │ │ │ │ -163 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -164 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(), │ │ │ │ │ -165 deviceContext); │ │ │ │ │ -166 if (instance) { │ │ │ │ │ -167 bool r = instance->_E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer, srcDesc, │ │ │ │ │ -168 dstBuffer, dstDesc, │ │ │ │ │ -169 stencilTable, │ │ │ │ │ -170 deviceContext); │ │ │ │ │ -171 delete instance; │ │ │ │ │ -172 return r; │ │ │ │ │ -173 } │ │ │ │ │ -174 return false; │ │ │ │ │ -175 } │ │ │ │ │ -176 } │ │ │ │ │ -177 │ │ │ │ │ -180 template │ │ │ │ │ -_1_8_1 bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -182 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -183 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -184 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -185 ID3D11DeviceContext *deviceContext) const { │ │ │ │ │ -186 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindD3D11UAV(deviceContext), srcDesc, │ │ │ │ │ -187 dstBuffer->BindD3D11UAV(deviceContext), dstDesc, │ │ │ │ │ -188 stencilTable->GetSizesSRV(), │ │ │ │ │ -189 stencilTable->GetOffsetsSRV(), │ │ │ │ │ -190 stencilTable->GetIndicesSRV(), │ │ │ │ │ -191 stencilTable->GetWeightsSRV(), │ │ │ │ │ -192 /* start = */ 0, │ │ │ │ │ -193 /* end = */ stencilTable->GetNumStencils(), │ │ │ │ │ -194 deviceContext); │ │ │ │ │ -195 } │ │ │ │ │ -196 │ │ │ │ │ -_1_9_9 bool _E_v_a_l_S_t_e_n_c_i_l_s(ID3D11UnorderedAccessView *srcSRV, │ │ │ │ │ -200 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -201 ID3D11UnorderedAccessView *dstUAV, │ │ │ │ │ -202 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -203 ID3D11ShaderResourceView *sizesSRV, │ │ │ │ │ -204 ID3D11ShaderResourceView *offsetsSRV, │ │ │ │ │ -205 ID3D11ShaderResourceView *indicesSRV, │ │ │ │ │ -206 ID3D11ShaderResourceView *weightsSRV, │ │ │ │ │ -207 int start, │ │ │ │ │ -208 int end, │ │ │ │ │ -209 ID3D11DeviceContext *deviceContext) const; │ │ │ │ │ -210 │ │ │ │ │ -_2_1_2 bool _C_o_m_p_i_l_e(_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -213 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -214 ID3D11DeviceContext *deviceContext); │ │ │ │ │ -215 │ │ │ │ │ -_2_1_7 static void _S_y_n_c_h_r_o_n_i_z_e(ID3D11DeviceContext *deviceContext); │ │ │ │ │ -218 │ │ │ │ │ -219private: │ │ │ │ │ -220 ID3D11ComputeShader * _computeShader; │ │ │ │ │ -221 ID3D11ClassLinkage * _classLinkage; │ │ │ │ │ -222 ID3D11ClassInstance * _singleBufferKernel; │ │ │ │ │ -223 ID3D11ClassInstance * _separateBufferKernel; │ │ │ │ │ -224 ID3D11Buffer * _uniformArgs; // uniform parameters for kernels │ │ │ │ │ -225 │ │ │ │ │ -226 int _workGroupSize; │ │ │ │ │ -227}; │ │ │ │ │ -228 │ │ │ │ │ -229} // end namespace Osd │ │ │ │ │ -230 │ │ │ │ │ -231} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -232using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -233 │ │ │ │ │ -234} // end namespace OpenSubdiv │ │ │ │ │ -235 │ │ │ │ │ -236 │ │ │ │ │ -237#endif // OPENSUBDIV3_OSD_D3D11_COMPUTE_EVALUATOR_H │ │ │ │ │ +94} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +95using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +96 │ │ │ │ │ +97} // end namespace OpenSubdiv │ │ │ │ │ +98 │ │ │ │ │ +99#endif // OPENSUBDIV3_OSD_CPU_D3D11_VERTEX_BUFFER_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_F_a_r_:_:_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -Stencil table class wrapping the template for compatibility. │ │ │ │ │ -DDeeffiinniittiioonn _s_t_e_n_c_i_l_T_a_b_l_e_._h_:_2_7_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ -data buffers.... │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -D3D11 stencil table. │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ -static D3D11StencilTable * Create(Far::StencilTable const *stencilTable, │ │ │ │ │ -DEVICE_CONTEXT context) │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_5_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_O_f_f_s_e_t_s_S_R_V │ │ │ │ │ -ID3D11ShaderResourceView * GetOffsetsSRV() const │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_N_u_m_S_t_e_n_c_i_l_s │ │ │ │ │ -int GetNumStencils() const │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_I_n_d_i_c_e_s_S_R_V │ │ │ │ │ -ID3D11ShaderResourceView * GetIndicesSRV() const │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_~_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -~D3D11StencilTable() │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e │ │ │ │ │ -D3D11StencilTable(Far::StencilTable const *stencilTable, ID3D11DeviceContext │ │ │ │ │ -*deviceContext) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_C_r_e_a_t_e │ │ │ │ │ -static D3D11StencilTable * Create(Far::StencilTable const *stencilTable, │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +Concrete vertex buffer class for Cpu subdivision and DirectX drawing. │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_4_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_r_e_a_t_e │ │ │ │ │ +static CpuD3D11VertexBuffer * Create(int numElements, int numVertices, │ │ │ │ │ ID3D11DeviceContext *deviceContext) │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_6_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_S_i_z_e_s_S_R_V │ │ │ │ │ -ID3D11ShaderResourceView * GetSizesSRV() const │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_S_t_e_n_c_i_l_T_a_b_l_e_:_:_G_e_t_W_e_i_g_h_t_s_S_R_V │ │ │ │ │ -ID3D11ShaderResourceView * GetWeightsSRV() const │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_7_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_r_e_a_t_e │ │ │ │ │ -static D3D11ComputeEvaluator * Create(BufferDescriptor const &srcDesc, │ │ │ │ │ -BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, │ │ │ │ │ -BufferDescriptor const &dvDesc, ID3D11DeviceContext *deviceContext) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE │ │ │ │ │ -const *stencilTable, D3D11ComputeEvaluator const *instance, ID3D11DeviceContext │ │ │ │ │ -*deviceContext) │ │ │ │ │ -Generic static compute function. This function has a same signature as other │ │ │ │ │ -device kernels have so t... │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_4_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_r_e_a_t_e │ │ │ │ │ -static D3D11ComputeEvaluator * Create(BufferDescriptor const &srcDesc, │ │ │ │ │ -BufferDescriptor const &dstDesc, BufferDescriptor const &duDesc, │ │ │ │ │ -BufferDescriptor const &dvDesc, BufferDescriptor const &duuDesc, │ │ │ │ │ -BufferDescriptor const &duvDesc, BufferDescriptor const &dvvDesc, │ │ │ │ │ -ID3D11DeviceContext *deviceContext) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_I_n_s_t_a_n_t_i_a_t_a_b_l_e │ │ │ │ │ -bool Instantiatable │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_9_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_S_y_n_c_h_r_o_n_i_z_e │ │ │ │ │ -static void Synchronize(ID3D11DeviceContext *deviceContext) │ │ │ │ │ -Wait the dispatched kernel finishes. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const │ │ │ │ │ -*stencilTable, ID3D11DeviceContext *deviceContext) const │ │ │ │ │ -DDeeffiinniittiioonn _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h_:_1_8_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_C_o_m_p_i_l_e │ │ │ │ │ -bool Compile(BufferDescriptor const &srcDesc, BufferDescriptor const &dstDesc, │ │ │ │ │ -ID3D11DeviceContext *deviceContext) │ │ │ │ │ -Configure DX kernel. Returns false if it fails to compile the kernel. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ -_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ -D3D11ComputeEvaluator() │ │ │ │ │ +Creator. Returns NULL if error. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +CpuD3D11VertexBuffer(int numElements, int numVertices) │ │ │ │ │ Constructor. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_: │ │ │ │ │ -_~_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r │ │ │ │ │ -~D3D11ComputeEvaluator() │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_E_l_e_m_e_n_t_s │ │ │ │ │ +int GetNumElements() const │ │ │ │ │ +Returns how many elements defined in this vertex buffer. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_U_p_d_a_t_e_D_a_t_a │ │ │ │ │ +void UpdateData(const float *src, int startVertex, int numVertices, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s │ │ │ │ │ +int GetNumVertices() const │ │ │ │ │ +Returns how many vertices allocated in this vertex buffer. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_D_3_D_1_1_B_u_f_f_e_r │ │ │ │ │ +ID3D11Buffer * BindD3D11Buffer(ID3D11DeviceContext *deviceContext) │ │ │ │ │ +Returns the D3D11 buffer object. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_C_p_u_B_u_f_f_e_r │ │ │ │ │ +float * BindCpuBuffer() │ │ │ │ │ +Returns the address of CPU buffer. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_a_l_l_o_c_a_t_e │ │ │ │ │ +bool allocate(ID3D11Device *device) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_: │ │ │ │ │ +_~_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +virtual ~CpuD3D11VertexBuffer() │ │ │ │ │ Destructor. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_D_3_D_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -bool EvalStencils(ID3D11UnorderedAccessView *srcSRV, BufferDescriptor const │ │ │ │ │ -&srcDesc, ID3D11UnorderedAccessView *dstUAV, BufferDescriptor const &dstDesc, │ │ │ │ │ -ID3D11ShaderResourceView *sizesSRV, ID3D11ShaderResourceView *offsetsSRV, │ │ │ │ │ -ID3D11ShaderResourceView *indicesSRV, ID3D11ShaderResourceView *weightsSRV, int │ │ │ │ │ -start, int end, ID3D11DeviceContext *deviceContext) const │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_V_B_O │ │ │ │ │ +ID3D11Buffer * BindVBO(ID3D11DeviceContext *deviceContext) │ │ │ │ │ +Returns the D3D11 buffer object (for Osd::Mesh interface) │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_7_5 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _d_3_d_1_1_C_o_m_p_u_t_e_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ + * _c_p_u_D_3_D_1_1_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00848.html │ │ │ │ @@ -94,17 +94,17 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
glComputeEvaluator.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/opengl.h"
│ │ │ │ +#include "../osd/opengl.h"
│ │ │ │ #include "../osd/types.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00848_source.html │ │ │ │ @@ -1176,19 +1176,19 @@ │ │ │ │
2109} // end namespace OPENSUBDIV_VERSION
│ │ │ │
2110using namespace OPENSUBDIV_VERSION;
│ │ │ │
2111
│ │ │ │
2112} // end namespace OpenSubdiv
│ │ │ │
2113
│ │ │ │
2114
│ │ │ │
2115#endif // OPENSUBDIV3_OSD_GL_COMPUTE_EVALUATOR_H
│ │ │ │ - │ │ │ │ + │ │ │ │
std::vector< PatchArray > PatchArrayVector
Definition types.h:132
│ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ -
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ +
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
GLStencilTableSSBO(Far::LimitStencilTable const *limitStencilTable)
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00851.html │ │ │ │ @@ -94,17 +94,17 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
glXFBEvaluator.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/opengl.h"
│ │ │ │ +#include "../osd/opengl.h"
│ │ │ │ #include "../osd/types.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  GLStencilTableSSBO
 GL stencil table (Shader Storage buffer) More...
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00851_source.html │ │ │ │ @@ -1245,19 +1245,19 @@ │ │ │ │
2187} // end namespace OPENSUBDIV_VERSION
│ │ │ │
2188using namespace OPENSUBDIV_VERSION;
│ │ │ │
2189
│ │ │ │
2190} // end namespace OpenSubdiv
│ │ │ │
2191
│ │ │ │
2192
│ │ │ │
2193#endif // OPENSUBDIV3_OSD_GL_XFB_EVALUATOR_H
│ │ │ │ - │ │ │ │ + │ │ │ │
std::vector< PatchArray > PatchArrayVector
Definition types.h:132
│ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ -
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ +
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ │ │ │ │ │ │ │ │
static GLStencilTableTBO * Create(Far::StencilTable const *stencilTable, void *deviceContext=NULL)
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00854_source.html │ │ │ │ @@ -163,15 +163,15 @@ │ │ │ │
75
│ │ │ │
76} // end namespace OPENSUBDIV_VERSION
│ │ │ │
77using namespace OPENSUBDIV_VERSION;
│ │ │ │
78
│ │ │ │
79} // end namespace OpenSubdiv
│ │ │ │
80
│ │ │ │
81#endif // OPENSUBDIV3_OSD_GLSL_PATCH_SHADER_SOURCE
│ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │
Provides shader source which can be used by client code.
│ │ │ │
static std::string GetVertexShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │
static std::string GetPatchDrawingShaderSource()
Returns shader source which can be used while drawing piecewise parametric patches resulting from sub...
│ │ │ │
static std::string GetTessEvalShaderSource(Far::PatchDescriptor::Type type)
│ │ │ │
static std::string GetPatchBasisShaderSource()
Returns shader source which can be used to evaluate position and first and second derivatives on piec...
│ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00857_source.html │ │ │ │ @@ -143,15 +143,15 @@ │ │ │ │
42
│ │ │ │
43} // end namespace OPENSUBDIV_VERSION
│ │ │ │
44using namespace OPENSUBDIV_VERSION;
│ │ │ │
45
│ │ │ │
46} // end namespace OpenSubdiv
│ │ │ │
47
│ │ │ │
48#endif // OPENSUBDIV3_OSD_GL_MESH_H
│ │ │ │ - │ │ │ │ + │ │ │ │
MeshInterface< GLPatchTable > GLMeshInterface
Definition glMesh.h:38
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
glPatchTable.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include "../osd/nonCopyable.h"
│ │ │ │ -#include "../osd/opengl.h"
│ │ │ │ +#include "../osd/opengl.h"
│ │ │ │ #include "../osd/types.h"
│ │ │ │ #include <vector>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  GLStencilTableTBO
 GL TextureBuffer stencil table. More...
│ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00860_source.html │ │ │ │ @@ -265,15 +265,15 @@ │ │ │ │
150
│ │ │ │
151} // end namespace OPENSUBDIV_VERSION
│ │ │ │
152using namespace OPENSUBDIV_VERSION;
│ │ │ │
153
│ │ │ │
154} // end namespace OpenSubdiv
│ │ │ │
155
│ │ │ │
156#endif // OPENSUBDIV3_OSD_GL_PATCH_TABLE_H
│ │ │ │ - │ │ │ │ + │ │ │ │
std::vector< PatchArray > PatchArrayVector
Definition types.h:132
│ │ │ │
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
PatchArrayVector const & GetPatchArrays() const
Returns the patch arrays for vertex index buffer data.
│ │ │ │
GLuint GetFVarPatchIndexBuffer(int fvarChannel=0) const
Returns the GL index buffer containing face-varying control vertices.
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00863.html │ │ │ │ @@ -94,15 +94,15 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
glVertexBuffer.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/opengl.h"
│ │ │ │ +#include "../osd/opengl.h"
│ │ │ │ #include <cstddef>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00863_source.html │ │ │ │ @@ -169,15 +169,15 @@ │ │ │ │
82
│ │ │ │
83} // end namespace OPENSUBDIV_VERSION
│ │ │ │
84using namespace OPENSUBDIV_VERSION;
│ │ │ │
85
│ │ │ │
86} // end namespace OpenSubdiv
│ │ │ │
87
│ │ │ │
88#endif // OPENSUBDIV3_OSD_GL_VERTEX_BUFFER_H
│ │ │ │ - │ │ │ │ + │ │ │ │
Concrete vertex buffer class for GLSL subdivision and OpenGL drawing.
│ │ │ │ │ │ │ │
GLuint BindVBO(void *deviceContext=NULL)
Returns the GL buffer object.
│ │ │ │
int GetNumElements() const
Returns how many elements defined in this vertex buffer.
│ │ │ │
void UpdateData(const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
│ │ │ │
GLVertexBuffer(int numElements, int numVertices)
Constructor.
│ │ │ │
int GetNumVertices() const
Returns how many vertices allocated in this vertex buffer.
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00866.html │ │ │ │ @@ -95,15 +95,15 @@ │ │ │ │ Classes | │ │ │ │ Namespaces │ │ │ │
cpuGLVertexBuffer.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include <cstddef>
│ │ │ │ -#include "../osd/opengl.h"
│ │ │ │ +#include "../osd/opengl.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  GLVertexBuffer
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00866_source.html │ │ │ │ @@ -173,15 +173,15 @@ │ │ │ │
91
│ │ │ │
92} // end namespace OPENSUBDIV_VERSION
│ │ │ │
93using namespace OPENSUBDIV_VERSION;
│ │ │ │
94
│ │ │ │
95} // end namespace OpenSubdiv
│ │ │ │
96
│ │ │ │
97#endif // OPENSUBDIV3_OSD_CPU_GL_VERTEX_BUFFER_H
│ │ │ │ - │ │ │ │ + │ │ │ │
Concrete vertex buffer class for cpu subdivision and OpenGL drawing.
│ │ │ │
CpuGLVertexBuffer(int numElements, int numVertices)
Constructor.
│ │ │ │ │ │ │ │
int GetNumElements() const
Returns how many elements defined in this vertex buffer.
│ │ │ │
void UpdateData(const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
│ │ │ │
int GetNumVertices() const
Returns how many vertices allocated in this vertex buffer.
│ │ │ │
static CpuGLVertexBuffer * Create(int numElements, int numVertices, void *deviceContext=NULL)
Creator. Returns NULL if error.
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00869.html │ │ │ │ @@ -96,15 +96,15 @@ │ │ │ │ Namespaces │ │ │ │
glLegacyGregoryPatchTable.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include "../far/patchTable.h"
│ │ │ │ #include "../osd/nonCopyable.h"
│ │ │ │ -#include "../osd/opengl.h"
│ │ │ │ +#include "../osd/opengl.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  CpuGLVertexBuffer
 Concrete vertex buffer class for cpu subdivision and OpenGL drawing. More...
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00869_source.html │ │ │ │ @@ -191,15 +191,15 @@ │ │ │ │
80
│ │ │ │
81} // end namespace OPENSUBDIV_VERSION
│ │ │ │
82using namespace OPENSUBDIV_VERSION;
│ │ │ │
83
│ │ │ │
84} // end namespace OpenSubdiv
│ │ │ │
85
│ │ │ │
86#endif // OPENSUBDIV3_OSD_GL_LEGACY_GREGORY_PATCH_TABLE_H
│ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00872.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/tbbKernel.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/ompKernel.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,49 +90,43 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Namespaces | │ │ │ │ Functions
│ │ │ │ -
tbbKernel.h File Reference
│ │ │ │ +
ompKernel.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../far/patchDescriptor.h"
│ │ │ │ -#include "../far/patchParam.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  GLLegacyGregoryPatchTable
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │

│ │ │ │ Functions

void TbbEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)
 
void TbbEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, int start, int end)
 
void TbbEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, float *dstDuu, BufferDescriptor const &dstDuuDesc, float *dstDuv, BufferDescriptor const &dstDuvDesc, float *dstDvv, BufferDescriptor const &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, float const *duuWeights, float const *duvWeights, float const *dvvWeights, int start, int end)
 
void TbbEvalPatches (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrayBuffer, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
 
void TbbEvalPatches (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, float *dstDuu, BufferDescriptor const &dstDuuDesc, float *dstDuv, BufferDescriptor const &dstDuvDesc, float *dstDvv, BufferDescriptor const &dstDvvDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrayBuffer, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
 
void OmpEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)
 
void OmpEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, int start, int end)
 
void OmpEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, float *dstDuu, BufferDescriptor const &dstDuuDesc, float *dstDuv, BufferDescriptor const &dstDuvDesc, float *dstDvv, BufferDescriptor const &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, float const *duuWeights, float const *duvWeights, float const *dvvWeights, int start, int end)
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,59 +1,41 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _N_a_m_e_s_p_a_c_e_s | _F_u_n_c_t_i_o_n_s │ │ │ │ │ -tbbKernel.h File Reference │ │ │ │ │ +ompKernel.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_f_a_r_/_p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ -#include "_._._/_f_a_r_/_p_a_t_c_h_P_a_r_a_m_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ FFuunnccttiioonnss │ │ │ │ │ -void  _T_b_b_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ +void  _O_m_p_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, int const *sizes, int const │ │ │ │ │ *offsets, int const *indices, float const *weights, int start, int end) │ │ │ │ │   │ │ │ │ │ -void  _T_b_b_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ +void  _O_m_p_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, int │ │ │ │ │ const *sizes, int const *offsets, int const *indices, float const │ │ │ │ │ *weights, float const *duWeights, float const *dvWeights, int start, int │ │ │ │ │ end) │ │ │ │ │   │ │ │ │ │ -void  _T_b_b_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ +void  _O_m_p_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, float │ │ │ │ │ *dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, float *dstDuv, │ │ │ │ │ _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, float *dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const │ │ │ │ │ &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, │ │ │ │ │ float const *weights, float const *duWeights, float const *dvWeights, │ │ │ │ │ float const *duuWeights, float const *duvWeights, float const │ │ │ │ │ *dvvWeights, int start, int end) │ │ │ │ │   │ │ │ │ │ -void  _T_b_b_E_v_a_l_P_a_t_c_h_e_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ - *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ - const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, int │ │ │ │ │ - numPatchCoords, const _P_a_t_c_h_C_o_o_r_d *patchCoords, const _P_a_t_c_h_A_r_r_a_y │ │ │ │ │ - *patchArrayBuffer, const int *patchIndexBuffer, const _P_a_t_c_h_P_a_r_a_m │ │ │ │ │ - *patchParamBuffer) │ │ │ │ │ -  │ │ │ │ │ -void  _T_b_b_E_v_a_l_P_a_t_c_h_e_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ - *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ - const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, float │ │ │ │ │ - *dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, float *dstDuv, │ │ │ │ │ - _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, float *dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const │ │ │ │ │ - &dstDvvDesc, int numPatchCoords, const _P_a_t_c_h_C_o_o_r_d *patchCoords, const │ │ │ │ │ - _P_a_t_c_h_A_r_r_a_y *patchArrayBuffer, const int *patchIndexBuffer, const │ │ │ │ │ - _P_a_t_c_h_P_a_r_a_m *patchParamBuffer) │ │ │ │ │ -  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _t_b_b_K_e_r_n_e_l_._h │ │ │ │ │ + * _o_m_p_K_e_r_n_e_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00872.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,7 +1,5 @@ │ │ │ │ │ var a00872 = [ │ │ │ │ │ - ["TbbEvalPatches", "a00872.html#aa0c3c264a43eeddc5cb3a58b006d3d32", null], │ │ │ │ │ - ["TbbEvalPatches", "a00872.html#a20e08be34d6183b6943ed7a1586eca4a", null], │ │ │ │ │ - ["TbbEvalStencils", "a00872.html#aa65ed860a2fa5935d99129a898a8f0b6", null], │ │ │ │ │ - ["TbbEvalStencils", "a00872.html#af23c35537952bfdd493441e5c42ff2ed", null], │ │ │ │ │ - ["TbbEvalStencils", "a00872.html#a4a6a0fcc01638f2a0316b32ad158b485", null] │ │ │ │ │ + ["OmpEvalStencils", "a00872.html#a44a05502feb5015035bc81b93cffb99c", null], │ │ │ │ │ + ["OmpEvalStencils", "a00872.html#a907dc53421460557871ddc35f77751f5", null], │ │ │ │ │ + ["OmpEvalStencils", "a00872.html#a870745ff3e883b32547d4db42b3be2bd", null] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00872_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/tbbKernel.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/ompKernel.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
tbbKernel.h
│ │ │ │ +
ompKernel.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,116 +119,82 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_TBB_KERNEL_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_TBB_KERNEL_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_OMP_KERNEL_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_OMP_KERNEL_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29#include "../far/patchDescriptor.h"
│ │ │ │ -
30#include "../far/patchParam.h"
│ │ │ │ -
31
│ │ │ │ -
32namespace OpenSubdiv {
│ │ │ │ -
33namespace OPENSUBDIV_VERSION {
│ │ │ │ +
29
│ │ │ │ +
30namespace OpenSubdiv {
│ │ │ │ +
31namespace OPENSUBDIV_VERSION {
│ │ │ │ +
32
│ │ │ │ +
33namespace Osd {
│ │ │ │
34
│ │ │ │ -
35namespace Osd {
│ │ │ │ +
35struct BufferDescriptor;
│ │ │ │
36
│ │ │ │ -
37struct PatchArray;
│ │ │ │ -
38struct PatchCoord;
│ │ │ │ -
39struct PatchParam;
│ │ │ │ -
40struct BufferDescriptor;
│ │ │ │ -
41
│ │ │ │ -
42void
│ │ │ │ -
43TbbEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ -
44 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
45 int const * sizes,
│ │ │ │ -
46 int const * offsets,
│ │ │ │ -
47 int const * indices,
│ │ │ │ -
48 float const * weights,
│ │ │ │ -
49 int start, int end);
│ │ │ │ -
50
│ │ │ │ -
51void
│ │ │ │ -
52TbbEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ -
53 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
54 float * dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ -
55 float * dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ -
56 int const * sizes,
│ │ │ │ -
57 int const * offsets,
│ │ │ │ -
58 int const * indices,
│ │ │ │ -
59 float const * weights,
│ │ │ │ -
60 float const * duWeights,
│ │ │ │ -
61 float const * dvWeights,
│ │ │ │ -
62 int start, int end);
│ │ │ │ -
63
│ │ │ │ -
64void
│ │ │ │ -
65TbbEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ -
66 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
67 float * dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ -
68 float * dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ -
69 float * dstDuu, BufferDescriptor const &dstDuuDesc,
│ │ │ │ -
70 float * dstDuv, BufferDescriptor const &dstDuvDesc,
│ │ │ │ -
71 float * dstDvv, BufferDescriptor const &dstDvvDesc,
│ │ │ │ -
72 int const * sizes,
│ │ │ │ -
73 int const * offsets,
│ │ │ │ -
74 int const * indices,
│ │ │ │ -
75 float const * weights,
│ │ │ │ -
76 float const * duWeights,
│ │ │ │ -
77 float const * dvWeights,
│ │ │ │ -
78 float const * duuWeights,
│ │ │ │ -
79 float const * duvWeights,
│ │ │ │ -
80 float const * dvvWeights,
│ │ │ │ -
81 int start, int end);
│ │ │ │ +
37void
│ │ │ │ +
38OmpEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ +
39 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
40 int const * sizes,
│ │ │ │ +
41 int const * offsets,
│ │ │ │ +
42 int const * indices,
│ │ │ │ +
43 float const * weights,
│ │ │ │ +
44 int start, int end);
│ │ │ │ +
45
│ │ │ │ +
46void
│ │ │ │ +
47OmpEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ +
48 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
49 float * dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ +
50 float * dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ +
51 int const * sizes,
│ │ │ │ +
52 int const * offsets,
│ │ │ │ +
53 int const * indices,
│ │ │ │ +
54 float const * weights,
│ │ │ │ +
55 float const * duWeights,
│ │ │ │ +
56 float const * dvWeights,
│ │ │ │ +
57 int start, int end);
│ │ │ │ +
58
│ │ │ │ +
59void
│ │ │ │ +
60OmpEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ +
61 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
62 float * dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ +
63 float * dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ +
64 float * dstDuu, BufferDescriptor const &dstDuuDesc,
│ │ │ │ +
65 float * dstDuv, BufferDescriptor const &dstDuvDesc,
│ │ │ │ +
66 float * dstDvv, BufferDescriptor const &dstDvvDesc,
│ │ │ │ +
67 int const * sizes,
│ │ │ │ +
68 int const * offsets,
│ │ │ │ +
69 int const * indices,
│ │ │ │ +
70 float const * weights,
│ │ │ │ +
71 float const * duWeights,
│ │ │ │ +
72 float const * dvWeights,
│ │ │ │ +
73 float const * duuWeights,
│ │ │ │ +
74 float const * duvWeights,
│ │ │ │ +
75 float const * dvvWeights,
│ │ │ │ +
76 int start, int end);
│ │ │ │ +
77
│ │ │ │ +
78} // end namespace Osd
│ │ │ │ +
79
│ │ │ │ +
80} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
81using namespace OPENSUBDIV_VERSION;
│ │ │ │
82
│ │ │ │ -
83void
│ │ │ │ -
84TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
85 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
86 float *dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ -
87 float *dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ -
88 int numPatchCoords,
│ │ │ │ -
89 const PatchCoord *patchCoords,
│ │ │ │ -
90 const PatchArray *patchArrayBuffer,
│ │ │ │ -
91 const int *patchIndexBuffer,
│ │ │ │ -
92 const PatchParam *patchParamBuffer);
│ │ │ │ -
93
│ │ │ │ -
94void
│ │ │ │ -
95TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
96 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
97 float *dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ -
98 float *dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ -
99 float *dstDuu, BufferDescriptor const &dstDuuDesc,
│ │ │ │ -
100 float *dstDuv, BufferDescriptor const &dstDuvDesc,
│ │ │ │ -
101 float *dstDvv, BufferDescriptor const &dstDvvDesc,
│ │ │ │ -
102 int numPatchCoords,
│ │ │ │ -
103 const PatchCoord *patchCoords,
│ │ │ │ -
104 const PatchArray *patchArrayBuffer,
│ │ │ │ -
105 const int *patchIndexBuffer,
│ │ │ │ -
106 const PatchParam *patchParamBuffer);
│ │ │ │ -
107
│ │ │ │ -
108} // end namespace Osd
│ │ │ │ -
109
│ │ │ │ -
110} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
111using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
112
│ │ │ │ -
113} // end namespace OpenSubdiv
│ │ │ │ -
114
│ │ │ │ -
115#endif // OPENSUBDIV3_OSD_TBB_KERNEL_H
│ │ │ │ - │ │ │ │ -
void TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrayBuffer, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
│ │ │ │ -
void TbbEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)
│ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ -
Coordinates set on a patch table.
Definition types.h:42
│ │ │ │ - │ │ │ │ - │ │ │ │ +
83} // end namespace OpenSubdiv
│ │ │ │ +
84
│ │ │ │ +
85#endif // OPENSUBDIV3_OSD_OMP_KERNEL_H
│ │ │ │ + │ │ │ │ +
void OmpEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)
│ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -tbbKernel.h │ │ │ │ │ +ompKernel.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,126 +24,82 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_TBB_KERNEL_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_TBB_KERNEL_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_OMP_KERNEL_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_OMP_KERNEL_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29#include "../far/patchDescriptor.h" │ │ │ │ │ -30#include "../far/patchParam.h" │ │ │ │ │ -31 │ │ │ │ │ -32namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -33namespace OPENSUBDIV_VERSION { │ │ │ │ │ +29 │ │ │ │ │ +30namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +31namespace OPENSUBDIV_VERSION { │ │ │ │ │ +32 │ │ │ │ │ +33namespace Osd { │ │ │ │ │ 34 │ │ │ │ │ -35namespace Osd { │ │ │ │ │ +35struct BufferDescriptor; │ │ │ │ │ 36 │ │ │ │ │ -37struct PatchArray; │ │ │ │ │ -38struct PatchCoord; │ │ │ │ │ -39struct PatchParam; │ │ │ │ │ -40struct BufferDescriptor; │ │ │ │ │ -41 │ │ │ │ │ -42void │ │ │ │ │ -_4_3_T_b_b_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -44 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -45 int const * sizes, │ │ │ │ │ -46 int const * offsets, │ │ │ │ │ -47 int const * indices, │ │ │ │ │ -48 float const * weights, │ │ │ │ │ -49 int start, int end); │ │ │ │ │ -50 │ │ │ │ │ -51void │ │ │ │ │ -_5_2_T_b_b_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -53 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -54 float * dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ -55 float * dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ -56 int const * sizes, │ │ │ │ │ -57 int const * offsets, │ │ │ │ │ -58 int const * indices, │ │ │ │ │ -59 float const * weights, │ │ │ │ │ -60 float const * duWeights, │ │ │ │ │ -61 float const * dvWeights, │ │ │ │ │ -62 int start, int end); │ │ │ │ │ -63 │ │ │ │ │ -64void │ │ │ │ │ -_6_5_T_b_b_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -66 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -67 float * dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ -68 float * dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ -69 float * dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, │ │ │ │ │ -70 float * dstDuv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, │ │ │ │ │ -71 float * dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvvDesc, │ │ │ │ │ -72 int const * sizes, │ │ │ │ │ -73 int const * offsets, │ │ │ │ │ -74 int const * indices, │ │ │ │ │ -75 float const * weights, │ │ │ │ │ -76 float const * duWeights, │ │ │ │ │ -77 float const * dvWeights, │ │ │ │ │ -78 float const * duuWeights, │ │ │ │ │ -79 float const * duvWeights, │ │ │ │ │ -80 float const * dvvWeights, │ │ │ │ │ -81 int start, int end); │ │ │ │ │ +37void │ │ │ │ │ +_3_8_O_m_p_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +39 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +40 int const * sizes, │ │ │ │ │ +41 int const * offsets, │ │ │ │ │ +42 int const * indices, │ │ │ │ │ +43 float const * weights, │ │ │ │ │ +44 int start, int end); │ │ │ │ │ +45 │ │ │ │ │ +46void │ │ │ │ │ +_4_7_O_m_p_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +48 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +49 float * dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ +50 float * dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ +51 int const * sizes, │ │ │ │ │ +52 int const * offsets, │ │ │ │ │ +53 int const * indices, │ │ │ │ │ +54 float const * weights, │ │ │ │ │ +55 float const * duWeights, │ │ │ │ │ +56 float const * dvWeights, │ │ │ │ │ +57 int start, int end); │ │ │ │ │ +58 │ │ │ │ │ +59void │ │ │ │ │ +_6_0_O_m_p_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +61 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +62 float * dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ +63 float * dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ +64 float * dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, │ │ │ │ │ +65 float * dstDuv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, │ │ │ │ │ +66 float * dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvvDesc, │ │ │ │ │ +67 int const * sizes, │ │ │ │ │ +68 int const * offsets, │ │ │ │ │ +69 int const * indices, │ │ │ │ │ +70 float const * weights, │ │ │ │ │ +71 float const * duWeights, │ │ │ │ │ +72 float const * dvWeights, │ │ │ │ │ +73 float const * duuWeights, │ │ │ │ │ +74 float const * duvWeights, │ │ │ │ │ +75 float const * dvvWeights, │ │ │ │ │ +76 int start, int end); │ │ │ │ │ +77 │ │ │ │ │ +78} // end namespace Osd │ │ │ │ │ +79 │ │ │ │ │ +80} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +81using namespace OPENSUBDIV_VERSION; │ │ │ │ │ 82 │ │ │ │ │ -83void │ │ │ │ │ -_8_4_T_b_b_E_v_a_l_P_a_t_c_h_e_s(float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -85 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -86 float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ -87 float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ -88 int numPatchCoords, │ │ │ │ │ -89 const _P_a_t_c_h_C_o_o_r_d *patchCoords, │ │ │ │ │ -90 const _P_a_t_c_h_A_r_r_a_y *patchArrayBuffer, │ │ │ │ │ -91 const int *patchIndexBuffer, │ │ │ │ │ -92 const _P_a_t_c_h_P_a_r_a_m *patchParamBuffer); │ │ │ │ │ -93 │ │ │ │ │ -94void │ │ │ │ │ -_9_5_T_b_b_E_v_a_l_P_a_t_c_h_e_s(float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -96 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -97 float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ -98 float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ -99 float *dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, │ │ │ │ │ -100 float *dstDuv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, │ │ │ │ │ -101 float *dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvvDesc, │ │ │ │ │ -102 int numPatchCoords, │ │ │ │ │ -103 const _P_a_t_c_h_C_o_o_r_d *patchCoords, │ │ │ │ │ -104 const _P_a_t_c_h_A_r_r_a_y *patchArrayBuffer, │ │ │ │ │ -105 const int *patchIndexBuffer, │ │ │ │ │ -106 const _P_a_t_c_h_P_a_r_a_m *patchParamBuffer); │ │ │ │ │ -107 │ │ │ │ │ -108} // end namespace Osd │ │ │ │ │ -109 │ │ │ │ │ -110} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -111using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -112 │ │ │ │ │ -113} // end namespace OpenSubdiv │ │ │ │ │ -114 │ │ │ │ │ -115#endif // OPENSUBDIV3_OSD_TBB_KERNEL_H │ │ │ │ │ +83} // end namespace OpenSubdiv │ │ │ │ │ +84 │ │ │ │ │ +85#endif // OPENSUBDIV3_OSD_OMP_KERNEL_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -void TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc, float │ │ │ │ │ -*dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const │ │ │ │ │ -&dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int │ │ │ │ │ -numPatchCoords, const PatchCoord *patchCoords, const PatchArray │ │ │ │ │ -*patchArrayBuffer, const int *patchIndexBuffer, const PatchParam │ │ │ │ │ -*patchParamBuffer) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -void TbbEvalStencils(float const *src, BufferDescriptor const &srcDesc, float │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_O_m_p_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +void OmpEvalStencils(float const *src, BufferDescriptor const &srcDesc, float │ │ │ │ │ *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, │ │ │ │ │ int const *indices, float const *weights, int start, int end) │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ data buffers.... │ │ │ │ │ DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_C_o_o_r_d │ │ │ │ │ -Coordinates set on a patch table. │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_A_r_r_a_y │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_P_a_r_a_m │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_1_2_7 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _t_b_b_K_e_r_n_e_l_._h │ │ │ │ │ + * _o_m_p_K_e_r_n_e_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00875.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/ompKernel.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/tbbEvaluator.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -88,45 +88,44 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ -Namespaces | │ │ │ │ -Functions
│ │ │ │ -
ompKernel.h File Reference
│ │ │ │ +Classes | │ │ │ │ +Namespaces
│ │ │ │ +
tbbEvaluator.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../osd/types.h"
│ │ │ │ +#include <cstddef>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +

│ │ │ │ +Classes

class  TbbEvaluator
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │

│ │ │ │ -Functions

void OmpEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)
 
void OmpEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, int start, int end)
 
void OmpEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, float *dstDuu, BufferDescriptor const &dstDuuDesc, float *dstDuv, BufferDescriptor const &dstDuvDesc, float *dstDvv, BufferDescriptor const &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, float const *duuWeights, float const *duvWeights, float const *dvvWeights, int start, int end)
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,41 +1,25 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -_N_a_m_e_s_p_a_c_e_s | _F_u_n_c_t_i_o_n_s │ │ │ │ │ -ompKernel.h File Reference │ │ │ │ │ +_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ +tbbEvaluator.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ +#include "_._._/_o_s_d_/_b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ +#include "_._._/_o_s_d_/_t_y_p_e_s_._h" │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ +CCllaasssseess │ │ │ │ │ +class   _T_b_b_E_v_a_l_u_a_t_o_r │ │ │ │ │ +  │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ -FFuunnccttiioonnss │ │ │ │ │ -void  _O_m_p_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ - *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, int const *sizes, int const │ │ │ │ │ - *offsets, int const *indices, float const *weights, int start, int end) │ │ │ │ │ -  │ │ │ │ │ -void  _O_m_p_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ - *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ - const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, int │ │ │ │ │ - const *sizes, int const *offsets, int const *indices, float const │ │ │ │ │ - *weights, float const *duWeights, float const *dvWeights, int start, int │ │ │ │ │ - end) │ │ │ │ │ -  │ │ │ │ │ -void  _O_m_p_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ - *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ - const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, float │ │ │ │ │ - *dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, float *dstDuv, │ │ │ │ │ - _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, float *dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const │ │ │ │ │ - &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, │ │ │ │ │ - float const *weights, float const *duWeights, float const *dvWeights, │ │ │ │ │ - float const *duuWeights, float const *duvWeights, float const │ │ │ │ │ - *dvvWeights, int start, int end) │ │ │ │ │ -  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _o_m_p_K_e_r_n_e_l_._h │ │ │ │ │ + * _t_b_b_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00875.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,5 +1,3 @@ │ │ │ │ │ var a00875 = [ │ │ │ │ │ - ["OmpEvalStencils", "a00875.html#a44a05502feb5015035bc81b93cffb99c", null], │ │ │ │ │ - ["OmpEvalStencils", "a00875.html#a907dc53421460557871ddc35f77751f5", null], │ │ │ │ │ - ["OmpEvalStencils", "a00875.html#a870745ff3e883b32547d4db42b3be2bd", null] │ │ │ │ │ + ["TbbEvaluator", "a01317.html", null] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00875_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/ompKernel.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/tbbEvaluator.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
ompKernel.h
│ │ │ │ +
tbbEvaluator.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2013 Pixar
│ │ │ │ +
2// Copyright 2015 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -119,82 +119,528 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_OMP_KERNEL_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_OMP_KERNEL_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_TBB_EVALUATOR_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_TBB_EVALUATOR_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29
│ │ │ │ -
30namespace OpenSubdiv {
│ │ │ │ -
31namespace OPENSUBDIV_VERSION {
│ │ │ │ -
32
│ │ │ │ -
33namespace Osd {
│ │ │ │ -
34
│ │ │ │ -
35struct BufferDescriptor;
│ │ │ │ +
29#include "../osd/bufferDescriptor.h"
│ │ │ │ +
30#include "../osd/types.h"
│ │ │ │ +
31
│ │ │ │ +
32#include <cstddef>
│ │ │ │ +
33
│ │ │ │ +
34namespace OpenSubdiv {
│ │ │ │ +
35namespace OPENSUBDIV_VERSION {
│ │ │ │
36
│ │ │ │ -
37void
│ │ │ │ -
38OmpEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ -
39 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
40 int const * sizes,
│ │ │ │ -
41 int const * offsets,
│ │ │ │ -
42 int const * indices,
│ │ │ │ -
43 float const * weights,
│ │ │ │ -
44 int start, int end);
│ │ │ │ -
45
│ │ │ │ -
46void
│ │ │ │ -
47OmpEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ -
48 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
49 float * dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ -
50 float * dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ -
51 int const * sizes,
│ │ │ │ -
52 int const * offsets,
│ │ │ │ -
53 int const * indices,
│ │ │ │ -
54 float const * weights,
│ │ │ │ -
55 float const * duWeights,
│ │ │ │ -
56 float const * dvWeights,
│ │ │ │ -
57 int start, int end);
│ │ │ │ -
58
│ │ │ │ -
59void
│ │ │ │ -
60OmpEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ -
61 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
62 float * dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ -
63 float * dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ -
64 float * dstDuu, BufferDescriptor const &dstDuuDesc,
│ │ │ │ -
65 float * dstDuv, BufferDescriptor const &dstDuvDesc,
│ │ │ │ -
66 float * dstDvv, BufferDescriptor const &dstDvvDesc,
│ │ │ │ -
67 int const * sizes,
│ │ │ │ -
68 int const * offsets,
│ │ │ │ -
69 int const * indices,
│ │ │ │ -
70 float const * weights,
│ │ │ │ -
71 float const * duWeights,
│ │ │ │ -
72 float const * dvWeights,
│ │ │ │ -
73 float const * duuWeights,
│ │ │ │ -
74 float const * duvWeights,
│ │ │ │ -
75 float const * dvvWeights,
│ │ │ │ -
76 int start, int end);
│ │ │ │ -
77
│ │ │ │ -
78} // end namespace Osd
│ │ │ │ -
79
│ │ │ │ -
80} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
81using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
82
│ │ │ │ -
83} // end namespace OpenSubdiv
│ │ │ │ +
37namespace Osd {
│ │ │ │ +
38
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
40public:
│ │ │ │ +
46
│ │ │ │ +
71 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
72 static bool EvalStencils(
│ │ │ │ +
73 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
74 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
75 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
76 TbbEvaluator const *instance = NULL,
│ │ │ │ +
77 void *deviceContext = NULL) {
│ │ │ │ +
78
│ │ │ │ +
79 (void)instance; // unused
│ │ │ │ +
80 (void)deviceContext; // unused
│ │ │ │ +
81
│ │ │ │ +
82 if (stencilTable->GetNumStencils() == 0)
│ │ │ │ +
83 return false;
│ │ │ │
84
│ │ │ │ -
85#endif // OPENSUBDIV3_OSD_OMP_KERNEL_H
│ │ │ │ - │ │ │ │ -
void OmpEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)
│ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ +
85 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
86 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
87 &stencilTable->GetSizes()[0],
│ │ │ │ +
88 &stencilTable->GetOffsets()[0],
│ │ │ │ +
89 &stencilTable->GetControlIndices()[0],
│ │ │ │ +
90 &stencilTable->GetWeights()[0],
│ │ │ │ +
91 /*start = */ 0,
│ │ │ │ +
92 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ +
93 }
│ │ │ │ +
│ │ │ │ +
94
│ │ │ │ +
121 static bool EvalStencils(
│ │ │ │ +
122 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
123 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
124 const int * sizes,
│ │ │ │ +
125 const int * offsets,
│ │ │ │ +
126 const int * indices,
│ │ │ │ +
127 const float * weights,
│ │ │ │ +
128 int start, int end);
│ │ │ │ +
129
│ │ │ │ +
167 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
168 static bool EvalStencils(
│ │ │ │ +
169 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
170 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
171 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
172 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
173 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
174 const TbbEvaluator *instance = NULL,
│ │ │ │ +
175 void * deviceContext = NULL) {
│ │ │ │ +
176
│ │ │ │ +
177 (void)instance; // unused
│ │ │ │ +
178 (void)deviceContext; // unused
│ │ │ │ +
179
│ │ │ │ +
180 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
181 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
182 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
183 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
184 &stencilTable->GetSizes()[0],
│ │ │ │ +
185 &stencilTable->GetOffsets()[0],
│ │ │ │ +
186 &stencilTable->GetControlIndices()[0],
│ │ │ │ +
187 &stencilTable->GetWeights()[0],
│ │ │ │ +
188 &stencilTable->GetDuWeights()[0],
│ │ │ │ +
189 &stencilTable->GetDvWeights()[0],
│ │ │ │ +
190 /*start = */ 0,
│ │ │ │ +
191 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ +
192 }
│ │ │ │ +
│ │ │ │ +
193
│ │ │ │ +
234 static bool EvalStencils(
│ │ │ │ +
235 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
236 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
237 float *du, BufferDescriptor const &duDesc,
│ │ │ │ +
238 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ +
239 const int * sizes,
│ │ │ │ +
240 const int * offsets,
│ │ │ │ +
241 const int * indices,
│ │ │ │ +
242 const float * weights,
│ │ │ │ +
243 const float * duWeights,
│ │ │ │ +
244 const float * dvWeights,
│ │ │ │ +
245 int start, int end);
│ │ │ │ +
246
│ │ │ │ +
302 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
303 static bool EvalStencils(
│ │ │ │ +
304 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
305 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
306 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
307 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
308 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
309 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
310 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
311 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
312 const TbbEvaluator *instance = NULL,
│ │ │ │ +
313 void * deviceContext = NULL) {
│ │ │ │ +
314
│ │ │ │ +
315 (void)instance; // unused
│ │ │ │ +
316 (void)deviceContext; // unused
│ │ │ │ +
317
│ │ │ │ +
318 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
319 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
320 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
321 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
322 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ +
323 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ +
324 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ +
325 &stencilTable->GetSizes()[0],
│ │ │ │ +
326 &stencilTable->GetOffsets()[0],
│ │ │ │ +
327 &stencilTable->GetControlIndices()[0],
│ │ │ │ +
328 &stencilTable->GetWeights()[0],
│ │ │ │ +
329 &stencilTable->GetDuWeights()[0],
│ │ │ │ +
330 &stencilTable->GetDvWeights()[0],
│ │ │ │ +
331 &stencilTable->GetDuuWeights()[0],
│ │ │ │ +
332 &stencilTable->GetDuvWeights()[0],
│ │ │ │ +
333 &stencilTable->GetDvvWeights()[0],
│ │ │ │ +
334 /*start = */ 0,
│ │ │ │ +
335 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ +
336 }
│ │ │ │ +
│ │ │ │ +
337
│ │ │ │ +
399 static bool EvalStencils(
│ │ │ │ +
400 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
401 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
402 float *du, BufferDescriptor const &duDesc,
│ │ │ │ +
403 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ +
404 float *duu, BufferDescriptor const &duuDesc,
│ │ │ │ +
405 float *duv, BufferDescriptor const &duvDesc,
│ │ │ │ +
406 float *dvv, BufferDescriptor const &dvvDesc,
│ │ │ │ +
407 const int * sizes,
│ │ │ │ +
408 const int * offsets,
│ │ │ │ +
409 const int * indices,
│ │ │ │ +
410 const float * weights,
│ │ │ │ +
411 const float * duWeights,
│ │ │ │ +
412 const float * dvWeights,
│ │ │ │ +
413 const float * duuWeights,
│ │ │ │ +
414 const float * duvWeights,
│ │ │ │ +
415 const float * dvvWeights,
│ │ │ │ +
416 int start, int end);
│ │ │ │ +
417
│ │ │ │ +
423
│ │ │ │ +
452 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
453 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
454 static bool EvalPatches(
│ │ │ │ +
455 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
456 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
457 int numPatchCoords,
│ │ │ │ +
458 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
459 PATCH_TABLE *patchTable,
│ │ │ │ +
460 TbbEvaluator const *instance = NULL,
│ │ │ │ +
461 void * deviceContext = NULL) {
│ │ │ │ +
462
│ │ │ │ +
463 (void)instance; // unused
│ │ │ │ +
464 (void)deviceContext; // unused
│ │ │ │ +
465
│ │ │ │ +
466 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
467 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
468 numPatchCoords,
│ │ │ │ +
469 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
470 patchTable->GetPatchArrayBuffer(),
│ │ │ │ +
471 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
472 patchTable->GetPatchParamBuffer());
│ │ │ │ +
473 }
│ │ │ │ +
│ │ │ │ +
474
│ │ │ │ +
515 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
516 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
517 static bool EvalPatches(
│ │ │ │ +
518 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
519 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
520 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
521 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
522 int numPatchCoords,
│ │ │ │ +
523 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
524 PATCH_TABLE *patchTable,
│ │ │ │ +
525 TbbEvaluator const *instance = NULL,
│ │ │ │ +
526 void * deviceContext = NULL) {
│ │ │ │ +
527
│ │ │ │ +
528 (void)instance; // unused
│ │ │ │ +
529 (void)deviceContext; // unused
│ │ │ │ +
530
│ │ │ │ +
531 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop.
│ │ │ │ +
532 // ideally all buffer classes should have templated by datatype
│ │ │ │ +
533 // so that downcast isn't needed there.
│ │ │ │ +
534 // (e.g. Osd::CpuBuffer<PatchCoord> )
│ │ │ │ +
535 //
│ │ │ │ +
536 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
537 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
538 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
539 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
540 numPatchCoords,
│ │ │ │ +
541 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
542 patchTable->GetPatchArrayBuffer(),
│ │ │ │ +
543 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
544 patchTable->GetPatchParamBuffer());
│ │ │ │ +
545 }
│ │ │ │ +
│ │ │ │ +
546
│ │ │ │ +
605 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
606 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
607 static bool EvalPatches(
│ │ │ │ +
608 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
609 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
610 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
611 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
612 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
613 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
614 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
615 int numPatchCoords,
│ │ │ │ +
616 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
617 PATCH_TABLE *patchTable,
│ │ │ │ +
618 TbbEvaluator const *instance = NULL,
│ │ │ │ +
619 void * deviceContext = NULL) {
│ │ │ │ +
620
│ │ │ │ +
621 (void)instance; // unused
│ │ │ │ +
622 (void)deviceContext; // unused
│ │ │ │ +
623
│ │ │ │ +
624 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop.
│ │ │ │ +
625 // ideally all buffer classes should have templated by datatype
│ │ │ │ +
626 // so that downcast isn't needed there.
│ │ │ │ +
627 // (e.g. Osd::CpuBuffer<PatchCoord> )
│ │ │ │ +
628 //
│ │ │ │ +
629 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
630 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
631 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
632 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
633 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ +
634 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ +
635 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ +
636 numPatchCoords,
│ │ │ │ +
637 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
638 patchTable->GetPatchArrayBuffer(),
│ │ │ │ +
639 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
640 patchTable->GetPatchParamBuffer());
│ │ │ │ +
641 }
│ │ │ │ +
│ │ │ │ +
642
│ │ │ │ +
670 static bool EvalPatches(
│ │ │ │ +
671 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
672 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
673 int numPatchCoords,
│ │ │ │ +
674 const PatchCoord *patchCoords,
│ │ │ │ +
675 const PatchArray *patchArrays,
│ │ │ │ +
676 const int *patchIndexBuffer,
│ │ │ │ +
677 const PatchParam *patchParamBuffer);
│ │ │ │ +
678
│ │ │ │ +
716 static bool EvalPatches(
│ │ │ │ +
717 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
718 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
719 float *du, BufferDescriptor const &duDesc,
│ │ │ │ +
720 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ +
721 int numPatchCoords,
│ │ │ │ +
722 PatchCoord const *patchCoords,
│ │ │ │ +
723 PatchArray const *patchArrays,
│ │ │ │ +
724 const int *patchIndexBuffer,
│ │ │ │ +
725 PatchParam const *patchParamBuffer);
│ │ │ │ +
726
│ │ │ │ +
779 static bool EvalPatches(
│ │ │ │ +
780 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
781 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
782 float *du, BufferDescriptor const &duDesc,
│ │ │ │ +
783 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ +
784 float *duu, BufferDescriptor const &duuDesc,
│ │ │ │ +
785 float *duv, BufferDescriptor const &duvDesc,
│ │ │ │ +
786 float *dvv, BufferDescriptor const &dvvDesc,
│ │ │ │ +
787 int numPatchCoords,
│ │ │ │ +
788 PatchCoord const *patchCoords,
│ │ │ │ +
789 PatchArray const *patchArrays,
│ │ │ │ +
790 const int *patchIndexBuffer,
│ │ │ │ +
791 PatchParam const *patchParamBuffer);
│ │ │ │ +
792
│ │ │ │ +
821 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
822 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
824 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
825 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
826 int numPatchCoords,
│ │ │ │ +
827 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
828 PATCH_TABLE *patchTable,
│ │ │ │ +
829 TbbEvaluator const *instance = NULL,
│ │ │ │ +
830 void * deviceContext = NULL) {
│ │ │ │ +
831
│ │ │ │ +
832 (void)instance; // unused
│ │ │ │ +
833 (void)deviceContext; // unused
│ │ │ │ +
834
│ │ │ │ +
835 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
836 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
837 numPatchCoords,
│ │ │ │ +
838 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
839 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ +
840 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
841 patchTable->GetPatchParamBuffer());
│ │ │ │ +
842 }
│ │ │ │ +
│ │ │ │ +
843
│ │ │ │ +
884 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
885 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
887 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
888 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
889 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
890 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
891 int numPatchCoords,
│ │ │ │ +
892 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
893 PATCH_TABLE *patchTable,
│ │ │ │ +
894 TbbEvaluator const *instance = NULL,
│ │ │ │ +
895 void * deviceContext = NULL) {
│ │ │ │ +
896
│ │ │ │ +
897 (void)instance; // unused
│ │ │ │ +
898 (void)deviceContext; // unused
│ │ │ │ +
899
│ │ │ │ +
900 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
901 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
902 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
903 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
904 numPatchCoords,
│ │ │ │ +
905 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
906 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ +
907 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
908 patchTable->GetPatchParamBuffer());
│ │ │ │ +
909 }
│ │ │ │ +
│ │ │ │ +
910
│ │ │ │ +
969 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
970 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
972 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
973 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
974 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
975 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
976 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
977 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
978 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
979 int numPatchCoords,
│ │ │ │ +
980 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
981 PATCH_TABLE *patchTable,
│ │ │ │ +
982 TbbEvaluator const *instance = NULL,
│ │ │ │ +
983 void * deviceContext = NULL) {
│ │ │ │ +
984
│ │ │ │ +
985 (void)instance; // unused
│ │ │ │ +
986 (void)deviceContext; // unused
│ │ │ │ +
987
│ │ │ │ +
988 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
989 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
990 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
991 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
992 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ +
993 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ +
994 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ +
995 numPatchCoords,
│ │ │ │ +
996 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
997 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ +
998 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
999 patchTable->GetPatchParamBuffer());
│ │ │ │ +
1000 }
│ │ │ │ +
│ │ │ │ +
1001
│ │ │ │ +
1032 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1033 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1035 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1036 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1037 int numPatchCoords,
│ │ │ │ +
1038 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1039 PATCH_TABLE *patchTable,
│ │ │ │ +
1040 int fvarChannel,
│ │ │ │ +
1041 TbbEvaluator const *instance = NULL,
│ │ │ │ +
1042 void * deviceContext = NULL) {
│ │ │ │ +
1043
│ │ │ │ +
1044 (void)instance; // unused
│ │ │ │ +
1045 (void)deviceContext; // unused
│ │ │ │ +
1046
│ │ │ │ +
1047 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
1048 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
1049 numPatchCoords,
│ │ │ │ +
1050 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
1051 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ +
1052 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
1053 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ +
1054 }
│ │ │ │ +
│ │ │ │ +
1055
│ │ │ │ +
1098 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1099 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1101 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1102 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1103 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1104 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1105 int numPatchCoords,
│ │ │ │ +
1106 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1107 PATCH_TABLE *patchTable,
│ │ │ │ +
1108 int fvarChannel,
│ │ │ │ +
1109 TbbEvaluator const *instance = NULL,
│ │ │ │ +
1110 void * deviceContext = NULL) {
│ │ │ │ +
1111
│ │ │ │ +
1112 (void)instance; // unused
│ │ │ │ +
1113 (void)deviceContext; // unused
│ │ │ │ +
1114
│ │ │ │ +
1115 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
1116 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
1117 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
1118 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
1119 numPatchCoords,
│ │ │ │ +
1120 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
1121 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ +
1122 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
1123 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ +
1124 }
│ │ │ │ +
│ │ │ │ +
1125
│ │ │ │ +
1186 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1187 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1189 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1190 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1191 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1192 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1193 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
1194 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
1195 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
1196 int numPatchCoords,
│ │ │ │ +
1197 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1198 PATCH_TABLE *patchTable,
│ │ │ │ +
1199 int fvarChannel,
│ │ │ │ +
1200 TbbEvaluator const *instance = NULL,
│ │ │ │ +
1201 void * deviceContext = NULL) {
│ │ │ │ +
1202
│ │ │ │ +
1203 (void)instance; // unused
│ │ │ │ +
1204 (void)deviceContext; // unused
│ │ │ │ +
1205
│ │ │ │ +
1206 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
1207 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
1208 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
1209 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
1210 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ +
1211 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ +
1212 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ +
1213 numPatchCoords,
│ │ │ │ +
1214 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
1215 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ +
1216 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
1217 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ +
1218 }
│ │ │ │ +
│ │ │ │ +
1219
│ │ │ │ +
1225
│ │ │ │ +
1227 static void Synchronize(void *deviceContext = NULL);
│ │ │ │ +
1228
│ │ │ │ +
1233 static void SetNumThreads(int numThreads);
│ │ │ │ +
1234};
│ │ │ │ +
│ │ │ │ +
1235
│ │ │ │ +
1236
│ │ │ │ +
1237} // end namespace Osd
│ │ │ │ +
1238
│ │ │ │ +
1239} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
1240using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
1241
│ │ │ │ +
1242} // end namespace OpenSubdiv
│ │ │ │ +
1243
│ │ │ │ +
1244
│ │ │ │ +
1245#endif // OPENSUBDIV3_OSD_TBB_EVALUATOR_H
│ │ │ │ + │ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ + │ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function. This function has a same signature as other device kernels hav...
│ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, const TbbEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │ +
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, int start, int end)
Static eval stencils function which takes raw CPU pointers for input and output.
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ +
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │ +
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, float *dvv, BufferDescriptor const &dvvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, const float *duuWeights, const float *duvWeights, const float *dvvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │ +
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, float *dvv, BufferDescriptor const &dvvDesc, int numPatchCoords, PatchCoord const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, PatchParam const *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ +
static void Synchronize(void *deviceContext=NULL)
synchronize all asynchronous computation invoked on this device.
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, int numPatchCoords, PatchCoord const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, PatchParam const *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ +
static void SetNumThreads(int numThreads)
Deprecated. Client code should initialize TBB.
│ │ │ │ +
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrays, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const TbbEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
Coordinates set on a patch table.
Definition types.h:42
│ │ │ │ + │ │ │ │ + │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -ompKernel.h │ │ │ │ │ +tbbEvaluator.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2013 Pixar │ │ │ │ │ +2// Copyright 2015 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -24,82 +24,657 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_OMP_KERNEL_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_OMP_KERNEL_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_TBB_EVALUATOR_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_TBB_EVALUATOR_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29 │ │ │ │ │ -30namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -31namespace OPENSUBDIV_VERSION { │ │ │ │ │ -32 │ │ │ │ │ -33namespace Osd { │ │ │ │ │ -34 │ │ │ │ │ -35struct BufferDescriptor; │ │ │ │ │ +29#include "../osd/bufferDescriptor.h" │ │ │ │ │ +30#include "../osd/types.h" │ │ │ │ │ +31 │ │ │ │ │ +32#include │ │ │ │ │ +33 │ │ │ │ │ +34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +35namespace OPENSUBDIV_VERSION { │ │ │ │ │ 36 │ │ │ │ │ -37void │ │ │ │ │ -_3_8_O_m_p_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -39 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -40 int const * sizes, │ │ │ │ │ -41 int const * offsets, │ │ │ │ │ -42 int const * indices, │ │ │ │ │ -43 float const * weights, │ │ │ │ │ -44 int start, int end); │ │ │ │ │ -45 │ │ │ │ │ -46void │ │ │ │ │ -_4_7_O_m_p_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -48 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -49 float * dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ -50 float * dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ -51 int const * sizes, │ │ │ │ │ -52 int const * offsets, │ │ │ │ │ -53 int const * indices, │ │ │ │ │ -54 float const * weights, │ │ │ │ │ -55 float const * duWeights, │ │ │ │ │ -56 float const * dvWeights, │ │ │ │ │ -57 int start, int end); │ │ │ │ │ -58 │ │ │ │ │ -59void │ │ │ │ │ -_6_0_O_m_p_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -61 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -62 float * dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ -63 float * dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ -64 float * dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, │ │ │ │ │ -65 float * dstDuv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, │ │ │ │ │ -66 float * dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvvDesc, │ │ │ │ │ -67 int const * sizes, │ │ │ │ │ -68 int const * offsets, │ │ │ │ │ -69 int const * indices, │ │ │ │ │ -70 float const * weights, │ │ │ │ │ -71 float const * duWeights, │ │ │ │ │ -72 float const * dvWeights, │ │ │ │ │ -73 float const * duuWeights, │ │ │ │ │ -74 float const * duvWeights, │ │ │ │ │ -75 float const * dvvWeights, │ │ │ │ │ -76 int start, int end); │ │ │ │ │ -77 │ │ │ │ │ -78} // end namespace Osd │ │ │ │ │ -79 │ │ │ │ │ -80} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -81using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -82 │ │ │ │ │ -83} // end namespace OpenSubdiv │ │ │ │ │ +37namespace Osd { │ │ │ │ │ +38 │ │ │ │ │ +_3_9class _T_b_b_E_v_a_l_u_a_t_o_r { │ │ │ │ │ +40public: │ │ │ │ │ +46 │ │ │ │ │ +71 template │ │ │ │ │ +_7_2 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +73 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +74 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +75 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +76 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +77 void *deviceContext = NULL) { │ │ │ │ │ +78 │ │ │ │ │ +79 (void)instance; // unused │ │ │ │ │ +80 (void)deviceContext; // unused │ │ │ │ │ +81 │ │ │ │ │ +82 if (stencilTable->GetNumStencils() == 0) │ │ │ │ │ +83 return false; │ │ │ │ │ 84 │ │ │ │ │ -85#endif // OPENSUBDIV3_OSD_OMP_KERNEL_H │ │ │ │ │ +85 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +86 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +87 &stencilTable->GetSizes()[0], │ │ │ │ │ +88 &stencilTable->GetOffsets()[0], │ │ │ │ │ +89 &stencilTable->GetControlIndices()[0], │ │ │ │ │ +90 &stencilTable->GetWeights()[0], │ │ │ │ │ +91 /*start = */ 0, │ │ │ │ │ +92 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ +93 } │ │ │ │ │ +94 │ │ │ │ │ +_1_2_1 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +122 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +123 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +124 const int * sizes, │ │ │ │ │ +125 const int * offsets, │ │ │ │ │ +126 const int * indices, │ │ │ │ │ +127 const float * weights, │ │ │ │ │ +128 int start, int end); │ │ │ │ │ +129 │ │ │ │ │ +167 template │ │ │ │ │ +_1_6_8 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +169 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +170 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +171 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +172 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +173 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +174 const _T_b_b_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ +175 void * deviceContext = NULL) { │ │ │ │ │ +176 │ │ │ │ │ +177 (void)instance; // unused │ │ │ │ │ +178 (void)deviceContext; // unused │ │ │ │ │ +179 │ │ │ │ │ +180 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +181 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +182 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +183 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +184 &stencilTable->GetSizes()[0], │ │ │ │ │ +185 &stencilTable->GetOffsets()[0], │ │ │ │ │ +186 &stencilTable->GetControlIndices()[0], │ │ │ │ │ +187 &stencilTable->GetWeights()[0], │ │ │ │ │ +188 &stencilTable->GetDuWeights()[0], │ │ │ │ │ +189 &stencilTable->GetDvWeights()[0], │ │ │ │ │ +190 /*start = */ 0, │ │ │ │ │ +191 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ +192 } │ │ │ │ │ +193 │ │ │ │ │ +_2_3_4 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +235 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +236 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +237 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +238 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +239 const int * sizes, │ │ │ │ │ +240 const int * offsets, │ │ │ │ │ +241 const int * indices, │ │ │ │ │ +242 const float * weights, │ │ │ │ │ +243 const float * duWeights, │ │ │ │ │ +244 const float * dvWeights, │ │ │ │ │ +245 int start, int end); │ │ │ │ │ +246 │ │ │ │ │ +302 template │ │ │ │ │ +_3_0_3 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +304 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +305 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +306 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +307 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +308 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +309 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +310 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +311 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +312 const _T_b_b_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ +313 void * deviceContext = NULL) { │ │ │ │ │ +314 │ │ │ │ │ +315 (void)instance; // unused │ │ │ │ │ +316 (void)deviceContext; // unused │ │ │ │ │ +317 │ │ │ │ │ +318 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +319 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +320 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +321 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +322 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ +323 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ +324 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ +325 &stencilTable->GetSizes()[0], │ │ │ │ │ +326 &stencilTable->GetOffsets()[0], │ │ │ │ │ +327 &stencilTable->GetControlIndices()[0], │ │ │ │ │ +328 &stencilTable->GetWeights()[0], │ │ │ │ │ +329 &stencilTable->GetDuWeights()[0], │ │ │ │ │ +330 &stencilTable->GetDvWeights()[0], │ │ │ │ │ +331 &stencilTable->GetDuuWeights()[0], │ │ │ │ │ +332 &stencilTable->GetDuvWeights()[0], │ │ │ │ │ +333 &stencilTable->GetDvvWeights()[0], │ │ │ │ │ +334 /*start = */ 0, │ │ │ │ │ +335 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ +336 } │ │ │ │ │ +337 │ │ │ │ │ +_3_9_9 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +400 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +401 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +402 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +403 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +404 float *duu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +405 float *duv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +406 float *dvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +407 const int * sizes, │ │ │ │ │ +408 const int * offsets, │ │ │ │ │ +409 const int * indices, │ │ │ │ │ +410 const float * weights, │ │ │ │ │ +411 const float * duWeights, │ │ │ │ │ +412 const float * dvWeights, │ │ │ │ │ +413 const float * duuWeights, │ │ │ │ │ +414 const float * duvWeights, │ │ │ │ │ +415 const float * dvvWeights, │ │ │ │ │ +416 int start, int end); │ │ │ │ │ +417 │ │ │ │ │ +423 │ │ │ │ │ +452 template │ │ │ │ │ +_4_5_4 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +455 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +456 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +457 int numPatchCoords, │ │ │ │ │ +458 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +459 PATCH_TABLE *patchTable, │ │ │ │ │ +460 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +461 void * deviceContext = NULL) { │ │ │ │ │ +462 │ │ │ │ │ +463 (void)instance; // unused │ │ │ │ │ +464 (void)deviceContext; // unused │ │ │ │ │ +465 │ │ │ │ │ +466 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +467 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +468 numPatchCoords, │ │ │ │ │ +469 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +470 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ +471 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +472 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +473 } │ │ │ │ │ +474 │ │ │ │ │ +515 template │ │ │ │ │ +_5_1_7 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +518 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +519 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +520 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +521 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +522 int numPatchCoords, │ │ │ │ │ +523 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +524 PATCH_TABLE *patchTable, │ │ │ │ │ +525 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +526 void * deviceContext = NULL) { │ │ │ │ │ +527 │ │ │ │ │ +528 (void)instance; // unused │ │ │ │ │ +529 (void)deviceContext; // unused │ │ │ │ │ +530 │ │ │ │ │ +531 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop. │ │ │ │ │ +532 // ideally all buffer classes should have templated by datatype │ │ │ │ │ +533 // so that downcast isn't needed there. │ │ │ │ │ +534 // (e.g. Osd::CpuBuffer ) │ │ │ │ │ +535 // │ │ │ │ │ +536 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +537 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +538 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +539 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +540 numPatchCoords, │ │ │ │ │ +541 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +542 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ +543 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +544 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +545 } │ │ │ │ │ +546 │ │ │ │ │ +605 template │ │ │ │ │ +_6_0_7 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +608 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +609 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +610 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +611 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +612 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +613 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +614 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +615 int numPatchCoords, │ │ │ │ │ +616 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +617 PATCH_TABLE *patchTable, │ │ │ │ │ +618 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +619 void * deviceContext = NULL) { │ │ │ │ │ +620 │ │ │ │ │ +621 (void)instance; // unused │ │ │ │ │ +622 (void)deviceContext; // unused │ │ │ │ │ +623 │ │ │ │ │ +624 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop. │ │ │ │ │ +625 // ideally all buffer classes should have templated by datatype │ │ │ │ │ +626 // so that downcast isn't needed there. │ │ │ │ │ +627 // (e.g. Osd::CpuBuffer ) │ │ │ │ │ +628 // │ │ │ │ │ +629 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +630 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +631 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +632 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +633 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ +634 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ +635 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ +636 numPatchCoords, │ │ │ │ │ +637 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +638 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ +639 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +640 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +641 } │ │ │ │ │ +642 │ │ │ │ │ +_6_7_0 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +671 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +672 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +673 int numPatchCoords, │ │ │ │ │ +674 const _P_a_t_c_h_C_o_o_r_d *patchCoords, │ │ │ │ │ +675 const _P_a_t_c_h_A_r_r_a_y *patchArrays, │ │ │ │ │ +676 const int *patchIndexBuffer, │ │ │ │ │ +677 const _P_a_t_c_h_P_a_r_a_m *patchParamBuffer); │ │ │ │ │ +678 │ │ │ │ │ +_7_1_6 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +717 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +718 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +719 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +720 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +721 int numPatchCoords, │ │ │ │ │ +722 _P_a_t_c_h_C_o_o_r_d const *patchCoords, │ │ │ │ │ +723 _P_a_t_c_h_A_r_r_a_y const *patchArrays, │ │ │ │ │ +724 const int *patchIndexBuffer, │ │ │ │ │ +725 _P_a_t_c_h_P_a_r_a_m const *patchParamBuffer); │ │ │ │ │ +726 │ │ │ │ │ +_7_7_9 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +780 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +781 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +782 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +783 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +784 float *duu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +785 float *duv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +786 float *dvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +787 int numPatchCoords, │ │ │ │ │ +788 _P_a_t_c_h_C_o_o_r_d const *patchCoords, │ │ │ │ │ +789 _P_a_t_c_h_A_r_r_a_y const *patchArrays, │ │ │ │ │ +790 const int *patchIndexBuffer, │ │ │ │ │ +791 _P_a_t_c_h_P_a_r_a_m const *patchParamBuffer); │ │ │ │ │ +792 │ │ │ │ │ +821 template │ │ │ │ │ +_8_2_3 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +824 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +825 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +826 int numPatchCoords, │ │ │ │ │ +827 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +828 PATCH_TABLE *patchTable, │ │ │ │ │ +829 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +830 void * deviceContext = NULL) { │ │ │ │ │ +831 │ │ │ │ │ +832 (void)instance; // unused │ │ │ │ │ +833 (void)deviceContext; // unused │ │ │ │ │ +834 │ │ │ │ │ +835 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +836 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +837 numPatchCoords, │ │ │ │ │ +838 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +839 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ +840 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +841 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +842 } │ │ │ │ │ +843 │ │ │ │ │ +884 template │ │ │ │ │ +_8_8_6 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +887 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +888 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +889 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +890 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +891 int numPatchCoords, │ │ │ │ │ +892 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +893 PATCH_TABLE *patchTable, │ │ │ │ │ +894 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +895 void * deviceContext = NULL) { │ │ │ │ │ +896 │ │ │ │ │ +897 (void)instance; // unused │ │ │ │ │ +898 (void)deviceContext; // unused │ │ │ │ │ +899 │ │ │ │ │ +900 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +901 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +902 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +903 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +904 numPatchCoords, │ │ │ │ │ +905 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +906 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ +907 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +908 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +909 } │ │ │ │ │ +910 │ │ │ │ │ +969 template │ │ │ │ │ +_9_7_1 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +972 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +973 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +974 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +975 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +976 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +977 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +978 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +979 int numPatchCoords, │ │ │ │ │ +980 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +981 PATCH_TABLE *patchTable, │ │ │ │ │ +982 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +983 void * deviceContext = NULL) { │ │ │ │ │ +984 │ │ │ │ │ +985 (void)instance; // unused │ │ │ │ │ +986 (void)deviceContext; // unused │ │ │ │ │ +987 │ │ │ │ │ +988 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +989 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +990 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +991 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +992 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ +993 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ +994 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ +995 numPatchCoords, │ │ │ │ │ +996 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +997 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ +998 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +999 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +1000 } │ │ │ │ │ +1001 │ │ │ │ │ +1032 template │ │ │ │ │ +_1_0_3_4 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1035 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1036 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1037 int numPatchCoords, │ │ │ │ │ +1038 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1039 PATCH_TABLE *patchTable, │ │ │ │ │ +1040 int fvarChannel, │ │ │ │ │ +1041 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +1042 void * deviceContext = NULL) { │ │ │ │ │ +1043 │ │ │ │ │ +1044 (void)instance; // unused │ │ │ │ │ +1045 (void)deviceContext; // unused │ │ │ │ │ +1046 │ │ │ │ │ +1047 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +1048 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +1049 numPatchCoords, │ │ │ │ │ +1050 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +1051 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ +1052 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +1053 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ +1054 } │ │ │ │ │ +1055 │ │ │ │ │ +1098 template │ │ │ │ │ +_1_1_0_0 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1101 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1102 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1103 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1104 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1105 int numPatchCoords, │ │ │ │ │ +1106 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1107 PATCH_TABLE *patchTable, │ │ │ │ │ +1108 int fvarChannel, │ │ │ │ │ +1109 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +1110 void * deviceContext = NULL) { │ │ │ │ │ +1111 │ │ │ │ │ +1112 (void)instance; // unused │ │ │ │ │ +1113 (void)deviceContext; // unused │ │ │ │ │ +1114 │ │ │ │ │ +1115 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +1116 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +1117 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +1118 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +1119 numPatchCoords, │ │ │ │ │ +1120 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +1121 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ +1122 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +1123 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ +1124 } │ │ │ │ │ +1125 │ │ │ │ │ +1186 template │ │ │ │ │ +_1_1_8_8 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1189 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1190 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1191 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1192 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1193 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +1194 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +1195 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +1196 int numPatchCoords, │ │ │ │ │ +1197 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1198 PATCH_TABLE *patchTable, │ │ │ │ │ +1199 int fvarChannel, │ │ │ │ │ +1200 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +1201 void * deviceContext = NULL) { │ │ │ │ │ +1202 │ │ │ │ │ +1203 (void)instance; // unused │ │ │ │ │ +1204 (void)deviceContext; // unused │ │ │ │ │ +1205 │ │ │ │ │ +1206 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +1207 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +1208 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +1209 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +1210 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ +1211 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ +1212 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ +1213 numPatchCoords, │ │ │ │ │ +1214 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +1215 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ +1216 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +1217 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ +1218 } │ │ │ │ │ +1219 │ │ │ │ │ +1225 │ │ │ │ │ +_1_2_2_7 static void _S_y_n_c_h_r_o_n_i_z_e(void *deviceContext = NULL); │ │ │ │ │ +1228 │ │ │ │ │ +_1_2_3_3 static void _S_e_t_N_u_m_T_h_r_e_a_d_s(int numThreads); │ │ │ │ │ +1234}; │ │ │ │ │ +1235 │ │ │ │ │ +1236 │ │ │ │ │ +1237} // end namespace Osd │ │ │ │ │ +1238 │ │ │ │ │ +1239} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +1240using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +1241 │ │ │ │ │ +1242} // end namespace OpenSubdiv │ │ │ │ │ +1243 │ │ │ │ │ +1244 │ │ │ │ │ +1245#endif // OPENSUBDIV3_OSD_TBB_EVALUATOR_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_O_m_p_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -void OmpEvalStencils(float const *src, BufferDescriptor const &srcDesc, float │ │ │ │ │ -*dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, │ │ │ │ │ -int const *indices, float const *weights, int start, int end) │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ data buffers.... │ │ │ │ │ DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_3_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE │ │ │ │ │ +const *stencilTable, TbbEvaluator const *instance=NULL, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +Generic static eval stencils function. This function has a same signature as │ │ │ │ │ +other device kernels hav... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const │ │ │ │ │ +*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_4_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, │ │ │ │ │ +const TbbEvaluator *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic static eval stencils function with derivatives. This function has a │ │ │ │ │ +same signature as other d... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_3_0_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int │ │ │ │ │ +*offsets, const int *indices, const float *weights, int start, int end) │ │ │ │ │ +Static eval stencils function which takes raw CPU pointers for input and │ │ │ │ │ +output. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_8_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ +*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ +BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +Generic limit eval function with derivatives. This function has a same │ │ │ │ │ +signature as other device kern... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_6_0_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ +&duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int │ │ │ │ │ +*offsets, const int *indices, const float *weights, const float *duWeights, │ │ │ │ │ +const float *dvWeights, int start, int end) │ │ │ │ │ +Static eval stencils function with derivatives, which takes raw CPU pointers │ │ │ │ │ +for input and output. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ +&duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, │ │ │ │ │ +BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, │ │ │ │ │ +float *dvv, BufferDescriptor const &dvvDesc, const int *sizes, const int │ │ │ │ │ +*offsets, const int *indices, const float *weights, const float *duWeights, │ │ │ │ │ +const float *dvWeights, const float *duuWeights, const float *duvWeights, const │ │ │ │ │ +float *dvvWeights, int start, int end) │ │ │ │ │ +Static eval stencils function with derivatives, which takes raw CPU pointers │ │ │ │ │ +for input and output. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ +&duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, │ │ │ │ │ +BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, │ │ │ │ │ +float *dvv, BufferDescriptor const &dvvDesc, int numPatchCoords, PatchCoord │ │ │ │ │ +const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, │ │ │ │ │ +PatchParam const *patchParamBuffer) │ │ │ │ │ +Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ +values on given PatchT... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_S_y_n_c_h_r_o_n_i_z_e │ │ │ │ │ +static void Synchronize(void *deviceContext=NULL) │ │ │ │ │ +synchronize all asynchronous computation invoked on this device. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const │ │ │ │ │ +*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_9_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ +DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, int fvarChannel, TbbEvaluator const │ │ │ │ │ +*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_1_1_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ +*patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function with derivatives. This function has a same │ │ │ │ │ +signature as other device kern... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_5_1_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ +numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int │ │ │ │ │ +fvarChannel, TbbEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_1_0_3_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ +&duDesc, float *dv, BufferDescriptor const &dvDesc, int numPatchCoords, │ │ │ │ │ +PatchCoord const *patchCoords, PatchArray const *patchArrays, const int │ │ │ │ │ +*patchIndexBuffer, PatchParam const *patchParamBuffer) │ │ │ │ │ +Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ +values on given PatchT... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_S_e_t_N_u_m_T_h_r_e_a_d_s │ │ │ │ │ +static void SetNumThreads(int numThreads) │ │ │ │ │ +Deprecated. Client code should initialize TBB. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, int numPatchCoords, const │ │ │ │ │ +PatchCoord *patchCoords, const PatchArray *patchArrays, const int │ │ │ │ │ +*patchIndexBuffer, const PatchParam *patchParamBuffer) │ │ │ │ │ +Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ +values on given PatchT... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const │ │ │ │ │ +TbbEvaluator *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic static eval stencils function with derivatives. This function has a │ │ │ │ │ +same signature as other d... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_1_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ +DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, │ │ │ │ │ +TbbEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_1_1_8_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ +numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, │ │ │ │ │ +TbbEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_8_2_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_C_o_o_r_d │ │ │ │ │ +Coordinates set on a patch table. │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_A_r_r_a_y │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_P_a_r_a_m │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_1_2_7 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _o_m_p_K_e_r_n_e_l_._h │ │ │ │ │ + * _t_b_b_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00878.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/tbbEvaluator.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/tbbKernel.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -88,44 +88,51 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ -Classes | │ │ │ │ -Namespaces
│ │ │ │ -
tbbEvaluator.h File Reference
│ │ │ │ +Namespaces | │ │ │ │ +Functions
│ │ │ │ +
tbbKernel.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ -#include "../osd/types.h"
│ │ │ │ -#include <cstddef>
│ │ │ │ +#include "../far/patchDescriptor.h"
│ │ │ │ +#include "../far/patchParam.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -

│ │ │ │ -Classes

class  TbbEvaluator
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ +

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │

│ │ │ │ +Functions

void TbbEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)
 
void TbbEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, int start, int end)
 
void TbbEvalStencils (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, float *dstDuu, BufferDescriptor const &dstDuuDesc, float *dstDuv, BufferDescriptor const &dstDuvDesc, float *dstDvv, BufferDescriptor const &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, float const *duuWeights, float const *duvWeights, float const *dvvWeights, int start, int end)
 
void TbbEvalPatches (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrayBuffer, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
 
void TbbEvalPatches (float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, float *dstDuu, BufferDescriptor const &dstDuuDesc, float *dstDuv, BufferDescriptor const &dstDuvDesc, float *dstDvv, BufferDescriptor const &dstDvvDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrayBuffer, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,25 +1,59 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -tbbEvaluator.h File Reference │ │ │ │ │ +_N_a_m_e_s_p_a_c_e_s | _F_u_n_c_t_i_o_n_s │ │ │ │ │ +tbbKernel.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_o_s_d_/_b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ -#include "_._._/_o_s_d_/_t_y_p_e_s_._h" │ │ │ │ │ -#include │ │ │ │ │ +#include "_._._/_f_a_r_/_p_a_t_c_h_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ +#include "_._._/_f_a_r_/_p_a_t_c_h_P_a_r_a_m_._h" │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ -CCllaasssseess │ │ │ │ │ -class   _T_b_b_E_v_a_l_u_a_t_o_r │ │ │ │ │ -  │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ +FFuunnccttiioonnss │ │ │ │ │ +void  _T_b_b_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ + *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, int const *sizes, int const │ │ │ │ │ + *offsets, int const *indices, float const *weights, int start, int end) │ │ │ │ │ +  │ │ │ │ │ +void  _T_b_b_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ + *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ + const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, int │ │ │ │ │ + const *sizes, int const *offsets, int const *indices, float const │ │ │ │ │ + *weights, float const *duWeights, float const *dvWeights, int start, int │ │ │ │ │ + end) │ │ │ │ │ +  │ │ │ │ │ +void  _T_b_b_E_v_a_l_S_t_e_n_c_i_l_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ + *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ + const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, float │ │ │ │ │ + *dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, float *dstDuv, │ │ │ │ │ + _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, float *dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const │ │ │ │ │ + &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, │ │ │ │ │ + float const *weights, float const *duWeights, float const *dvWeights, │ │ │ │ │ + float const *duuWeights, float const *duvWeights, float const │ │ │ │ │ + *dvvWeights, int start, int end) │ │ │ │ │ +  │ │ │ │ │ +void  _T_b_b_E_v_a_l_P_a_t_c_h_e_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ + *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ + const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, int │ │ │ │ │ + numPatchCoords, const _P_a_t_c_h_C_o_o_r_d *patchCoords, const _P_a_t_c_h_A_r_r_a_y │ │ │ │ │ + *patchArrayBuffer, const int *patchIndexBuffer, const _P_a_t_c_h_P_a_r_a_m │ │ │ │ │ + *patchParamBuffer) │ │ │ │ │ +  │ │ │ │ │ +void  _T_b_b_E_v_a_l_P_a_t_c_h_e_s (float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, float │ │ │ │ │ + *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ + const &dstDuDesc, float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, float │ │ │ │ │ + *dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, float *dstDuv, │ │ │ │ │ + _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, float *dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const │ │ │ │ │ + &dstDvvDesc, int numPatchCoords, const _P_a_t_c_h_C_o_o_r_d *patchCoords, const │ │ │ │ │ + _P_a_t_c_h_A_r_r_a_y *patchArrayBuffer, const int *patchIndexBuffer, const │ │ │ │ │ + _P_a_t_c_h_P_a_r_a_m *patchParamBuffer) │ │ │ │ │ +  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _t_b_b_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ + * _t_b_b_K_e_r_n_e_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00878.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,7 @@ │ │ │ │ │ var a00878 = [ │ │ │ │ │ - ["TbbEvaluator", "a01317.html", null] │ │ │ │ │ + ["TbbEvalPatches", "a00878.html#aa0c3c264a43eeddc5cb3a58b006d3d32", null], │ │ │ │ │ + ["TbbEvalPatches", "a00878.html#a20e08be34d6183b6943ed7a1586eca4a", null], │ │ │ │ │ + ["TbbEvalStencils", "a00878.html#aa65ed860a2fa5935d99129a898a8f0b6", null], │ │ │ │ │ + ["TbbEvalStencils", "a00878.html#af23c35537952bfdd493441e5c42ff2ed", null], │ │ │ │ │ + ["TbbEvalStencils", "a00878.html#a4a6a0fcc01638f2a0316b32ad158b485", null] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00878_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/tbbEvaluator.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/tbbKernel.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,19 +92,19 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
tbbEvaluator.h
│ │ │ │ +
tbbKernel.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │ -
2// Copyright 2015 Pixar
│ │ │ │ +
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │
6// compliance with the Apache License and the following modification to it:
│ │ │ │
7// Section 6. Trademarks. is deleted and replaced with:
│ │ │ │
8//
│ │ │ │
9// 6. Trademarks. This License does not grant permission to use the trade
│ │ │ │ @@ -119,528 +119,116 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_TBB_EVALUATOR_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_TBB_EVALUATOR_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_TBB_KERNEL_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_TBB_KERNEL_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29#include "../osd/bufferDescriptor.h"
│ │ │ │ -
30#include "../osd/types.h"
│ │ │ │ +
29#include "../far/patchDescriptor.h"
│ │ │ │ +
30#include "../far/patchParam.h"
│ │ │ │
31
│ │ │ │ -
32#include <cstddef>
│ │ │ │ -
33
│ │ │ │ -
34namespace OpenSubdiv {
│ │ │ │ -
35namespace OPENSUBDIV_VERSION {
│ │ │ │ +
32namespace OpenSubdiv {
│ │ │ │ +
33namespace OPENSUBDIV_VERSION {
│ │ │ │ +
34
│ │ │ │ +
35namespace Osd {
│ │ │ │
36
│ │ │ │ -
37namespace Osd {
│ │ │ │ -
38
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
40public:
│ │ │ │ -
46
│ │ │ │ -
71 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
72 static bool EvalStencils(
│ │ │ │ -
73 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
74 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
75 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
76 TbbEvaluator const *instance = NULL,
│ │ │ │ -
77 void *deviceContext = NULL) {
│ │ │ │ -
78
│ │ │ │ -
79 (void)instance; // unused
│ │ │ │ -
80 (void)deviceContext; // unused
│ │ │ │ -
81
│ │ │ │ -
82 if (stencilTable->GetNumStencils() == 0)
│ │ │ │ -
83 return false;
│ │ │ │ -
84
│ │ │ │ -
85 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
86 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
87 &stencilTable->GetSizes()[0],
│ │ │ │ -
88 &stencilTable->GetOffsets()[0],
│ │ │ │ -
89 &stencilTable->GetControlIndices()[0],
│ │ │ │ -
90 &stencilTable->GetWeights()[0],
│ │ │ │ -
91 /*start = */ 0,
│ │ │ │ -
92 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ -
93 }
│ │ │ │ -
│ │ │ │ -
94
│ │ │ │ -
121 static bool EvalStencils(
│ │ │ │ -
122 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
123 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
124 const int * sizes,
│ │ │ │ -
125 const int * offsets,
│ │ │ │ -
126 const int * indices,
│ │ │ │ -
127 const float * weights,
│ │ │ │ -
128 int start, int end);
│ │ │ │ -
129
│ │ │ │ -
167 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
168 static bool EvalStencils(
│ │ │ │ -
169 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
170 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
171 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
172 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
173 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
174 const TbbEvaluator *instance = NULL,
│ │ │ │ -
175 void * deviceContext = NULL) {
│ │ │ │ -
176
│ │ │ │ -
177 (void)instance; // unused
│ │ │ │ -
178 (void)deviceContext; // unused
│ │ │ │ -
179
│ │ │ │ -
180 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
181 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
182 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
183 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
184 &stencilTable->GetSizes()[0],
│ │ │ │ -
185 &stencilTable->GetOffsets()[0],
│ │ │ │ -
186 &stencilTable->GetControlIndices()[0],
│ │ │ │ -
187 &stencilTable->GetWeights()[0],
│ │ │ │ -
188 &stencilTable->GetDuWeights()[0],
│ │ │ │ -
189 &stencilTable->GetDvWeights()[0],
│ │ │ │ -
190 /*start = */ 0,
│ │ │ │ -
191 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ -
192 }
│ │ │ │ -
│ │ │ │ -
193
│ │ │ │ -
234 static bool EvalStencils(
│ │ │ │ -
235 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
236 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
237 float *du, BufferDescriptor const &duDesc,
│ │ │ │ -
238 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ -
239 const int * sizes,
│ │ │ │ -
240 const int * offsets,
│ │ │ │ -
241 const int * indices,
│ │ │ │ -
242 const float * weights,
│ │ │ │ -
243 const float * duWeights,
│ │ │ │ -
244 const float * dvWeights,
│ │ │ │ -
245 int start, int end);
│ │ │ │ -
246
│ │ │ │ -
302 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
303 static bool EvalStencils(
│ │ │ │ -
304 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
305 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
306 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
307 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
308 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
309 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
310 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
311 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
312 const TbbEvaluator *instance = NULL,
│ │ │ │ -
313 void * deviceContext = NULL) {
│ │ │ │ -
314
│ │ │ │ -
315 (void)instance; // unused
│ │ │ │ -
316 (void)deviceContext; // unused
│ │ │ │ -
317
│ │ │ │ -
318 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
319 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
320 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
321 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
322 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ -
323 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ -
324 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ -
325 &stencilTable->GetSizes()[0],
│ │ │ │ -
326 &stencilTable->GetOffsets()[0],
│ │ │ │ -
327 &stencilTable->GetControlIndices()[0],
│ │ │ │ -
328 &stencilTable->GetWeights()[0],
│ │ │ │ -
329 &stencilTable->GetDuWeights()[0],
│ │ │ │ -
330 &stencilTable->GetDvWeights()[0],
│ │ │ │ -
331 &stencilTable->GetDuuWeights()[0],
│ │ │ │ -
332 &stencilTable->GetDuvWeights()[0],
│ │ │ │ -
333 &stencilTable->GetDvvWeights()[0],
│ │ │ │ -
334 /*start = */ 0,
│ │ │ │ -
335 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ -
336 }
│ │ │ │ -
│ │ │ │ -
337
│ │ │ │ -
399 static bool EvalStencils(
│ │ │ │ -
400 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
401 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
402 float *du, BufferDescriptor const &duDesc,
│ │ │ │ -
403 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ -
404 float *duu, BufferDescriptor const &duuDesc,
│ │ │ │ -
405 float *duv, BufferDescriptor const &duvDesc,
│ │ │ │ -
406 float *dvv, BufferDescriptor const &dvvDesc,
│ │ │ │ -
407 const int * sizes,
│ │ │ │ -
408 const int * offsets,
│ │ │ │ -
409 const int * indices,
│ │ │ │ -
410 const float * weights,
│ │ │ │ -
411 const float * duWeights,
│ │ │ │ -
412 const float * dvWeights,
│ │ │ │ -
413 const float * duuWeights,
│ │ │ │ -
414 const float * duvWeights,
│ │ │ │ -
415 const float * dvvWeights,
│ │ │ │ -
416 int start, int end);
│ │ │ │ -
417
│ │ │ │ -
423
│ │ │ │ -
452 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
453 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
454 static bool EvalPatches(
│ │ │ │ -
455 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
456 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
457 int numPatchCoords,
│ │ │ │ -
458 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
459 PATCH_TABLE *patchTable,
│ │ │ │ -
460 TbbEvaluator const *instance = NULL,
│ │ │ │ -
461 void * deviceContext = NULL) {
│ │ │ │ -
462
│ │ │ │ -
463 (void)instance; // unused
│ │ │ │ -
464 (void)deviceContext; // unused
│ │ │ │ -
465
│ │ │ │ -
466 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
467 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
468 numPatchCoords,
│ │ │ │ -
469 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
470 patchTable->GetPatchArrayBuffer(),
│ │ │ │ -
471 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
472 patchTable->GetPatchParamBuffer());
│ │ │ │ -
473 }
│ │ │ │ -
│ │ │ │ -
474
│ │ │ │ -
515 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
516 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
517 static bool EvalPatches(
│ │ │ │ -
518 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
519 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
520 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
521 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
522 int numPatchCoords,
│ │ │ │ -
523 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
524 PATCH_TABLE *patchTable,
│ │ │ │ -
525 TbbEvaluator const *instance = NULL,
│ │ │ │ -
526 void * deviceContext = NULL) {
│ │ │ │ -
527
│ │ │ │ -
528 (void)instance; // unused
│ │ │ │ -
529 (void)deviceContext; // unused
│ │ │ │ -
530
│ │ │ │ -
531 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop.
│ │ │ │ -
532 // ideally all buffer classes should have templated by datatype
│ │ │ │ -
533 // so that downcast isn't needed there.
│ │ │ │ -
534 // (e.g. Osd::CpuBuffer<PatchCoord> )
│ │ │ │ -
535 //
│ │ │ │ -
536 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
537 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
538 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
539 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
540 numPatchCoords,
│ │ │ │ -
541 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
542 patchTable->GetPatchArrayBuffer(),
│ │ │ │ -
543 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
544 patchTable->GetPatchParamBuffer());
│ │ │ │ -
545 }
│ │ │ │ -
│ │ │ │ -
546
│ │ │ │ -
605 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
606 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
607 static bool EvalPatches(
│ │ │ │ -
608 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
609 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
610 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
611 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
612 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
613 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
614 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
615 int numPatchCoords,
│ │ │ │ -
616 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
617 PATCH_TABLE *patchTable,
│ │ │ │ -
618 TbbEvaluator const *instance = NULL,
│ │ │ │ -
619 void * deviceContext = NULL) {
│ │ │ │ -
620
│ │ │ │ -
621 (void)instance; // unused
│ │ │ │ -
622 (void)deviceContext; // unused
│ │ │ │ -
623
│ │ │ │ -
624 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop.
│ │ │ │ -
625 // ideally all buffer classes should have templated by datatype
│ │ │ │ -
626 // so that downcast isn't needed there.
│ │ │ │ -
627 // (e.g. Osd::CpuBuffer<PatchCoord> )
│ │ │ │ -
628 //
│ │ │ │ -
629 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
630 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
631 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
632 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
633 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ -
634 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ -
635 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ -
636 numPatchCoords,
│ │ │ │ -
637 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
638 patchTable->GetPatchArrayBuffer(),
│ │ │ │ -
639 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
640 patchTable->GetPatchParamBuffer());
│ │ │ │ -
641 }
│ │ │ │ -
│ │ │ │ -
642
│ │ │ │ -
670 static bool EvalPatches(
│ │ │ │ -
671 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
672 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
673 int numPatchCoords,
│ │ │ │ -
674 const PatchCoord *patchCoords,
│ │ │ │ -
675 const PatchArray *patchArrays,
│ │ │ │ -
676 const int *patchIndexBuffer,
│ │ │ │ -
677 const PatchParam *patchParamBuffer);
│ │ │ │ -
678
│ │ │ │ -
716 static bool EvalPatches(
│ │ │ │ -
717 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
718 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
719 float *du, BufferDescriptor const &duDesc,
│ │ │ │ -
720 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ -
721 int numPatchCoords,
│ │ │ │ -
722 PatchCoord const *patchCoords,
│ │ │ │ -
723 PatchArray const *patchArrays,
│ │ │ │ -
724 const int *patchIndexBuffer,
│ │ │ │ -
725 PatchParam const *patchParamBuffer);
│ │ │ │ -
726
│ │ │ │ -
779 static bool EvalPatches(
│ │ │ │ -
780 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
781 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
782 float *du, BufferDescriptor const &duDesc,
│ │ │ │ -
783 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ -
784 float *duu, BufferDescriptor const &duuDesc,
│ │ │ │ -
785 float *duv, BufferDescriptor const &duvDesc,
│ │ │ │ -
786 float *dvv, BufferDescriptor const &dvvDesc,
│ │ │ │ -
787 int numPatchCoords,
│ │ │ │ -
788 PatchCoord const *patchCoords,
│ │ │ │ -
789 PatchArray const *patchArrays,
│ │ │ │ -
790 const int *patchIndexBuffer,
│ │ │ │ -
791 PatchParam const *patchParamBuffer);
│ │ │ │ -
792
│ │ │ │ -
821 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
822 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
824 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
825 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
826 int numPatchCoords,
│ │ │ │ -
827 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
828 PATCH_TABLE *patchTable,
│ │ │ │ -
829 TbbEvaluator const *instance = NULL,
│ │ │ │ -
830 void * deviceContext = NULL) {
│ │ │ │ -
831
│ │ │ │ -
832 (void)instance; // unused
│ │ │ │ -
833 (void)deviceContext; // unused
│ │ │ │ -
834
│ │ │ │ -
835 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
836 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
837 numPatchCoords,
│ │ │ │ -
838 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
839 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ -
840 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
841 patchTable->GetPatchParamBuffer());
│ │ │ │ -
842 }
│ │ │ │ -
│ │ │ │ -
843
│ │ │ │ -
884 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
885 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
887 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
888 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
889 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
890 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
891 int numPatchCoords,
│ │ │ │ -
892 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
893 PATCH_TABLE *patchTable,
│ │ │ │ -
894 TbbEvaluator const *instance = NULL,
│ │ │ │ -
895 void * deviceContext = NULL) {
│ │ │ │ -
896
│ │ │ │ -
897 (void)instance; // unused
│ │ │ │ -
898 (void)deviceContext; // unused
│ │ │ │ -
899
│ │ │ │ -
900 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
901 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
902 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
903 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
904 numPatchCoords,
│ │ │ │ -
905 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
906 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ -
907 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
908 patchTable->GetPatchParamBuffer());
│ │ │ │ -
909 }
│ │ │ │ -
│ │ │ │ -
910
│ │ │ │ -
969 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
970 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
972 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
973 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
974 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
975 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
976 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
977 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
978 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
979 int numPatchCoords,
│ │ │ │ -
980 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
981 PATCH_TABLE *patchTable,
│ │ │ │ -
982 TbbEvaluator const *instance = NULL,
│ │ │ │ -
983 void * deviceContext = NULL) {
│ │ │ │ -
984
│ │ │ │ -
985 (void)instance; // unused
│ │ │ │ -
986 (void)deviceContext; // unused
│ │ │ │ -
987
│ │ │ │ -
988 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
989 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
990 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
991 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
992 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ -
993 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ -
994 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ -
995 numPatchCoords,
│ │ │ │ -
996 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
997 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ -
998 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
999 patchTable->GetPatchParamBuffer());
│ │ │ │ -
1000 }
│ │ │ │ -
│ │ │ │ -
1001
│ │ │ │ -
1032 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1033 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1035 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1036 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1037 int numPatchCoords,
│ │ │ │ -
1038 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1039 PATCH_TABLE *patchTable,
│ │ │ │ -
1040 int fvarChannel,
│ │ │ │ -
1041 TbbEvaluator const *instance = NULL,
│ │ │ │ -
1042 void * deviceContext = NULL) {
│ │ │ │ -
1043
│ │ │ │ -
1044 (void)instance; // unused
│ │ │ │ -
1045 (void)deviceContext; // unused
│ │ │ │ -
1046
│ │ │ │ -
1047 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
1048 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
1049 numPatchCoords,
│ │ │ │ -
1050 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
1051 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ -
1052 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
1053 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ -
1054 }
│ │ │ │ -
│ │ │ │ -
1055
│ │ │ │ -
1098 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1099 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1101 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1102 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1103 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1104 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1105 int numPatchCoords,
│ │ │ │ -
1106 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1107 PATCH_TABLE *patchTable,
│ │ │ │ -
1108 int fvarChannel,
│ │ │ │ -
1109 TbbEvaluator const *instance = NULL,
│ │ │ │ -
1110 void * deviceContext = NULL) {
│ │ │ │ -
1111
│ │ │ │ -
1112 (void)instance; // unused
│ │ │ │ -
1113 (void)deviceContext; // unused
│ │ │ │ -
1114
│ │ │ │ -
1115 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
1116 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
1117 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
1118 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
1119 numPatchCoords,
│ │ │ │ -
1120 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
1121 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ -
1122 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
1123 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ -
1124 }
│ │ │ │ -
│ │ │ │ -
1125
│ │ │ │ -
1186 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1187 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1189 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1190 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1191 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1192 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1193 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
1194 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
1195 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
1196 int numPatchCoords,
│ │ │ │ -
1197 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1198 PATCH_TABLE *patchTable,
│ │ │ │ -
1199 int fvarChannel,
│ │ │ │ -
1200 TbbEvaluator const *instance = NULL,
│ │ │ │ -
1201 void * deviceContext = NULL) {
│ │ │ │ -
1202
│ │ │ │ -
1203 (void)instance; // unused
│ │ │ │ -
1204 (void)deviceContext; // unused
│ │ │ │ -
1205
│ │ │ │ -
1206 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
1207 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
1208 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
1209 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
1210 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ -
1211 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ -
1212 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ -
1213 numPatchCoords,
│ │ │ │ -
1214 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
1215 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ -
1216 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
1217 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ -
1218 }
│ │ │ │ -
│ │ │ │ -
1219
│ │ │ │ -
1225
│ │ │ │ -
1227 static void Synchronize(void *deviceContext = NULL);
│ │ │ │ -
1228
│ │ │ │ -
1233 static void SetNumThreads(int numThreads);
│ │ │ │ -
1234};
│ │ │ │ -
│ │ │ │ -
1235
│ │ │ │ -
1236
│ │ │ │ -
1237} // end namespace Osd
│ │ │ │ -
1238
│ │ │ │ -
1239} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
1240using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
1241
│ │ │ │ -
1242} // end namespace OpenSubdiv
│ │ │ │ -
1243
│ │ │ │ -
1244
│ │ │ │ -
1245#endif // OPENSUBDIV3_OSD_TBB_EVALUATOR_H
│ │ │ │ - │ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ - │ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function. This function has a same signature as other device kernels hav...
│ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, const TbbEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │ -
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, int start, int end)
Static eval stencils function which takes raw CPU pointers for input and output.
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ -
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │ -
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, float *dvv, BufferDescriptor const &dvvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, const float *duuWeights, const float *duvWeights, const float *dvvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │ -
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, float *dvv, BufferDescriptor const &dvvDesc, int numPatchCoords, PatchCoord const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, PatchParam const *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ -
static void Synchronize(void *deviceContext=NULL)
synchronize all asynchronous computation invoked on this device.
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, int numPatchCoords, PatchCoord const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, PatchParam const *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ -
static void SetNumThreads(int numThreads)
Deprecated. Client code should initialize TBB.
│ │ │ │ -
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrays, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const TbbEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
37struct PatchArray;
│ │ │ │ +
38struct PatchCoord;
│ │ │ │ +
39struct PatchParam;
│ │ │ │ +
40struct BufferDescriptor;
│ │ │ │ +
41
│ │ │ │ +
42void
│ │ │ │ +
43TbbEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ +
44 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
45 int const * sizes,
│ │ │ │ +
46 int const * offsets,
│ │ │ │ +
47 int const * indices,
│ │ │ │ +
48 float const * weights,
│ │ │ │ +
49 int start, int end);
│ │ │ │ +
50
│ │ │ │ +
51void
│ │ │ │ +
52TbbEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ +
53 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
54 float * dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ +
55 float * dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ +
56 int const * sizes,
│ │ │ │ +
57 int const * offsets,
│ │ │ │ +
58 int const * indices,
│ │ │ │ +
59 float const * weights,
│ │ │ │ +
60 float const * duWeights,
│ │ │ │ +
61 float const * dvWeights,
│ │ │ │ +
62 int start, int end);
│ │ │ │ +
63
│ │ │ │ +
64void
│ │ │ │ +
65TbbEvalStencils(float const * src, BufferDescriptor const &srcDesc,
│ │ │ │ +
66 float * dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
67 float * dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ +
68 float * dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ +
69 float * dstDuu, BufferDescriptor const &dstDuuDesc,
│ │ │ │ +
70 float * dstDuv, BufferDescriptor const &dstDuvDesc,
│ │ │ │ +
71 float * dstDvv, BufferDescriptor const &dstDvvDesc,
│ │ │ │ +
72 int const * sizes,
│ │ │ │ +
73 int const * offsets,
│ │ │ │ +
74 int const * indices,
│ │ │ │ +
75 float const * weights,
│ │ │ │ +
76 float const * duWeights,
│ │ │ │ +
77 float const * dvWeights,
│ │ │ │ +
78 float const * duuWeights,
│ │ │ │ +
79 float const * duvWeights,
│ │ │ │ +
80 float const * dvvWeights,
│ │ │ │ +
81 int start, int end);
│ │ │ │ +
82
│ │ │ │ +
83void
│ │ │ │ +
84TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
85 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
86 float *dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ +
87 float *dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ +
88 int numPatchCoords,
│ │ │ │ +
89 const PatchCoord *patchCoords,
│ │ │ │ +
90 const PatchArray *patchArrayBuffer,
│ │ │ │ +
91 const int *patchIndexBuffer,
│ │ │ │ +
92 const PatchParam *patchParamBuffer);
│ │ │ │ +
93
│ │ │ │ +
94void
│ │ │ │ +
95TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
96 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
97 float *dstDu, BufferDescriptor const &dstDuDesc,
│ │ │ │ +
98 float *dstDv, BufferDescriptor const &dstDvDesc,
│ │ │ │ +
99 float *dstDuu, BufferDescriptor const &dstDuuDesc,
│ │ │ │ +
100 float *dstDuv, BufferDescriptor const &dstDuvDesc,
│ │ │ │ +
101 float *dstDvv, BufferDescriptor const &dstDvvDesc,
│ │ │ │ +
102 int numPatchCoords,
│ │ │ │ +
103 const PatchCoord *patchCoords,
│ │ │ │ +
104 const PatchArray *patchArrayBuffer,
│ │ │ │ +
105 const int *patchIndexBuffer,
│ │ │ │ +
106 const PatchParam *patchParamBuffer);
│ │ │ │ +
107
│ │ │ │ +
108} // end namespace Osd
│ │ │ │ +
109
│ │ │ │ +
110} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
111using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
112
│ │ │ │ +
113} // end namespace OpenSubdiv
│ │ │ │ +
114
│ │ │ │ +
115#endif // OPENSUBDIV3_OSD_TBB_KERNEL_H
│ │ │ │ + │ │ │ │ +
void TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrayBuffer, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
│ │ │ │ +
void TbbEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)
│ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │
Coordinates set on a patch table.
Definition types.h:42
│ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -tbbEvaluator.h │ │ │ │ │ +tbbKernel.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ -2// Copyright 2015 Pixar │ │ │ │ │ +2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ 7// Section 6. Trademarks. is deleted and replaced with: │ │ │ │ │ 8// │ │ │ │ │ 9// 6. Trademarks. This License does not grant permission to use the trade │ │ │ │ │ @@ -24,657 +24,126 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_TBB_EVALUATOR_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_TBB_EVALUATOR_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_TBB_KERNEL_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_TBB_KERNEL_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29#include "../osd/bufferDescriptor.h" │ │ │ │ │ -30#include "../osd/types.h" │ │ │ │ │ +29#include "../far/patchDescriptor.h" │ │ │ │ │ +30#include "../far/patchParam.h" │ │ │ │ │ 31 │ │ │ │ │ -32#include │ │ │ │ │ -33 │ │ │ │ │ -34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -35namespace OPENSUBDIV_VERSION { │ │ │ │ │ +32namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +33namespace OPENSUBDIV_VERSION { │ │ │ │ │ +34 │ │ │ │ │ +35namespace Osd { │ │ │ │ │ 36 │ │ │ │ │ -37namespace Osd { │ │ │ │ │ -38 │ │ │ │ │ -_3_9class _T_b_b_E_v_a_l_u_a_t_o_r { │ │ │ │ │ -40public: │ │ │ │ │ -46 │ │ │ │ │ -71 template │ │ │ │ │ -_7_2 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -73 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -74 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -75 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -76 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -77 void *deviceContext = NULL) { │ │ │ │ │ -78 │ │ │ │ │ -79 (void)instance; // unused │ │ │ │ │ -80 (void)deviceContext; // unused │ │ │ │ │ -81 │ │ │ │ │ -82 if (stencilTable->GetNumStencils() == 0) │ │ │ │ │ -83 return false; │ │ │ │ │ -84 │ │ │ │ │ -85 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -86 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -87 &stencilTable->GetSizes()[0], │ │ │ │ │ -88 &stencilTable->GetOffsets()[0], │ │ │ │ │ -89 &stencilTable->GetControlIndices()[0], │ │ │ │ │ -90 &stencilTable->GetWeights()[0], │ │ │ │ │ -91 /*start = */ 0, │ │ │ │ │ -92 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ -93 } │ │ │ │ │ -94 │ │ │ │ │ -_1_2_1 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -122 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -123 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -124 const int * sizes, │ │ │ │ │ -125 const int * offsets, │ │ │ │ │ -126 const int * indices, │ │ │ │ │ -127 const float * weights, │ │ │ │ │ -128 int start, int end); │ │ │ │ │ -129 │ │ │ │ │ -167 template │ │ │ │ │ -_1_6_8 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -169 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -170 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -171 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -172 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -173 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -174 const _T_b_b_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ -175 void * deviceContext = NULL) { │ │ │ │ │ -176 │ │ │ │ │ -177 (void)instance; // unused │ │ │ │ │ -178 (void)deviceContext; // unused │ │ │ │ │ -179 │ │ │ │ │ -180 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -181 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -182 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -183 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -184 &stencilTable->GetSizes()[0], │ │ │ │ │ -185 &stencilTable->GetOffsets()[0], │ │ │ │ │ -186 &stencilTable->GetControlIndices()[0], │ │ │ │ │ -187 &stencilTable->GetWeights()[0], │ │ │ │ │ -188 &stencilTable->GetDuWeights()[0], │ │ │ │ │ -189 &stencilTable->GetDvWeights()[0], │ │ │ │ │ -190 /*start = */ 0, │ │ │ │ │ -191 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ -192 } │ │ │ │ │ -193 │ │ │ │ │ -_2_3_4 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -235 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -236 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -237 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -238 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -239 const int * sizes, │ │ │ │ │ -240 const int * offsets, │ │ │ │ │ -241 const int * indices, │ │ │ │ │ -242 const float * weights, │ │ │ │ │ -243 const float * duWeights, │ │ │ │ │ -244 const float * dvWeights, │ │ │ │ │ -245 int start, int end); │ │ │ │ │ -246 │ │ │ │ │ -302 template │ │ │ │ │ -_3_0_3 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -304 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -305 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -306 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -307 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -308 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -309 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -310 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -311 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -312 const _T_b_b_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ -313 void * deviceContext = NULL) { │ │ │ │ │ -314 │ │ │ │ │ -315 (void)instance; // unused │ │ │ │ │ -316 (void)deviceContext; // unused │ │ │ │ │ -317 │ │ │ │ │ -318 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -319 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -320 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -321 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -322 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ -323 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ -324 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ -325 &stencilTable->GetSizes()[0], │ │ │ │ │ -326 &stencilTable->GetOffsets()[0], │ │ │ │ │ -327 &stencilTable->GetControlIndices()[0], │ │ │ │ │ -328 &stencilTable->GetWeights()[0], │ │ │ │ │ -329 &stencilTable->GetDuWeights()[0], │ │ │ │ │ -330 &stencilTable->GetDvWeights()[0], │ │ │ │ │ -331 &stencilTable->GetDuuWeights()[0], │ │ │ │ │ -332 &stencilTable->GetDuvWeights()[0], │ │ │ │ │ -333 &stencilTable->GetDvvWeights()[0], │ │ │ │ │ -334 /*start = */ 0, │ │ │ │ │ -335 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ -336 } │ │ │ │ │ -337 │ │ │ │ │ -_3_9_9 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -400 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -401 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -402 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -403 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -404 float *duu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -405 float *duv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -406 float *dvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -407 const int * sizes, │ │ │ │ │ -408 const int * offsets, │ │ │ │ │ -409 const int * indices, │ │ │ │ │ -410 const float * weights, │ │ │ │ │ -411 const float * duWeights, │ │ │ │ │ -412 const float * dvWeights, │ │ │ │ │ -413 const float * duuWeights, │ │ │ │ │ -414 const float * duvWeights, │ │ │ │ │ -415 const float * dvvWeights, │ │ │ │ │ -416 int start, int end); │ │ │ │ │ -417 │ │ │ │ │ -423 │ │ │ │ │ -452 template │ │ │ │ │ -_4_5_4 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -455 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -456 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -457 int numPatchCoords, │ │ │ │ │ -458 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -459 PATCH_TABLE *patchTable, │ │ │ │ │ -460 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -461 void * deviceContext = NULL) { │ │ │ │ │ -462 │ │ │ │ │ -463 (void)instance; // unused │ │ │ │ │ -464 (void)deviceContext; // unused │ │ │ │ │ -465 │ │ │ │ │ -466 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -467 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -468 numPatchCoords, │ │ │ │ │ -469 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -470 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ -471 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -472 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -473 } │ │ │ │ │ -474 │ │ │ │ │ -515 template │ │ │ │ │ -_5_1_7 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -518 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -519 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -520 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -521 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -522 int numPatchCoords, │ │ │ │ │ -523 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -524 PATCH_TABLE *patchTable, │ │ │ │ │ -525 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -526 void * deviceContext = NULL) { │ │ │ │ │ -527 │ │ │ │ │ -528 (void)instance; // unused │ │ │ │ │ -529 (void)deviceContext; // unused │ │ │ │ │ -530 │ │ │ │ │ -531 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop. │ │ │ │ │ -532 // ideally all buffer classes should have templated by datatype │ │ │ │ │ -533 // so that downcast isn't needed there. │ │ │ │ │ -534 // (e.g. Osd::CpuBuffer ) │ │ │ │ │ -535 // │ │ │ │ │ -536 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -537 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -538 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -539 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -540 numPatchCoords, │ │ │ │ │ -541 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -542 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ -543 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -544 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -545 } │ │ │ │ │ -546 │ │ │ │ │ -605 template │ │ │ │ │ -_6_0_7 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -608 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -609 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -610 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -611 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -612 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -613 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -614 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -615 int numPatchCoords, │ │ │ │ │ -616 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -617 PATCH_TABLE *patchTable, │ │ │ │ │ -618 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -619 void * deviceContext = NULL) { │ │ │ │ │ -620 │ │ │ │ │ -621 (void)instance; // unused │ │ │ │ │ -622 (void)deviceContext; // unused │ │ │ │ │ -623 │ │ │ │ │ -624 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop. │ │ │ │ │ -625 // ideally all buffer classes should have templated by datatype │ │ │ │ │ -626 // so that downcast isn't needed there. │ │ │ │ │ -627 // (e.g. Osd::CpuBuffer ) │ │ │ │ │ -628 // │ │ │ │ │ -629 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -630 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -631 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -632 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -633 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ -634 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ -635 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ -636 numPatchCoords, │ │ │ │ │ -637 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -638 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ -639 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -640 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -641 } │ │ │ │ │ -642 │ │ │ │ │ -_6_7_0 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -671 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -672 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -673 int numPatchCoords, │ │ │ │ │ -674 const _P_a_t_c_h_C_o_o_r_d *patchCoords, │ │ │ │ │ -675 const _P_a_t_c_h_A_r_r_a_y *patchArrays, │ │ │ │ │ -676 const int *patchIndexBuffer, │ │ │ │ │ -677 const _P_a_t_c_h_P_a_r_a_m *patchParamBuffer); │ │ │ │ │ -678 │ │ │ │ │ -_7_1_6 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -717 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -718 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -719 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -720 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -721 int numPatchCoords, │ │ │ │ │ -722 _P_a_t_c_h_C_o_o_r_d const *patchCoords, │ │ │ │ │ -723 _P_a_t_c_h_A_r_r_a_y const *patchArrays, │ │ │ │ │ -724 const int *patchIndexBuffer, │ │ │ │ │ -725 _P_a_t_c_h_P_a_r_a_m const *patchParamBuffer); │ │ │ │ │ -726 │ │ │ │ │ -_7_7_9 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -780 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -781 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -782 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -783 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -784 float *duu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -785 float *duv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -786 float *dvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -787 int numPatchCoords, │ │ │ │ │ -788 _P_a_t_c_h_C_o_o_r_d const *patchCoords, │ │ │ │ │ -789 _P_a_t_c_h_A_r_r_a_y const *patchArrays, │ │ │ │ │ -790 const int *patchIndexBuffer, │ │ │ │ │ -791 _P_a_t_c_h_P_a_r_a_m const *patchParamBuffer); │ │ │ │ │ -792 │ │ │ │ │ -821 template │ │ │ │ │ -_8_2_3 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -824 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -825 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -826 int numPatchCoords, │ │ │ │ │ -827 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -828 PATCH_TABLE *patchTable, │ │ │ │ │ -829 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -830 void * deviceContext = NULL) { │ │ │ │ │ -831 │ │ │ │ │ -832 (void)instance; // unused │ │ │ │ │ -833 (void)deviceContext; // unused │ │ │ │ │ -834 │ │ │ │ │ -835 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -836 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -837 numPatchCoords, │ │ │ │ │ -838 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -839 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ -840 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -841 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -842 } │ │ │ │ │ -843 │ │ │ │ │ -884 template │ │ │ │ │ -_8_8_6 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -887 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -888 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -889 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -890 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -891 int numPatchCoords, │ │ │ │ │ -892 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -893 PATCH_TABLE *patchTable, │ │ │ │ │ -894 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -895 void * deviceContext = NULL) { │ │ │ │ │ -896 │ │ │ │ │ -897 (void)instance; // unused │ │ │ │ │ -898 (void)deviceContext; // unused │ │ │ │ │ -899 │ │ │ │ │ -900 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -901 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -902 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -903 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -904 numPatchCoords, │ │ │ │ │ -905 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -906 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ -907 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -908 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -909 } │ │ │ │ │ -910 │ │ │ │ │ -969 template │ │ │ │ │ -_9_7_1 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -972 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -973 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -974 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -975 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -976 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -977 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -978 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -979 int numPatchCoords, │ │ │ │ │ -980 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -981 PATCH_TABLE *patchTable, │ │ │ │ │ -982 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -983 void * deviceContext = NULL) { │ │ │ │ │ -984 │ │ │ │ │ -985 (void)instance; // unused │ │ │ │ │ -986 (void)deviceContext; // unused │ │ │ │ │ -987 │ │ │ │ │ -988 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -989 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -990 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -991 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -992 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ -993 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ -994 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ -995 numPatchCoords, │ │ │ │ │ -996 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -997 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ -998 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -999 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -1000 } │ │ │ │ │ -1001 │ │ │ │ │ -1032 template │ │ │ │ │ -_1_0_3_4 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1035 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1036 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1037 int numPatchCoords, │ │ │ │ │ -1038 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1039 PATCH_TABLE *patchTable, │ │ │ │ │ -1040 int fvarChannel, │ │ │ │ │ -1041 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -1042 void * deviceContext = NULL) { │ │ │ │ │ -1043 │ │ │ │ │ -1044 (void)instance; // unused │ │ │ │ │ -1045 (void)deviceContext; // unused │ │ │ │ │ -1046 │ │ │ │ │ -1047 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -1048 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -1049 numPatchCoords, │ │ │ │ │ -1050 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -1051 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ -1052 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -1053 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ -1054 } │ │ │ │ │ -1055 │ │ │ │ │ -1098 template │ │ │ │ │ -_1_1_0_0 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1101 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1102 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1103 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1104 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1105 int numPatchCoords, │ │ │ │ │ -1106 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1107 PATCH_TABLE *patchTable, │ │ │ │ │ -1108 int fvarChannel, │ │ │ │ │ -1109 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -1110 void * deviceContext = NULL) { │ │ │ │ │ -1111 │ │ │ │ │ -1112 (void)instance; // unused │ │ │ │ │ -1113 (void)deviceContext; // unused │ │ │ │ │ -1114 │ │ │ │ │ -1115 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -1116 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -1117 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -1118 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -1119 numPatchCoords, │ │ │ │ │ -1120 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -1121 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ -1122 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -1123 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ -1124 } │ │ │ │ │ -1125 │ │ │ │ │ -1186 template │ │ │ │ │ -_1_1_8_8 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1189 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1190 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1191 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1192 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1193 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -1194 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -1195 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -1196 int numPatchCoords, │ │ │ │ │ -1197 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1198 PATCH_TABLE *patchTable, │ │ │ │ │ -1199 int fvarChannel, │ │ │ │ │ -1200 _T_b_b_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -1201 void * deviceContext = NULL) { │ │ │ │ │ -1202 │ │ │ │ │ -1203 (void)instance; // unused │ │ │ │ │ -1204 (void)deviceContext; // unused │ │ │ │ │ -1205 │ │ │ │ │ -1206 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -1207 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -1208 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -1209 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -1210 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ -1211 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ -1212 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ -1213 numPatchCoords, │ │ │ │ │ -1214 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -1215 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ -1216 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -1217 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ -1218 } │ │ │ │ │ -1219 │ │ │ │ │ -1225 │ │ │ │ │ -_1_2_2_7 static void _S_y_n_c_h_r_o_n_i_z_e(void *deviceContext = NULL); │ │ │ │ │ -1228 │ │ │ │ │ -_1_2_3_3 static void _S_e_t_N_u_m_T_h_r_e_a_d_s(int numThreads); │ │ │ │ │ -1234}; │ │ │ │ │ -1235 │ │ │ │ │ -1236 │ │ │ │ │ -1237} // end namespace Osd │ │ │ │ │ -1238 │ │ │ │ │ -1239} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -1240using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -1241 │ │ │ │ │ -1242} // end namespace OpenSubdiv │ │ │ │ │ -1243 │ │ │ │ │ -1244 │ │ │ │ │ -1245#endif // OPENSUBDIV3_OSD_TBB_EVALUATOR_H │ │ │ │ │ +37struct PatchArray; │ │ │ │ │ +38struct PatchCoord; │ │ │ │ │ +39struct PatchParam; │ │ │ │ │ +40struct BufferDescriptor; │ │ │ │ │ +41 │ │ │ │ │ +42void │ │ │ │ │ +_4_3_T_b_b_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +44 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +45 int const * sizes, │ │ │ │ │ +46 int const * offsets, │ │ │ │ │ +47 int const * indices, │ │ │ │ │ +48 float const * weights, │ │ │ │ │ +49 int start, int end); │ │ │ │ │ +50 │ │ │ │ │ +51void │ │ │ │ │ +_5_2_T_b_b_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +53 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +54 float * dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ +55 float * dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ +56 int const * sizes, │ │ │ │ │ +57 int const * offsets, │ │ │ │ │ +58 int const * indices, │ │ │ │ │ +59 float const * weights, │ │ │ │ │ +60 float const * duWeights, │ │ │ │ │ +61 float const * dvWeights, │ │ │ │ │ +62 int start, int end); │ │ │ │ │ +63 │ │ │ │ │ +64void │ │ │ │ │ +_6_5_T_b_b_E_v_a_l_S_t_e_n_c_i_l_s(float const * src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +66 float * dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +67 float * dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ +68 float * dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ +69 float * dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, │ │ │ │ │ +70 float * dstDuv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, │ │ │ │ │ +71 float * dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvvDesc, │ │ │ │ │ +72 int const * sizes, │ │ │ │ │ +73 int const * offsets, │ │ │ │ │ +74 int const * indices, │ │ │ │ │ +75 float const * weights, │ │ │ │ │ +76 float const * duWeights, │ │ │ │ │ +77 float const * dvWeights, │ │ │ │ │ +78 float const * duuWeights, │ │ │ │ │ +79 float const * duvWeights, │ │ │ │ │ +80 float const * dvvWeights, │ │ │ │ │ +81 int start, int end); │ │ │ │ │ +82 │ │ │ │ │ +83void │ │ │ │ │ +_8_4_T_b_b_E_v_a_l_P_a_t_c_h_e_s(float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +85 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +86 float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ +87 float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ +88 int numPatchCoords, │ │ │ │ │ +89 const _P_a_t_c_h_C_o_o_r_d *patchCoords, │ │ │ │ │ +90 const _P_a_t_c_h_A_r_r_a_y *patchArrayBuffer, │ │ │ │ │ +91 const int *patchIndexBuffer, │ │ │ │ │ +92 const _P_a_t_c_h_P_a_r_a_m *patchParamBuffer); │ │ │ │ │ +93 │ │ │ │ │ +94void │ │ │ │ │ +_9_5_T_b_b_E_v_a_l_P_a_t_c_h_e_s(float const *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +96 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +97 float *dstDu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuDesc, │ │ │ │ │ +98 float *dstDv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvDesc, │ │ │ │ │ +99 float *dstDuu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuuDesc, │ │ │ │ │ +100 float *dstDuv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDuvDesc, │ │ │ │ │ +101 float *dstDvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDvvDesc, │ │ │ │ │ +102 int numPatchCoords, │ │ │ │ │ +103 const _P_a_t_c_h_C_o_o_r_d *patchCoords, │ │ │ │ │ +104 const _P_a_t_c_h_A_r_r_a_y *patchArrayBuffer, │ │ │ │ │ +105 const int *patchIndexBuffer, │ │ │ │ │ +106 const _P_a_t_c_h_P_a_r_a_m *patchParamBuffer); │ │ │ │ │ +107 │ │ │ │ │ +108} // end namespace Osd │ │ │ │ │ +109 │ │ │ │ │ +110} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +111using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +112 │ │ │ │ │ +113} // end namespace OpenSubdiv │ │ │ │ │ +114 │ │ │ │ │ +115#endif // OPENSUBDIV3_OSD_TBB_KERNEL_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +void TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc, float │ │ │ │ │ +*dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const │ │ │ │ │ +&dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int │ │ │ │ │ +numPatchCoords, const PatchCoord *patchCoords, const PatchArray │ │ │ │ │ +*patchArrayBuffer, const int *patchIndexBuffer, const PatchParam │ │ │ │ │ +*patchParamBuffer) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +void TbbEvalStencils(float const *src, BufferDescriptor const &srcDesc, float │ │ │ │ │ +*dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, │ │ │ │ │ +int const *indices, float const *weights, int start, int end) │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ data buffers.... │ │ │ │ │ DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_3_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE │ │ │ │ │ -const *stencilTable, TbbEvaluator const *instance=NULL, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -Generic static eval stencils function. This function has a same signature as │ │ │ │ │ -other device kernels hav... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const │ │ │ │ │ -*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_4_5_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, │ │ │ │ │ -const TbbEvaluator *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic static eval stencils function with derivatives. This function has a │ │ │ │ │ -same signature as other d... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_3_0_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int │ │ │ │ │ -*offsets, const int *indices, const float *weights, int start, int end) │ │ │ │ │ -Static eval stencils function which takes raw CPU pointers for input and │ │ │ │ │ -output. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_8_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ -*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ -BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const *instance=NULL, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -Generic limit eval function with derivatives. This function has a same │ │ │ │ │ -signature as other device kern... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_6_0_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ -&duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int │ │ │ │ │ -*offsets, const int *indices, const float *weights, const float *duWeights, │ │ │ │ │ -const float *dvWeights, int start, int end) │ │ │ │ │ -Static eval stencils function with derivatives, which takes raw CPU pointers │ │ │ │ │ -for input and output. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ -&duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, │ │ │ │ │ -BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, │ │ │ │ │ -float *dvv, BufferDescriptor const &dvvDesc, const int *sizes, const int │ │ │ │ │ -*offsets, const int *indices, const float *weights, const float *duWeights, │ │ │ │ │ -const float *dvWeights, const float *duuWeights, const float *duvWeights, const │ │ │ │ │ -float *dvvWeights, int start, int end) │ │ │ │ │ -Static eval stencils function with derivatives, which takes raw CPU pointers │ │ │ │ │ -for input and output. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ -&duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, │ │ │ │ │ -BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, │ │ │ │ │ -float *dvv, BufferDescriptor const &dvvDesc, int numPatchCoords, PatchCoord │ │ │ │ │ -const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, │ │ │ │ │ -PatchParam const *patchParamBuffer) │ │ │ │ │ -Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ -values on given PatchT... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_S_y_n_c_h_r_o_n_i_z_e │ │ │ │ │ -static void Synchronize(void *deviceContext=NULL) │ │ │ │ │ -synchronize all asynchronous computation invoked on this device. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, TbbEvaluator const │ │ │ │ │ -*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_9_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ -DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, int fvarChannel, TbbEvaluator const │ │ │ │ │ -*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_1_1_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ -*patchTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function with derivatives. This function has a same │ │ │ │ │ -signature as other device kern... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_5_1_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ -numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int │ │ │ │ │ -fvarChannel, TbbEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_1_0_3_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ -&duDesc, float *dv, BufferDescriptor const &dvDesc, int numPatchCoords, │ │ │ │ │ -PatchCoord const *patchCoords, PatchArray const *patchArrays, const int │ │ │ │ │ -*patchIndexBuffer, PatchParam const *patchParamBuffer) │ │ │ │ │ -Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ -values on given PatchT... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_S_e_t_N_u_m_T_h_r_e_a_d_s │ │ │ │ │ -static void SetNumThreads(int numThreads) │ │ │ │ │ -Deprecated. Client code should initialize TBB. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, int numPatchCoords, const │ │ │ │ │ -PatchCoord *patchCoords, const PatchArray *patchArrays, const int │ │ │ │ │ -*patchIndexBuffer, const PatchParam *patchParamBuffer) │ │ │ │ │ -Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ -values on given PatchT... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const │ │ │ │ │ -TbbEvaluator *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic static eval stencils function with derivatives. This function has a │ │ │ │ │ -same signature as other d... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_1_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ -DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, │ │ │ │ │ -TbbEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_1_1_8_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_T_b_b_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ -numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, │ │ │ │ │ -TbbEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _t_b_b_E_v_a_l_u_a_t_o_r_._h_:_8_2_3 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_C_o_o_r_d │ │ │ │ │ Coordinates set on a patch table. │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_2 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_A_r_r_a_y │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_6_6 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_P_a_r_a_m │ │ │ │ │ DDeeffiinniittiioonn _t_y_p_e_s_._h_:_1_2_7 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _t_b_b_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ + * _t_b_b_K_e_r_n_e_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00881.html │ │ │ │ @@ -94,15 +94,15 @@ │ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │
ompEvaluator.h File Reference
│ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │ #include "../osd/types.h"
│ │ │ │ #include <cstddef>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00881_source.html │ │ │ │ @@ -603,16 +603,16 @@ │ │ │ │
1235} // end namespace OPENSUBDIV_VERSION
│ │ │ │
1236using namespace OPENSUBDIV_VERSION;
│ │ │ │
1237
│ │ │ │
1238} // end namespace OpenSubdiv
│ │ │ │
1239
│ │ │ │
1240
│ │ │ │
1241#endif // OPENSUBDIV3_OSD_OMP_EVALUATOR_H
│ │ │ │ - │ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ + │ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ │ │ │ │
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, OmpEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, int start, int end)
Static eval stencils function which takes raw CPU pointers for input and output.
│ │ │ │
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, OmpEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const OmpEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, OmpEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00884.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/opengl.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/cpuVertexBuffer.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -87,24 +87,44 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
opengl.h File Reference
│ │ │ │ +
│ │ │ │ +Classes | │ │ │ │ +Namespaces
│ │ │ │ +
cpuVertexBuffer.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │ -
#include <GL/gl.h>
│ │ │ │ +
#include "../version.h"
│ │ │ │ +#include <cstddef>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ +

│ │ │ │ Classes

│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +

│ │ │ │ +Classes

class  CpuVertexBuffer
 Concrete vertex buffer class for CPU subdivision. More...
 
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +

│ │ │ │ +Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,11 +1,24 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -opengl.h File Reference │ │ │ │ │ -#include │ │ │ │ │ +_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ +cpuVertexBuffer.h File Reference │ │ │ │ │ +#include "../version.h" │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ +CCllaasssseess │ │ │ │ │ +class   _C_p_u_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +  Concrete vertex buffer class for CPU subdivision. _M_o_r_e_._._. │ │ │ │ │ +  │ │ │ │ │ +NNaammeessppaacceess │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ +  │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │ +  │ │ │ │ │ +namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │ +  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _o_p_e_n_g_l_._h │ │ │ │ │ + * _c_p_u_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00884_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/opengl.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/cpuVertexBuffer.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
opengl.h
│ │ │ │ +
cpuVertexBuffer.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,47 +119,75 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_OPENGL_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_OPENGL_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H
│ │ │ │
27
│ │ │ │ -
28#if defined(__APPLE__)
│ │ │ │ -
29 #include "TargetConditionals.h"
│ │ │ │ -
30 #if TARGET_OS_IPHONE || TARGET_IPHONE_SIMULATOR
│ │ │ │ -
31 #include <OpenGLES/ES2/gl.h>
│ │ │ │ -
32 #else
│ │ │ │ -
33 #if defined(OSD_USES_GLEW)
│ │ │ │ -
34 #include <GL/glew.h>
│ │ │ │ -
35 #else
│ │ │ │ -
36 #include <OpenGL/gl3.h>
│ │ │ │ -
37 #endif
│ │ │ │ -
38 #endif
│ │ │ │ -
39#elif defined(ANDROID)
│ │ │ │ -
40 #include <GLES2/gl2.h>
│ │ │ │ -
41#else
│ │ │ │ -
42 #if defined(_WIN32)
│ │ │ │ -
43 #define WIN32_LEAN_AND_MEAN
│ │ │ │ -
44 #include <windows.h>
│ │ │ │ -
45 #endif
│ │ │ │ -
46 #if defined(OSD_USES_GLEW)
│ │ │ │ -
47 #include <GL/glew.h>
│ │ │ │ -
48 #else
│ │ │ │ -
49 #include <GL/gl.h>
│ │ │ │ -
50 #endif
│ │ │ │ -
51#endif
│ │ │ │ -
52
│ │ │ │ -
53#endif // OPENSUBDIV3_OSD_OPENGL_H
│ │ │ │ +
28#include "../version.h"
│ │ │ │ +
29
│ │ │ │ +
30#include <cstddef>
│ │ │ │ +
31
│ │ │ │ +
32namespace OpenSubdiv {
│ │ │ │ +
33namespace OPENSUBDIV_VERSION {
│ │ │ │ +
34
│ │ │ │ +
35namespace Osd {
│ │ │ │ +
36
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
43public:
│ │ │ │ +
45 static CpuVertexBuffer * Create(int numElements, int numVertices,
│ │ │ │ +
46 void *deviceContext = NULL);
│ │ │ │ +
47
│ │ │ │ + │ │ │ │ +
50
│ │ │ │ +
53 void UpdateData(const float *src, int startVertex, int numVertices,
│ │ │ │ +
54 void *deviceContext = NULL);
│ │ │ │ +
55
│ │ │ │ +
57 int GetNumElements() const;
│ │ │ │ +
58
│ │ │ │ +
60 int GetNumVertices() const;
│ │ │ │ +
61
│ │ │ │ +
63 float * BindCpuBuffer();
│ │ │ │ +
64
│ │ │ │ +
65protected:
│ │ │ │ +
67 CpuVertexBuffer(int numElements, int numVertices);
│ │ │ │ +
68
│ │ │ │ +
69private:
│ │ │ │ +
70 int _numElements;
│ │ │ │ +
71 int _numVertices;
│ │ │ │ +
72 float *_cpuBuffer;
│ │ │ │ +
73};
│ │ │ │ +
│ │ │ │ +
74
│ │ │ │ +
75
│ │ │ │ +
76} // end namespace Osd
│ │ │ │ +
77
│ │ │ │ +
78} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
79using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
80
│ │ │ │ +
81} // end namespace OpenSubdiv
│ │ │ │ +
82
│ │ │ │ +
83#endif // OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H
│ │ │ │ + │ │ │ │ +
Concrete vertex buffer class for CPU subdivision.
│ │ │ │ +
int GetNumElements() const
Returns how many elements defined in this vertex buffer.
│ │ │ │ +
static CpuVertexBuffer * Create(int numElements, int numVertices, void *deviceContext=NULL)
Creator. Returns NULL if error.
│ │ │ │ +
void UpdateData(const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
│ │ │ │ +
int GetNumVertices() const
Returns how many vertices allocated in this vertex buffer.
│ │ │ │ + │ │ │ │ +
float * BindCpuBuffer()
Returns the address of CPU buffer.
│ │ │ │ +
CpuVertexBuffer(int numElements, int numVertices)
Constructor.
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -opengl.h │ │ │ │ │ +cpuVertexBuffer.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,40 +24,84 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_OPENGL_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_OPENGL_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H │ │ │ │ │ 27 │ │ │ │ │ -28#if defined(__APPLE__) │ │ │ │ │ -29 #include "TargetConditionals.h" │ │ │ │ │ -30 #if TARGET_OS_IPHONE || TARGET_IPHONE_SIMULATOR │ │ │ │ │ -31 #include │ │ │ │ │ -32 #else │ │ │ │ │ -33 #if defined(OSD_USES_GLEW) │ │ │ │ │ -34 #include │ │ │ │ │ -35 #else │ │ │ │ │ -36 #include │ │ │ │ │ -37 #endif │ │ │ │ │ -38 #endif │ │ │ │ │ -39#elif defined(ANDROID) │ │ │ │ │ -40 #include │ │ │ │ │ -41#else │ │ │ │ │ -42 #if defined(_WIN32) │ │ │ │ │ -43 #define WIN32_LEAN_AND_MEAN │ │ │ │ │ -44 #include │ │ │ │ │ -45 #endif │ │ │ │ │ -46 #if defined(OSD_USES_GLEW) │ │ │ │ │ -47 #include │ │ │ │ │ -48 #else │ │ │ │ │ -49 #include │ │ │ │ │ -50 #endif │ │ │ │ │ -51#endif │ │ │ │ │ -52 │ │ │ │ │ -53#endif // OPENSUBDIV3_OSD_OPENGL_H │ │ │ │ │ +28#include "../version.h" │ │ │ │ │ +29 │ │ │ │ │ +30#include │ │ │ │ │ +31 │ │ │ │ │ +32namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +33namespace OPENSUBDIV_VERSION { │ │ │ │ │ +34 │ │ │ │ │ +35namespace Osd { │ │ │ │ │ +36 │ │ │ │ │ +_4_2class _C_p_u_V_e_r_t_e_x_B_u_f_f_e_r { │ │ │ │ │ +43public: │ │ │ │ │ +_4_5 static _C_p_u_V_e_r_t_e_x_B_u_f_f_e_r * _C_r_e_a_t_e(int numElements, int numVertices, │ │ │ │ │ +46 void *deviceContext = NULL); │ │ │ │ │ +47 │ │ │ │ │ +_4_9 _~_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r(); │ │ │ │ │ +50 │ │ │ │ │ +_5_3 void _U_p_d_a_t_e_D_a_t_a(const float *src, int startVertex, int numVertices, │ │ │ │ │ +54 void *deviceContext = NULL); │ │ │ │ │ +55 │ │ │ │ │ +_5_7 int _G_e_t_N_u_m_E_l_e_m_e_n_t_s() const; │ │ │ │ │ +58 │ │ │ │ │ +_6_0 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s() const; │ │ │ │ │ +61 │ │ │ │ │ +_6_3 float * _B_i_n_d_C_p_u_B_u_f_f_e_r(); │ │ │ │ │ +64 │ │ │ │ │ +65protected: │ │ │ │ │ +_6_7 _C_p_u_V_e_r_t_e_x_B_u_f_f_e_r(int numElements, int numVertices); │ │ │ │ │ +68 │ │ │ │ │ +69private: │ │ │ │ │ +70 int _numElements; │ │ │ │ │ +71 int _numVertices; │ │ │ │ │ +72 float *_cpuBuffer; │ │ │ │ │ +73}; │ │ │ │ │ +74 │ │ │ │ │ +75 │ │ │ │ │ +76} // end namespace Osd │ │ │ │ │ +77 │ │ │ │ │ +78} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +79using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +80 │ │ │ │ │ +81} // end namespace OpenSubdiv │ │ │ │ │ +82 │ │ │ │ │ +83#endif // OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v │ │ │ │ │ +DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +Concrete vertex buffer class for CPU subdivision. │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_4_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_E_l_e_m_e_n_t_s │ │ │ │ │ +int GetNumElements() const │ │ │ │ │ +Returns how many elements defined in this vertex buffer. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_r_e_a_t_e │ │ │ │ │ +static CpuVertexBuffer * Create(int numElements, int numVertices, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +Creator. Returns NULL if error. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_U_p_d_a_t_e_D_a_t_a │ │ │ │ │ +void UpdateData(const float *src, int startVertex, int numVertices, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s │ │ │ │ │ +int GetNumVertices() const │ │ │ │ │ +Returns how many vertices allocated in this vertex buffer. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_~_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +~CpuVertexBuffer() │ │ │ │ │ +Destructor. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_C_p_u_B_u_f_f_e_r │ │ │ │ │ +float * BindCpuBuffer() │ │ │ │ │ +Returns the address of CPU buffer. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ +CpuVertexBuffer(int numElements, int numVertices) │ │ │ │ │ +Constructor. │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _o_p_e_n_g_l_._h │ │ │ │ │ + * _c_p_u_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00887.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/cpuVertexBuffer.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/opengl.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -87,44 +87,24 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
│ │ │ │ -Classes | │ │ │ │ -Namespaces
│ │ │ │ -
cpuVertexBuffer.h File Reference
│ │ │ │ +
opengl.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │ -
#include "../version.h"
│ │ │ │ -#include <cstddef>
│ │ │ │ +
#include <GL/gl.h>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -

│ │ │ │ -Classes

class  CpuVertexBuffer
 Concrete vertex buffer class for CPU subdivision. More...
 
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -

│ │ │ │ -Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION::Osd
 
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,24 +1,11 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -_C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -cpuVertexBuffer.h File Reference │ │ │ │ │ -#include "../version.h" │ │ │ │ │ -#include │ │ │ │ │ +opengl.h File Reference │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ -CCllaasssseess │ │ │ │ │ -class   _C_p_u_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -  Concrete vertex buffer class for CPU subdivision. _M_o_r_e_._._. │ │ │ │ │ -  │ │ │ │ │ -NNaammeessppaacceess │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ -  │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │ -  │ │ │ │ │ -namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │ -  │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _c_p_u_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ + * _o_p_e_n_g_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00887_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/cpuVertexBuffer.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/opengl.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
cpuVertexBuffer.h
│ │ │ │ +
opengl.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2013 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,75 +119,47 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_OPENGL_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_OPENGL_H
│ │ │ │
27
│ │ │ │ -
28#include "../version.h"
│ │ │ │ -
29
│ │ │ │ -
30#include <cstddef>
│ │ │ │ -
31
│ │ │ │ -
32namespace OpenSubdiv {
│ │ │ │ -
33namespace OPENSUBDIV_VERSION {
│ │ │ │ -
34
│ │ │ │ -
35namespace Osd {
│ │ │ │ -
36
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
43public:
│ │ │ │ -
45 static CpuVertexBuffer * Create(int numElements, int numVertices,
│ │ │ │ -
46 void *deviceContext = NULL);
│ │ │ │ -
47
│ │ │ │ - │ │ │ │ -
50
│ │ │ │ -
53 void UpdateData(const float *src, int startVertex, int numVertices,
│ │ │ │ -
54 void *deviceContext = NULL);
│ │ │ │ -
55
│ │ │ │ -
57 int GetNumElements() const;
│ │ │ │ -
58
│ │ │ │ -
60 int GetNumVertices() const;
│ │ │ │ -
61
│ │ │ │ -
63 float * BindCpuBuffer();
│ │ │ │ -
64
│ │ │ │ -
65protected:
│ │ │ │ -
67 CpuVertexBuffer(int numElements, int numVertices);
│ │ │ │ -
68
│ │ │ │ -
69private:
│ │ │ │ -
70 int _numElements;
│ │ │ │ -
71 int _numVertices;
│ │ │ │ -
72 float *_cpuBuffer;
│ │ │ │ -
73};
│ │ │ │ -
│ │ │ │ -
74
│ │ │ │ -
75
│ │ │ │ -
76} // end namespace Osd
│ │ │ │ -
77
│ │ │ │ -
78} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
79using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
80
│ │ │ │ -
81} // end namespace OpenSubdiv
│ │ │ │ -
82
│ │ │ │ -
83#endif // OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H
│ │ │ │ - │ │ │ │ -
Concrete vertex buffer class for CPU subdivision.
│ │ │ │ -
int GetNumElements() const
Returns how many elements defined in this vertex buffer.
│ │ │ │ -
static CpuVertexBuffer * Create(int numElements, int numVertices, void *deviceContext=NULL)
Creator. Returns NULL if error.
│ │ │ │ -
void UpdateData(const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
│ │ │ │ -
int GetNumVertices() const
Returns how many vertices allocated in this vertex buffer.
│ │ │ │ - │ │ │ │ -
float * BindCpuBuffer()
Returns the address of CPU buffer.
│ │ │ │ -
CpuVertexBuffer(int numElements, int numVertices)
Constructor.
│ │ │ │ +
28#if defined(__APPLE__)
│ │ │ │ +
29 #include "TargetConditionals.h"
│ │ │ │ +
30 #if TARGET_OS_IPHONE || TARGET_IPHONE_SIMULATOR
│ │ │ │ +
31 #include <OpenGLES/ES2/gl.h>
│ │ │ │ +
32 #else
│ │ │ │ +
33 #if defined(OSD_USES_GLEW)
│ │ │ │ +
34 #include <GL/glew.h>
│ │ │ │ +
35 #else
│ │ │ │ +
36 #include <OpenGL/gl3.h>
│ │ │ │ +
37 #endif
│ │ │ │ +
38 #endif
│ │ │ │ +
39#elif defined(ANDROID)
│ │ │ │ +
40 #include <GLES2/gl2.h>
│ │ │ │ +
41#else
│ │ │ │ +
42 #if defined(_WIN32)
│ │ │ │ +
43 #define WIN32_LEAN_AND_MEAN
│ │ │ │ +
44 #include <windows.h>
│ │ │ │ +
45 #endif
│ │ │ │ +
46 #if defined(OSD_USES_GLEW)
│ │ │ │ +
47 #include <GL/glew.h>
│ │ │ │ +
48 #else
│ │ │ │ +
49 #include <GL/gl.h>
│ │ │ │ +
50 #endif
│ │ │ │ +
51#endif
│ │ │ │ +
52
│ │ │ │ +
53#endif // OPENSUBDIV3_OSD_OPENGL_H
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -cpuVertexBuffer.h │ │ │ │ │ +opengl.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2013 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,84 +24,40 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_OPENGL_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_OPENGL_H │ │ │ │ │ 27 │ │ │ │ │ -28#include "../version.h" │ │ │ │ │ -29 │ │ │ │ │ -30#include │ │ │ │ │ -31 │ │ │ │ │ -32namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -33namespace OPENSUBDIV_VERSION { │ │ │ │ │ -34 │ │ │ │ │ -35namespace Osd { │ │ │ │ │ -36 │ │ │ │ │ -_4_2class _C_p_u_V_e_r_t_e_x_B_u_f_f_e_r { │ │ │ │ │ -43public: │ │ │ │ │ -_4_5 static _C_p_u_V_e_r_t_e_x_B_u_f_f_e_r * _C_r_e_a_t_e(int numElements, int numVertices, │ │ │ │ │ -46 void *deviceContext = NULL); │ │ │ │ │ -47 │ │ │ │ │ -_4_9 _~_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r(); │ │ │ │ │ -50 │ │ │ │ │ -_5_3 void _U_p_d_a_t_e_D_a_t_a(const float *src, int startVertex, int numVertices, │ │ │ │ │ -54 void *deviceContext = NULL); │ │ │ │ │ -55 │ │ │ │ │ -_5_7 int _G_e_t_N_u_m_E_l_e_m_e_n_t_s() const; │ │ │ │ │ -58 │ │ │ │ │ -_6_0 int _G_e_t_N_u_m_V_e_r_t_i_c_e_s() const; │ │ │ │ │ -61 │ │ │ │ │ -_6_3 float * _B_i_n_d_C_p_u_B_u_f_f_e_r(); │ │ │ │ │ -64 │ │ │ │ │ -65protected: │ │ │ │ │ -_6_7 _C_p_u_V_e_r_t_e_x_B_u_f_f_e_r(int numElements, int numVertices); │ │ │ │ │ -68 │ │ │ │ │ -69private: │ │ │ │ │ -70 int _numElements; │ │ │ │ │ -71 int _numVertices; │ │ │ │ │ -72 float *_cpuBuffer; │ │ │ │ │ -73}; │ │ │ │ │ -74 │ │ │ │ │ -75 │ │ │ │ │ -76} // end namespace Osd │ │ │ │ │ -77 │ │ │ │ │ -78} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -79using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -80 │ │ │ │ │ -81} // end namespace OpenSubdiv │ │ │ │ │ -82 │ │ │ │ │ -83#endif // OPENSUBDIV3_OSD_CPU_VERTEX_BUFFER_H │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v │ │ │ │ │ -DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -Concrete vertex buffer class for CPU subdivision. │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_V_e_r_t_e_x_B_u_f_f_e_r_._h_:_4_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_E_l_e_m_e_n_t_s │ │ │ │ │ -int GetNumElements() const │ │ │ │ │ -Returns how many elements defined in this vertex buffer. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_r_e_a_t_e │ │ │ │ │ -static CpuVertexBuffer * Create(int numElements, int numVertices, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -Creator. Returns NULL if error. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_U_p_d_a_t_e_D_a_t_a │ │ │ │ │ -void UpdateData(const float *src, int startVertex, int numVertices, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_G_e_t_N_u_m_V_e_r_t_i_c_e_s │ │ │ │ │ -int GetNumVertices() const │ │ │ │ │ -Returns how many vertices allocated in this vertex buffer. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_~_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -~CpuVertexBuffer() │ │ │ │ │ -Destructor. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_B_i_n_d_C_p_u_B_u_f_f_e_r │ │ │ │ │ -float * BindCpuBuffer() │ │ │ │ │ -Returns the address of CPU buffer. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r_:_:_C_p_u_V_e_r_t_e_x_B_u_f_f_e_r │ │ │ │ │ -CpuVertexBuffer(int numElements, int numVertices) │ │ │ │ │ -Constructor. │ │ │ │ │ +28#if defined(__APPLE__) │ │ │ │ │ +29 #include "TargetConditionals.h" │ │ │ │ │ +30 #if TARGET_OS_IPHONE || TARGET_IPHONE_SIMULATOR │ │ │ │ │ +31 #include │ │ │ │ │ +32 #else │ │ │ │ │ +33 #if defined(OSD_USES_GLEW) │ │ │ │ │ +34 #include │ │ │ │ │ +35 #else │ │ │ │ │ +36 #include │ │ │ │ │ +37 #endif │ │ │ │ │ +38 #endif │ │ │ │ │ +39#elif defined(ANDROID) │ │ │ │ │ +40 #include │ │ │ │ │ +41#else │ │ │ │ │ +42 #if defined(_WIN32) │ │ │ │ │ +43 #define WIN32_LEAN_AND_MEAN │ │ │ │ │ +44 #include │ │ │ │ │ +45 #endif │ │ │ │ │ +46 #if defined(OSD_USES_GLEW) │ │ │ │ │ +47 #include │ │ │ │ │ +48 #else │ │ │ │ │ +49 #include │ │ │ │ │ +50 #endif │ │ │ │ │ +51#endif │ │ │ │ │ +52 │ │ │ │ │ +53#endif // OPENSUBDIV3_OSD_OPENGL_H │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _c_p_u_V_e_r_t_e_x_B_u_f_f_e_r_._h │ │ │ │ │ + * _o_p_e_n_g_l_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00890.html │ │ │ │ @@ -101,19 +101,19 @@ │ │ │ │ │ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ #include <bitset>
│ │ │ │ #include <cassert>
│ │ │ │ #include <cstring>
│ │ │ │ #include <vector>
│ │ │ │ -#include "../far/topologyRefiner.h"
│ │ │ │ -#include "../far/patchTableFactory.h"
│ │ │ │ -#include "../far/stencilTable.h"
│ │ │ │ -#include "../far/stencilTableFactory.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../far/topologyRefiner.h"
│ │ │ │ +#include "../far/patchTableFactory.h"
│ │ │ │ +#include "../far/stencilTable.h"
│ │ │ │ +#include "../far/stencilTableFactory.h"
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00890_source.html │ │ │ │ @@ -876,15 +876,15 @@ │ │ │ │
717
│ │ │ │
718} // end namespace OPENSUBDIV_VERSION
│ │ │ │
719using namespace OPENSUBDIV_VERSION;
│ │ │ │
720
│ │ │ │
721} // end namespace OpenSubdiv
│ │ │ │
722
│ │ │ │
723#endif // OPENSUBDIV3_OSD_MESH_H
│ │ │ │ - │ │ │ │ + │ │ │ │
STENCIL_TABLE const * convertToCompatibleStencilTable(SRC_STENCIL_TABLE const *table, DEVICE_CONTEXT *context)
Definition mesh.h:141
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -900,43 +900,43 @@ │ │ │ │
std::bitset< NUM_MESH_BITS > MeshBitset
Definition mesh.h:63
│ │ │ │
Far::StencilTable const * convertToCompatibleStencilTable< Far::StencilTable, Far::StencilTable, ID3D11DeviceContext >(Far::StencilTable const *table, ID3D11DeviceContext *)
Definition mesh.h:169
│ │ │ │
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │
int GetMaxValence() const
Returns max vertex valence.
Definition patchTable.h:92
│ │ │ │
StencilTable const * GetLocalPointStencilTable() const
Returns the stencil table to compute local point vertex values.
Definition patchTable.h:778
│ │ │ │
StencilTable const * GetLocalPointVaryingStencilTable() const
Returns the stencil table to compute local point varying values.
Definition patchTable.h:783
│ │ │ │
static PatchTable * Create(TopologyRefiner const &refiner, Options options=Options(), ConstIndexArray selectedFaces=ConstIndexArray())
Instantiates a PatchTable from a client-provided TopologyRefiner.
│ │ │ │ - │ │ │ │ -
@ ENDCAP_LEGACY_GREGORY
legacy option for 2.x style Gregory patches (Catmark only)
│ │ │ │ -
@ ENDCAP_GREGORY_BASIS
use Gregory patches (highest quality, recommended default)
│ │ │ │ -
@ ENDCAP_BILINEAR_BASIS
use linear patches (simple quads or tris)
│ │ │ │ -
@ ENDCAP_BSPLINE_BASIS
use BSpline-like patches (same patch type as regular)
│ │ │ │ - │ │ │ │ -
int GetNumControlVertices() const
Returns the number of control vertices indexed in the table.
│ │ │ │ -
int GetNumStencils() const
Returns the number of stencils in the table.
│ │ │ │ -
Stencil table class wrapping the template for compatibility.
│ │ │ │ -
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ -
static StencilTable const * Create(TopologyRefiner const &refiner, Options options=Options())
│ │ │ │ -
static StencilTable const * AppendLocalPointStencilTable(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, StencilTable const *localPointStencilTable, bool factorize=true)
│ │ │ │ -
int GetNumVertices() const
Return the number of vertices in this level.
│ │ │ │ -
Stores topology data for a specified set of refinement options.
│ │ │ │ -
bool IsUniform() const
Returns true if uniform refinement has been applied.
│ │ │ │ -
int GetNumFVarChannels() const
Returns the number of face-varying channels in the tables.
│ │ │ │ + │ │ │ │ +
@ ENDCAP_LEGACY_GREGORY
legacy option for 2.x style Gregory patches (Catmark only)
│ │ │ │ +
@ ENDCAP_GREGORY_BASIS
use Gregory patches (highest quality, recommended default)
│ │ │ │ +
@ ENDCAP_BILINEAR_BASIS
use linear patches (simple quads or tris)
│ │ │ │ +
@ ENDCAP_BSPLINE_BASIS
use BSpline-like patches (same patch type as regular)
│ │ │ │ + │ │ │ │ +
int GetNumControlVertices() const
Returns the number of control vertices indexed in the table.
│ │ │ │ +
int GetNumStencils() const
Returns the number of stencils in the table.
│ │ │ │ +
Stencil table class wrapping the template for compatibility.
│ │ │ │ +
Limit stencil table class wrapping the template for compatibility.
│ │ │ │ +
static StencilTable const * Create(TopologyRefiner const &refiner, Options options=Options())
│ │ │ │ +
static StencilTable const * AppendLocalPointStencilTable(TopologyRefiner const &refiner, StencilTable const *baseStencilTable, StencilTable const *localPointStencilTable, bool factorize=true)
│ │ │ │ +
int GetNumVertices() const
Return the number of vertices in this level.
│ │ │ │ +
Stores topology data for a specified set of refinement options.
│ │ │ │ +
bool IsUniform() const
Returns true if uniform refinement has been applied.
│ │ │ │ +
int GetNumFVarChannels() const
Returns the number of face-varying channels in the tables.
│ │ │ │
void RefineUniform(UniformOptions options)
Refine the topology uniformly.
│ │ │ │ -
TopologyLevel const & GetLevel(int level) const
Returns a handle to access data specific to a particular level.
│ │ │ │ +
TopologyLevel const & GetLevel(int level) const
Returns a handle to access data specific to a particular level.
│ │ │ │
void RefineAdaptive(AdaptiveOptions options, ConstIndexArray selectedFaces=ConstIndexArray())
Feature Adaptive topology refinement.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │
virtual Far::PatchTable const * GetFarPatchTable() const =0
│ │ │ │
static void refineMesh(Far::TopologyRefiner &refiner, int level, MeshBitset bits)
Definition mesh.h:117
│ │ │ │ │ │ │ │ │ │ │ │
virtual void UpdateVaryingBuffer(float const *varyingData, int startVertex, int numVerts)=0
│ │ │ │
static void refineMesh(Far::TopologyRefiner &refiner, int level, bool adaptive, bool singleCreasePatch)
Definition mesh.h:101
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00893_source.html │ │ │ │ @@ -261,15 +261,15 @@ │ │ │ │
139
│ │ │ │
140} // end namespace OPENSUBDIV_VERSION
│ │ │ │
141using namespace OPENSUBDIV_VERSION;
│ │ │ │
142
│ │ │ │
143} // end namespace OpenSubdiv
│ │ │ │
144
│ │ │ │
145#endif // OPENSUBDIV3_OSD_CPU_PATCH_TABLE_H
│ │ │ │ - │ │ │ │ + │ │ │ │
std::vector< PatchParam > PatchParamVector
Definition types.h:133
│ │ │ │
std::vector< PatchArray > PatchArrayVector
Definition types.h:132
│ │ │ │
Container for arrays of parametric patches.
Definition patchTable.h:55
│ │ │ │ │ │ │ │
const PatchArray * GetFVarPatchArrayBuffer(int fvarChannel=0) const
│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00896.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/bufferDescriptor.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/cpuEvaluator.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,26 +90,27 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
bufferDescriptor.h File Reference
│ │ │ │ +
cpuEvaluator.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include <string.h>
│ │ │ │ +#include "../osd/bufferDescriptor.h"
│ │ │ │ +#include "../osd/types.h"
│ │ │ │ +#include <cstddef>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │

│ │ │ │ Classes

class  MeshInterface< PATCH_TABLE >
 
│ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

struct  BufferDescriptor
 BufferDescriptor is a struct which describes buffer elements in interleaved data buffers. Almost all Osd Evaluator APIs take BufferDescriptors along with device-specific buffer objects. More...
class  CpuEvaluator
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -118,13 +119,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,26 +1,25 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -bufferDescriptor.h File Reference │ │ │ │ │ +cpuEvaluator.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include │ │ │ │ │ +#include "_._._/_o_s_d_/_b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ +#include "_._._/_o_s_d_/_t_y_p_e_s_._h" │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -struct   _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ - _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r is a struct which describes buffer elements in │ │ │ │ │ -  interleaved data buffers. Almost all _O_s_d Evaluator APIs take │ │ │ │ │ - BufferDescriptors along with device-specific buffer objects. _M_o_r_e_._._. │ │ │ │ │ +class   _C_p_u_E_v_a_l_u_a_t_o_r │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h │ │ │ │ │ + * _c_p_u_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00896.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,3 @@ │ │ │ │ │ var a00896 = [ │ │ │ │ │ - ["BufferDescriptor", "a01141.html", "a01141"] │ │ │ │ │ + ["CpuEvaluator", "a01165.html", null] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00896_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/bufferDescriptor.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/cpuEvaluator.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
bufferDescriptor.h
│ │ │ │ +
cpuEvaluator.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2015 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,112 +119,529 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_CPU_EVALUATOR_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_CPU_EVALUATOR_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29#include <string.h>
│ │ │ │ -
30
│ │ │ │ -
31namespace OpenSubdiv {
│ │ │ │ -
32namespace OPENSUBDIV_VERSION {
│ │ │ │ +
29#include "../osd/bufferDescriptor.h"
│ │ │ │ +
30#include "../osd/types.h"
│ │ │ │ +
31
│ │ │ │ +
32#include <cstddef>
│ │ │ │
33
│ │ │ │ -
│ │ │ │ -
34namespace Osd {
│ │ │ │ -
35
│ │ │ │ +
34namespace OpenSubdiv {
│ │ │ │ +
35namespace OPENSUBDIV_VERSION {
│ │ │ │ +
36
│ │ │ │ +
37namespace Osd {
│ │ │ │ +
38
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
40public:
│ │ │ │
46
│ │ │ │ -
47// example:
│ │ │ │ -
48// n
│ │ │ │ -
49// -----+----------------------------------------+-------------------------
│ │ │ │ -
50// | vertex 0 |
│ │ │ │ -
51// -----+----------------------------------------+-------------------------
│ │ │ │ -
52// | X Y Z R G B A Xu Yu Zu Xv Yv Zv |
│ │ │ │ -
53// -----+----------------------------------------+-------------------------
│ │ │ │ -
54// <------------- stride = 13 -------------->
│ │ │ │ -
55//
│ │ │ │ -
56// - XYZ (offset = n+0, length = 3, stride = 13)
│ │ │ │ -
57// - RGBA (offset = n+3, length = 4, stride = 13)
│ │ │ │ -
58// - uTangent (offset = n+7, length = 3, stride = 13)
│ │ │ │ -
59// - vTangent (offset = n+10, length = 3, stride = 13)
│ │ │ │ -
60//
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
62
│ │ │ │ - │ │ │ │ -
65
│ │ │ │ -
67 BufferDescriptor(int o, int l, int s) : offset(o), length(l), stride(s) { }
│ │ │ │ -
68
│ │ │ │ -
│ │ │ │ -
70 int GetLocalOffset() const {
│ │ │ │ -
71 return stride > 0 ? offset % stride : 0;
│ │ │ │ -
72 }
│ │ │ │ -
│ │ │ │ -
73
│ │ │ │ -
│ │ │ │ -
75 bool IsValid() const {
│ │ │ │ -
76 return ((length > 0) &&
│ │ │ │ - │ │ │ │ -
78 }
│ │ │ │ -
│ │ │ │ -
79
│ │ │ │ -
│ │ │ │ -
81 void Reset() {
│ │ │ │ -
82 offset = length = stride = 0;
│ │ │ │ -
83 }
│ │ │ │ -
│ │ │ │ +
71 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
72 static bool EvalStencils(
│ │ │ │ +
73 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
74 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
75 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
76 const CpuEvaluator *instance = NULL,
│ │ │ │ +
77 void * deviceContext = NULL) {
│ │ │ │ +
78
│ │ │ │ +
79 (void)instance; // unused
│ │ │ │ +
80 (void)deviceContext; // unused
│ │ │ │ +
81
│ │ │ │ +
82 if (stencilTable->GetNumStencils() == 0)
│ │ │ │ +
83 return false;
│ │ │ │
84
│ │ │ │ -
│ │ │ │ -
86 bool operator == (BufferDescriptor const &other) const {
│ │ │ │ -
87 return (offset == other.offset &&
│ │ │ │ -
88 length == other.length &&
│ │ │ │ -
89 stride == other.stride);
│ │ │ │ -
90 }
│ │ │ │ -
│ │ │ │ -
91
│ │ │ │ -
│ │ │ │ -
93 bool operator != (BufferDescriptor const &other) const {
│ │ │ │ -
94 return !(this->operator==(other));
│ │ │ │ -
95 }
│ │ │ │ -
│ │ │ │ -
96
│ │ │ │ -
98 int offset;
│ │ │ │ - │ │ │ │ - │ │ │ │ -
103};
│ │ │ │ -
│ │ │ │ -
104
│ │ │ │ -
105} // end namespace Osd
│ │ │ │ -
│ │ │ │ -
106
│ │ │ │ -
107} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
108using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
109
│ │ │ │ -
110} // end namespace OpenSubdiv
│ │ │ │ -
111
│ │ │ │ -
112#endif // OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H
│ │ │ │ - │ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ - │ │ │ │ -
void Reset()
Resets the descriptor to default.
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ -
bool operator!=(BufferDescriptor const &other) const
True if the descriptors are not identical.
│ │ │ │ -
bool operator==(BufferDescriptor const &other) const
True if the descriptors are identical.
│ │ │ │ -
bool IsValid() const
True if the descriptor values are internally consistent.
│ │ │ │ -
int GetLocalOffset() const
Returns the relative offset within a stride.
│ │ │ │ - │ │ │ │ +
85 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
86 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
87 &stencilTable->GetSizes()[0],
│ │ │ │ +
88 &stencilTable->GetOffsets()[0],
│ │ │ │ +
89 &stencilTable->GetControlIndices()[0],
│ │ │ │ +
90 &stencilTable->GetWeights()[0],
│ │ │ │ +
91 /*start = */ 0,
│ │ │ │ +
92 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ +
93 }
│ │ │ │ +
│ │ │ │ +
94
│ │ │ │ +
121 static bool EvalStencils(
│ │ │ │ +
122 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
123 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
124 const int * sizes,
│ │ │ │ +
125 const int * offsets,
│ │ │ │ +
126 const int * indices,
│ │ │ │ +
127 const float * weights,
│ │ │ │ +
128 int start, int end);
│ │ │ │ +
129
│ │ │ │ +
167 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
168 static bool EvalStencils(
│ │ │ │ +
169 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
170 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
171 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
172 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
173 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
174 const CpuEvaluator *instance = NULL,
│ │ │ │ +
175 void * deviceContext = NULL) {
│ │ │ │ +
176
│ │ │ │ +
177 (void)instance; // unused
│ │ │ │ +
178 (void)deviceContext; // unused
│ │ │ │ +
179
│ │ │ │ +
180 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
181 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
182 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
183 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
184 &stencilTable->GetSizes()[0],
│ │ │ │ +
185 &stencilTable->GetOffsets()[0],
│ │ │ │ +
186 &stencilTable->GetControlIndices()[0],
│ │ │ │ +
187 &stencilTable->GetWeights()[0],
│ │ │ │ +
188 &stencilTable->GetDuWeights()[0],
│ │ │ │ +
189 &stencilTable->GetDvWeights()[0],
│ │ │ │ +
190 /*start = */ 0,
│ │ │ │ +
191 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ +
192 }
│ │ │ │ +
│ │ │ │ +
193
│ │ │ │ +
234 static bool EvalStencils(
│ │ │ │ +
235 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
236 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
237 float *du, BufferDescriptor const &duDesc,
│ │ │ │ +
238 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ +
239 const int * sizes,
│ │ │ │ +
240 const int * offsets,
│ │ │ │ +
241 const int * indices,
│ │ │ │ +
242 const float * weights,
│ │ │ │ +
243 const float * duWeights,
│ │ │ │ +
244 const float * dvWeights,
│ │ │ │ +
245 int start, int end);
│ │ │ │ +
246
│ │ │ │ +
302 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ +
│ │ │ │ +
303 static bool EvalStencils(
│ │ │ │ +
304 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
305 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
306 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
307 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
308 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
309 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
310 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
311 STENCIL_TABLE const *stencilTable,
│ │ │ │ +
312 const CpuEvaluator *instance = NULL,
│ │ │ │ +
313 void * deviceContext = NULL) {
│ │ │ │ +
314
│ │ │ │ +
315 (void)instance; // unused
│ │ │ │ +
316 (void)deviceContext; // unused
│ │ │ │ +
317
│ │ │ │ +
318 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
319 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
320 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
321 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
322 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ +
323 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ +
324 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ +
325 &stencilTable->GetSizes()[0],
│ │ │ │ +
326 &stencilTable->GetOffsets()[0],
│ │ │ │ +
327 &stencilTable->GetControlIndices()[0],
│ │ │ │ +
328 &stencilTable->GetWeights()[0],
│ │ │ │ +
329 &stencilTable->GetDuWeights()[0],
│ │ │ │ +
330 &stencilTable->GetDvWeights()[0],
│ │ │ │ +
331 &stencilTable->GetDuuWeights()[0],
│ │ │ │ +
332 &stencilTable->GetDuvWeights()[0],
│ │ │ │ +
333 &stencilTable->GetDvvWeights()[0],
│ │ │ │ +
334 /*start = */ 0,
│ │ │ │ +
335 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ +
336 }
│ │ │ │ +
│ │ │ │ +
337
│ │ │ │ +
399 static bool EvalStencils(
│ │ │ │ +
400 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
401 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
402 float *du, BufferDescriptor const &duDesc,
│ │ │ │ +
403 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ +
404 float *duu, BufferDescriptor const &duuDesc,
│ │ │ │ +
405 float *duv, BufferDescriptor const &duvDesc,
│ │ │ │ +
406 float *dvv, BufferDescriptor const &dvvDesc,
│ │ │ │ +
407 const int * sizes,
│ │ │ │ +
408 const int * offsets,
│ │ │ │ +
409 const int * indices,
│ │ │ │ +
410 const float * weights,
│ │ │ │ +
411 const float * duWeights,
│ │ │ │ +
412 const float * dvWeights,
│ │ │ │ +
413 const float * duuWeights,
│ │ │ │ +
414 const float * duvWeights,
│ │ │ │ +
415 const float * dvvWeights,
│ │ │ │ +
416 int start, int end);
│ │ │ │ +
417
│ │ │ │ +
423
│ │ │ │ +
452 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
453 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
454 static bool EvalPatches(
│ │ │ │ +
455 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
456 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
457 int numPatchCoords,
│ │ │ │ +
458 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
459 PATCH_TABLE *patchTable,
│ │ │ │ +
460 CpuEvaluator const *instance = NULL,
│ │ │ │ +
461 void * deviceContext = NULL) {
│ │ │ │ +
462
│ │ │ │ +
463 (void)instance; // unused
│ │ │ │ +
464 (void)deviceContext; // unused
│ │ │ │ +
465
│ │ │ │ +
466 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
467 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
468 numPatchCoords,
│ │ │ │ +
469 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
470 patchTable->GetPatchArrayBuffer(),
│ │ │ │ +
471 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
472 patchTable->GetPatchParamBuffer());
│ │ │ │ +
473 }
│ │ │ │ +
│ │ │ │ +
474
│ │ │ │ +
515 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
516 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
517 static bool EvalPatches(
│ │ │ │ +
518 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
519 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
520 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
521 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
522 int numPatchCoords,
│ │ │ │ +
523 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
524 PATCH_TABLE *patchTable,
│ │ │ │ +
525 CpuEvaluator const *instance = NULL,
│ │ │ │ +
526 void * deviceContext = NULL) {
│ │ │ │ +
527
│ │ │ │ +
528 (void)instance; // unused
│ │ │ │ +
529 (void)deviceContext; // unused
│ │ │ │ +
530
│ │ │ │ +
531 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop.
│ │ │ │ +
532 // ideally all buffer classes should have templated by datatype
│ │ │ │ +
533 // so that downcast isn't needed there.
│ │ │ │ +
534 // (e.g. Osd::CpuBuffer<PatchCoord> )
│ │ │ │ +
535 //
│ │ │ │ +
536 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
537 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
538 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
539 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
540 numPatchCoords,
│ │ │ │ +
541 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
542 patchTable->GetPatchArrayBuffer(),
│ │ │ │ +
543 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
544 patchTable->GetPatchParamBuffer());
│ │ │ │ +
545 }
│ │ │ │ +
│ │ │ │ +
546
│ │ │ │ +
605 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
606 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ +
607 static bool EvalPatches(
│ │ │ │ +
608 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
609 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
610 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
611 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
612 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
613 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
614 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
615 int numPatchCoords,
│ │ │ │ +
616 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
617 PATCH_TABLE *patchTable,
│ │ │ │ +
618 CpuEvaluator const *instance = NULL,
│ │ │ │ +
619 void * deviceContext = NULL) {
│ │ │ │ +
620
│ │ │ │ +
621 (void)instance; // unused
│ │ │ │ +
622 (void)deviceContext; // unused
│ │ │ │ +
623
│ │ │ │ +
624 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop.
│ │ │ │ +
625 // ideally all buffer classes should have templated by datatype
│ │ │ │ +
626 // so that downcast isn't needed there.
│ │ │ │ +
627 // (e.g. Osd::CpuBuffer<PatchCoord> )
│ │ │ │ +
628 //
│ │ │ │ +
629 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
630 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
631 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
632 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
633 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ +
634 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ +
635 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ +
636 numPatchCoords,
│ │ │ │ +
637 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
638 patchTable->GetPatchArrayBuffer(),
│ │ │ │ +
639 patchTable->GetPatchIndexBuffer(),
│ │ │ │ +
640 patchTable->GetPatchParamBuffer());
│ │ │ │ +
641 }
│ │ │ │ +
│ │ │ │ +
642
│ │ │ │ +
670 static bool EvalPatches(
│ │ │ │ +
671 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
672 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
673 int numPatchCoords,
│ │ │ │ +
674 const PatchCoord *patchCoords,
│ │ │ │ +
675 const PatchArray *patchArrays,
│ │ │ │ +
676 const int *patchIndexBuffer,
│ │ │ │ +
677 const PatchParam *patchParamBuffer);
│ │ │ │ +
678
│ │ │ │ +
716 static bool EvalPatches(
│ │ │ │ +
717 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
718 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
719 float *du, BufferDescriptor const &duDesc,
│ │ │ │ +
720 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ +
721 int numPatchCoords,
│ │ │ │ +
722 PatchCoord const *patchCoords,
│ │ │ │ +
723 PatchArray const *patchArrays,
│ │ │ │ +
724 const int *patchIndexBuffer,
│ │ │ │ +
725 PatchParam const *patchParamBuffer);
│ │ │ │ +
726
│ │ │ │ +
779 static bool EvalPatches(
│ │ │ │ +
780 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ +
781 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ +
782 float *du, BufferDescriptor const &duDesc,
│ │ │ │ +
783 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ +
784 float *duu, BufferDescriptor const &duuDesc,
│ │ │ │ +
785 float *duv, BufferDescriptor const &duvDesc,
│ │ │ │ +
786 float *dvv, BufferDescriptor const &dvvDesc,
│ │ │ │ +
787 int numPatchCoords,
│ │ │ │ +
788 PatchCoord const *patchCoords,
│ │ │ │ +
789 PatchArray const *patchArrays,
│ │ │ │ +
790 const int *patchIndexBuffer,
│ │ │ │ +
791 PatchParam const *patchParamBuffer);
│ │ │ │ +
792
│ │ │ │ +
821 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
822 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
824 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
825 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
826 int numPatchCoords,
│ │ │ │ +
827 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
828 PATCH_TABLE *patchTable,
│ │ │ │ +
829 CpuEvaluator const *instance = NULL,
│ │ │ │ +
830 void * deviceContext = NULL) {
│ │ │ │ +
831
│ │ │ │ +
832 (void)instance; // unused
│ │ │ │ +
833 (void)deviceContext; // unused
│ │ │ │ +
834
│ │ │ │ +
835 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
836 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
837 numPatchCoords,
│ │ │ │ +
838 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
839 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ +
840 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
841 patchTable->GetPatchParamBuffer());
│ │ │ │ +
842 }
│ │ │ │ +
│ │ │ │ +
843
│ │ │ │ +
884 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
885 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
887 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
888 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
889 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
890 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
891 int numPatchCoords,
│ │ │ │ +
892 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
893 PATCH_TABLE *patchTable,
│ │ │ │ +
894 CpuEvaluator const *instance = NULL,
│ │ │ │ +
895 void * deviceContext = NULL) {
│ │ │ │ +
896
│ │ │ │ +
897 (void)instance; // unused
│ │ │ │ +
898 (void)deviceContext; // unused
│ │ │ │ +
899
│ │ │ │ +
900 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
901 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
902 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
903 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
904 numPatchCoords,
│ │ │ │ +
905 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
906 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ +
907 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
908 patchTable->GetPatchParamBuffer());
│ │ │ │ +
909 }
│ │ │ │ +
│ │ │ │ +
910
│ │ │ │ +
969 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
970 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
972 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
973 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
974 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
975 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
976 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
977 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
978 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
979 int numPatchCoords,
│ │ │ │ +
980 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
981 PATCH_TABLE *patchTable,
│ │ │ │ +
982 CpuEvaluator const *instance = NULL,
│ │ │ │ +
983 void * deviceContext = NULL) {
│ │ │ │ +
984
│ │ │ │ +
985 (void)instance; // unused
│ │ │ │ +
986 (void)deviceContext; // unused
│ │ │ │ +
987
│ │ │ │ +
988 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
989 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
990 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
991 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
992 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ +
993 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ +
994 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ +
995 numPatchCoords,
│ │ │ │ +
996 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
997 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ +
998 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ +
999 patchTable->GetPatchParamBuffer());
│ │ │ │ +
1000 }
│ │ │ │ +
│ │ │ │ +
1001
│ │ │ │ +
1032 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1033 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1035 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1036 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1037 int numPatchCoords,
│ │ │ │ +
1038 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1039 PATCH_TABLE *patchTable,
│ │ │ │ +
1040 int fvarChannel,
│ │ │ │ +
1041 CpuEvaluator const *instance = NULL,
│ │ │ │ +
1042 void * deviceContext = NULL) {
│ │ │ │ +
1043
│ │ │ │ +
1044 (void)instance; // unused
│ │ │ │ +
1045 (void)deviceContext; // unused
│ │ │ │ +
1046
│ │ │ │ +
1047 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
1048 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
1049 numPatchCoords,
│ │ │ │ +
1050 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
1051 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ +
1052 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
1053 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ +
1054 }
│ │ │ │ +
│ │ │ │ +
1055
│ │ │ │ +
1098 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1099 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1101 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1102 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1103 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1104 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1105 int numPatchCoords,
│ │ │ │ +
1106 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1107 PATCH_TABLE *patchTable,
│ │ │ │ +
1108 int fvarChannel,
│ │ │ │ +
1109 CpuEvaluator const *instance = NULL,
│ │ │ │ +
1110 void * deviceContext = NULL) {
│ │ │ │ +
1111
│ │ │ │ +
1112 (void)instance; // unused
│ │ │ │ +
1113 (void)deviceContext; // unused
│ │ │ │ +
1114
│ │ │ │ +
1115 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
1116 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
1117 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
1118 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
1119 numPatchCoords,
│ │ │ │ +
1120 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
1121 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ +
1122 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
1123 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ +
1124 }
│ │ │ │ +
│ │ │ │ +
1125
│ │ │ │ +
1186 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ +
1187 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
1189 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ +
1190 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ +
1191 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ +
1192 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ +
1193 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ +
1194 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ +
1195 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ +
1196 int numPatchCoords,
│ │ │ │ +
1197 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ +
1198 PATCH_TABLE *patchTable,
│ │ │ │ +
1199 int fvarChannel,
│ │ │ │ +
1200 CpuEvaluator const *instance = NULL,
│ │ │ │ +
1201 void * deviceContext = NULL) {
│ │ │ │ +
1202
│ │ │ │ +
1203 (void)instance; // unused
│ │ │ │ +
1204 (void)deviceContext; // unused
│ │ │ │ +
1205
│ │ │ │ +
1206 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ +
1207 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ +
1208 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ +
1209 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ +
1210 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ +
1211 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ +
1212 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ +
1213 numPatchCoords,
│ │ │ │ +
1214 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ +
1215 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ +
1216 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ +
1217 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ +
1218 }
│ │ │ │ +
│ │ │ │ +
1219
│ │ │ │ +
1225
│ │ │ │ +
│ │ │ │ +
1227 static void Synchronize(void * /*deviceContext = NULL*/) {
│ │ │ │ +
1228 // nothing.
│ │ │ │ +
1229 }
│ │ │ │ +
│ │ │ │ +
1230};
│ │ │ │ +
│ │ │ │ +
1231
│ │ │ │ +
1232
│ │ │ │ +
1233} // end namespace Osd
│ │ │ │ +
1234
│ │ │ │ +
1235} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
1236using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
1237
│ │ │ │ +
1238} // end namespace OpenSubdiv
│ │ │ │ +
1239
│ │ │ │ +
1240
│ │ │ │ +
1241#endif // OPENSUBDIV3_OSD_CPU_EVALUATOR_H
│ │ │ │ + │ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ + │ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, int start, int end)
Static eval stencils function which takes raw CPU pointers for input and output.
│ │ │ │ +
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │ +
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, float *dvv, BufferDescriptor const &dvvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, const float *duuWeights, const float *duvWeights, const float *dvvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │ +
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, float *dvv, BufferDescriptor const &dvvDesc, int numPatchCoords, PatchCoord const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, PatchParam const *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ +
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, int numPatchCoords, PatchCoord const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, PatchParam const *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, const CpuEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │ +
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrays, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ +
static void Synchronize(void *)
synchronize all asynchronous computation invoked on this device.
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, const CpuEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function. This function has a same signature as other device kernels hav...
│ │ │ │ +
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ +
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const CpuEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │ +
Coordinates set on a patch table.
Definition types.h:42
│ │ │ │ + │ │ │ │ + │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -bufferDescriptor.h │ │ │ │ │ +cpuEvaluator.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2015 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,125 +24,655 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_CPU_EVALUATOR_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_CPU_EVALUATOR_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29#include │ │ │ │ │ -30 │ │ │ │ │ -31namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -32namespace OPENSUBDIV_VERSION { │ │ │ │ │ +29#include "../osd/bufferDescriptor.h" │ │ │ │ │ +30#include "../osd/types.h" │ │ │ │ │ +31 │ │ │ │ │ +32#include │ │ │ │ │ 33 │ │ │ │ │ -_3_4namespace Osd { │ │ │ │ │ -35 │ │ │ │ │ +34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +35namespace OPENSUBDIV_VERSION { │ │ │ │ │ +36 │ │ │ │ │ +37namespace Osd { │ │ │ │ │ +38 │ │ │ │ │ +_3_9class _C_p_u_E_v_a_l_u_a_t_o_r { │ │ │ │ │ +40public: │ │ │ │ │ 46 │ │ │ │ │ -47// example: │ │ │ │ │ -48// n │ │ │ │ │ -49// -----+----------------------------------------+------------------------- │ │ │ │ │ -50// | vertex 0 | │ │ │ │ │ -51// -----+----------------------------------------+------------------------- │ │ │ │ │ -52// | X Y Z R G B A Xu Yu Zu Xv Yv Zv | │ │ │ │ │ -53// -----+----------------------------------------+------------------------- │ │ │ │ │ -54// <------------- stride = 13 --------------> │ │ │ │ │ -55// │ │ │ │ │ -56// - XYZ (offset = n+0, length = 3, stride = 13) │ │ │ │ │ -57// - RGBA (offset = n+3, length = 4, stride = 13) │ │ │ │ │ -58// - uTangent (offset = n+7, length = 3, stride = 13) │ │ │ │ │ -59// - vTangent (offset = n+10, length = 3, stride = 13) │ │ │ │ │ -60// │ │ │ │ │ -_6_1struct _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r { │ │ │ │ │ -62 │ │ │ │ │ -_6_4 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r() : _o_f_f_s_e_t(0), _l_e_n_g_t_h(0), _s_t_r_i_d_e(0) { } │ │ │ │ │ -65 │ │ │ │ │ -_6_7 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(int o, int l, int s) : _o_f_f_s_e_t(o), _l_e_n_g_t_h(l), _s_t_r_i_d_e(s) { } │ │ │ │ │ -68 │ │ │ │ │ -_7_0 int _G_e_t_L_o_c_a_l_O_f_f_s_e_t() const { │ │ │ │ │ -71 return _s_t_r_i_d_e > 0 ? _o_f_f_s_e_t % _s_t_r_i_d_e : 0; │ │ │ │ │ -72 } │ │ │ │ │ -73 │ │ │ │ │ -_7_5 bool _I_s_V_a_l_i_d() const { │ │ │ │ │ -76 return ((_l_e_n_g_t_h > 0) && │ │ │ │ │ -77 (_l_e_n_g_t_h <= _s_t_r_i_d_e - _G_e_t_L_o_c_a_l_O_f_f_s_e_t())); │ │ │ │ │ -78 } │ │ │ │ │ -79 │ │ │ │ │ -_8_1 void _R_e_s_e_t() { │ │ │ │ │ -82 _o_f_f_s_e_t = _l_e_n_g_t_h = _s_t_r_i_d_e = 0; │ │ │ │ │ -83 } │ │ │ │ │ +71 template │ │ │ │ │ +_7_2 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +73 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +74 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +75 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +76 const _C_p_u_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ +77 void * deviceContext = NULL) { │ │ │ │ │ +78 │ │ │ │ │ +79 (void)instance; // unused │ │ │ │ │ +80 (void)deviceContext; // unused │ │ │ │ │ +81 │ │ │ │ │ +82 if (stencilTable->GetNumStencils() == 0) │ │ │ │ │ +83 return false; │ │ │ │ │ 84 │ │ │ │ │ -_8_6 bool _o_p_e_r_a_t_o_r_ _=_=_ (_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &other) const { │ │ │ │ │ -87 return (_o_f_f_s_e_t == other._o_f_f_s_e_t && │ │ │ │ │ -88 _l_e_n_g_t_h == other._l_e_n_g_t_h && │ │ │ │ │ -89 _s_t_r_i_d_e == other._s_t_r_i_d_e); │ │ │ │ │ -90 } │ │ │ │ │ -91 │ │ │ │ │ -_9_3 bool _o_p_e_r_a_t_o_r_ _!_=_ (_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &other) const { │ │ │ │ │ -94 return !(this->_o_p_e_r_a_t_o_r_=_=(other)); │ │ │ │ │ -95 } │ │ │ │ │ -96 │ │ │ │ │ -_9_8 int _o_f_f_s_e_t; │ │ │ │ │ -_1_0_0 int _l_e_n_g_t_h; │ │ │ │ │ -_1_0_2 int _s_t_r_i_d_e; │ │ │ │ │ -103}; │ │ │ │ │ -104 │ │ │ │ │ -105} // end namespace Osd │ │ │ │ │ -106 │ │ │ │ │ -107} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -108using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -109 │ │ │ │ │ -110} // end namespace OpenSubdiv │ │ │ │ │ -111 │ │ │ │ │ -112#endif // OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H │ │ │ │ │ +85 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +86 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +87 &stencilTable->GetSizes()[0], │ │ │ │ │ +88 &stencilTable->GetOffsets()[0], │ │ │ │ │ +89 &stencilTable->GetControlIndices()[0], │ │ │ │ │ +90 &stencilTable->GetWeights()[0], │ │ │ │ │ +91 /*start = */ 0, │ │ │ │ │ +92 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ +93 } │ │ │ │ │ +94 │ │ │ │ │ +_1_2_1 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +122 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +123 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +124 const int * sizes, │ │ │ │ │ +125 const int * offsets, │ │ │ │ │ +126 const int * indices, │ │ │ │ │ +127 const float * weights, │ │ │ │ │ +128 int start, int end); │ │ │ │ │ +129 │ │ │ │ │ +167 template │ │ │ │ │ +_1_6_8 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +169 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +170 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +171 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +172 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +173 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +174 const _C_p_u_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ +175 void * deviceContext = NULL) { │ │ │ │ │ +176 │ │ │ │ │ +177 (void)instance; // unused │ │ │ │ │ +178 (void)deviceContext; // unused │ │ │ │ │ +179 │ │ │ │ │ +180 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +181 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +182 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +183 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +184 &stencilTable->GetSizes()[0], │ │ │ │ │ +185 &stencilTable->GetOffsets()[0], │ │ │ │ │ +186 &stencilTable->GetControlIndices()[0], │ │ │ │ │ +187 &stencilTable->GetWeights()[0], │ │ │ │ │ +188 &stencilTable->GetDuWeights()[0], │ │ │ │ │ +189 &stencilTable->GetDvWeights()[0], │ │ │ │ │ +190 /*start = */ 0, │ │ │ │ │ +191 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ +192 } │ │ │ │ │ +193 │ │ │ │ │ +_2_3_4 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +235 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +236 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +237 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +238 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +239 const int * sizes, │ │ │ │ │ +240 const int * offsets, │ │ │ │ │ +241 const int * indices, │ │ │ │ │ +242 const float * weights, │ │ │ │ │ +243 const float * duWeights, │ │ │ │ │ +244 const float * dvWeights, │ │ │ │ │ +245 int start, int end); │ │ │ │ │ +246 │ │ │ │ │ +302 template │ │ │ │ │ +_3_0_3 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +304 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +305 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +306 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +307 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +308 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +309 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +310 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +311 STENCIL_TABLE const *stencilTable, │ │ │ │ │ +312 const _C_p_u_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ +313 void * deviceContext = NULL) { │ │ │ │ │ +314 │ │ │ │ │ +315 (void)instance; // unused │ │ │ │ │ +316 (void)deviceContext; // unused │ │ │ │ │ +317 │ │ │ │ │ +318 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +319 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +320 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +321 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +322 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ +323 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ +324 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ +325 &stencilTable->GetSizes()[0], │ │ │ │ │ +326 &stencilTable->GetOffsets()[0], │ │ │ │ │ +327 &stencilTable->GetControlIndices()[0], │ │ │ │ │ +328 &stencilTable->GetWeights()[0], │ │ │ │ │ +329 &stencilTable->GetDuWeights()[0], │ │ │ │ │ +330 &stencilTable->GetDvWeights()[0], │ │ │ │ │ +331 &stencilTable->GetDuuWeights()[0], │ │ │ │ │ +332 &stencilTable->GetDuvWeights()[0], │ │ │ │ │ +333 &stencilTable->GetDvvWeights()[0], │ │ │ │ │ +334 /*start = */ 0, │ │ │ │ │ +335 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ +336 } │ │ │ │ │ +337 │ │ │ │ │ +_3_9_9 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ +400 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +401 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +402 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +403 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +404 float *duu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +405 float *duv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +406 float *dvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +407 const int * sizes, │ │ │ │ │ +408 const int * offsets, │ │ │ │ │ +409 const int * indices, │ │ │ │ │ +410 const float * weights, │ │ │ │ │ +411 const float * duWeights, │ │ │ │ │ +412 const float * dvWeights, │ │ │ │ │ +413 const float * duuWeights, │ │ │ │ │ +414 const float * duvWeights, │ │ │ │ │ +415 const float * dvvWeights, │ │ │ │ │ +416 int start, int end); │ │ │ │ │ +417 │ │ │ │ │ +423 │ │ │ │ │ +452 template │ │ │ │ │ +_4_5_4 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +455 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +456 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +457 int numPatchCoords, │ │ │ │ │ +458 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +459 PATCH_TABLE *patchTable, │ │ │ │ │ +460 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +461 void * deviceContext = NULL) { │ │ │ │ │ +462 │ │ │ │ │ +463 (void)instance; // unused │ │ │ │ │ +464 (void)deviceContext; // unused │ │ │ │ │ +465 │ │ │ │ │ +466 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +467 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +468 numPatchCoords, │ │ │ │ │ +469 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +470 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ +471 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +472 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +473 } │ │ │ │ │ +474 │ │ │ │ │ +515 template │ │ │ │ │ +_5_1_7 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +518 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +519 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +520 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +521 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +522 int numPatchCoords, │ │ │ │ │ +523 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +524 PATCH_TABLE *patchTable, │ │ │ │ │ +525 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +526 void * deviceContext = NULL) { │ │ │ │ │ +527 │ │ │ │ │ +528 (void)instance; // unused │ │ │ │ │ +529 (void)deviceContext; // unused │ │ │ │ │ +530 │ │ │ │ │ +531 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop. │ │ │ │ │ +532 // ideally all buffer classes should have templated by datatype │ │ │ │ │ +533 // so that downcast isn't needed there. │ │ │ │ │ +534 // (e.g. Osd::CpuBuffer ) │ │ │ │ │ +535 // │ │ │ │ │ +536 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +537 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +538 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +539 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +540 numPatchCoords, │ │ │ │ │ +541 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +542 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ +543 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +544 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +545 } │ │ │ │ │ +546 │ │ │ │ │ +605 template │ │ │ │ │ +_6_0_7 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +608 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +609 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +610 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +611 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +612 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +613 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +614 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +615 int numPatchCoords, │ │ │ │ │ +616 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +617 PATCH_TABLE *patchTable, │ │ │ │ │ +618 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +619 void * deviceContext = NULL) { │ │ │ │ │ +620 │ │ │ │ │ +621 (void)instance; // unused │ │ │ │ │ +622 (void)deviceContext; // unused │ │ │ │ │ +623 │ │ │ │ │ +624 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop. │ │ │ │ │ +625 // ideally all buffer classes should have templated by datatype │ │ │ │ │ +626 // so that downcast isn't needed there. │ │ │ │ │ +627 // (e.g. Osd::CpuBuffer ) │ │ │ │ │ +628 // │ │ │ │ │ +629 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +630 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +631 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +632 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +633 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ +634 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ +635 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ +636 numPatchCoords, │ │ │ │ │ +637 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +638 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ +639 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ +640 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +641 } │ │ │ │ │ +642 │ │ │ │ │ +_6_7_0 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +671 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +672 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +673 int numPatchCoords, │ │ │ │ │ +674 const _P_a_t_c_h_C_o_o_r_d *patchCoords, │ │ │ │ │ +675 const _P_a_t_c_h_A_r_r_a_y *patchArrays, │ │ │ │ │ +676 const int *patchIndexBuffer, │ │ │ │ │ +677 const _P_a_t_c_h_P_a_r_a_m *patchParamBuffer); │ │ │ │ │ +678 │ │ │ │ │ +_7_1_6 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +717 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +718 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +719 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +720 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +721 int numPatchCoords, │ │ │ │ │ +722 _P_a_t_c_h_C_o_o_r_d const *patchCoords, │ │ │ │ │ +723 _P_a_t_c_h_A_r_r_a_y const *patchArrays, │ │ │ │ │ +724 const int *patchIndexBuffer, │ │ │ │ │ +725 _P_a_t_c_h_P_a_r_a_m const *patchParamBuffer); │ │ │ │ │ +726 │ │ │ │ │ +_7_7_9 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ +780 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +781 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +782 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +783 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +784 float *duu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +785 float *duv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +786 float *dvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +787 int numPatchCoords, │ │ │ │ │ +788 _P_a_t_c_h_C_o_o_r_d const *patchCoords, │ │ │ │ │ +789 _P_a_t_c_h_A_r_r_a_y const *patchArrays, │ │ │ │ │ +790 const int *patchIndexBuffer, │ │ │ │ │ +791 _P_a_t_c_h_P_a_r_a_m const *patchParamBuffer); │ │ │ │ │ +792 │ │ │ │ │ +821 template │ │ │ │ │ +_8_2_3 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +824 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +825 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +826 int numPatchCoords, │ │ │ │ │ +827 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +828 PATCH_TABLE *patchTable, │ │ │ │ │ +829 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +830 void * deviceContext = NULL) { │ │ │ │ │ +831 │ │ │ │ │ +832 (void)instance; // unused │ │ │ │ │ +833 (void)deviceContext; // unused │ │ │ │ │ +834 │ │ │ │ │ +835 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +836 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +837 numPatchCoords, │ │ │ │ │ +838 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +839 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ +840 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +841 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +842 } │ │ │ │ │ +843 │ │ │ │ │ +884 template │ │ │ │ │ +_8_8_6 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +887 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +888 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +889 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +890 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +891 int numPatchCoords, │ │ │ │ │ +892 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +893 PATCH_TABLE *patchTable, │ │ │ │ │ +894 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +895 void * deviceContext = NULL) { │ │ │ │ │ +896 │ │ │ │ │ +897 (void)instance; // unused │ │ │ │ │ +898 (void)deviceContext; // unused │ │ │ │ │ +899 │ │ │ │ │ +900 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +901 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +902 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +903 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +904 numPatchCoords, │ │ │ │ │ +905 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +906 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ +907 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +908 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +909 } │ │ │ │ │ +910 │ │ │ │ │ +969 template │ │ │ │ │ +_9_7_1 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ +972 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +973 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +974 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +975 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +976 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +977 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +978 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +979 int numPatchCoords, │ │ │ │ │ +980 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +981 PATCH_TABLE *patchTable, │ │ │ │ │ +982 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +983 void * deviceContext = NULL) { │ │ │ │ │ +984 │ │ │ │ │ +985 (void)instance; // unused │ │ │ │ │ +986 (void)deviceContext; // unused │ │ │ │ │ +987 │ │ │ │ │ +988 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +989 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +990 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +991 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +992 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ +993 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ +994 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ +995 numPatchCoords, │ │ │ │ │ +996 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +997 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ +998 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ +999 patchTable->GetPatchParamBuffer()); │ │ │ │ │ +1000 } │ │ │ │ │ +1001 │ │ │ │ │ +1032 template │ │ │ │ │ +_1_0_3_4 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1035 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1036 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1037 int numPatchCoords, │ │ │ │ │ +1038 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1039 PATCH_TABLE *patchTable, │ │ │ │ │ +1040 int fvarChannel, │ │ │ │ │ +1041 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +1042 void * deviceContext = NULL) { │ │ │ │ │ +1043 │ │ │ │ │ +1044 (void)instance; // unused │ │ │ │ │ +1045 (void)deviceContext; // unused │ │ │ │ │ +1046 │ │ │ │ │ +1047 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +1048 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +1049 numPatchCoords, │ │ │ │ │ +1050 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +1051 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ +1052 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +1053 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ +1054 } │ │ │ │ │ +1055 │ │ │ │ │ +1098 template │ │ │ │ │ +_1_1_0_0 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1101 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1102 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1103 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1104 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1105 int numPatchCoords, │ │ │ │ │ +1106 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1107 PATCH_TABLE *patchTable, │ │ │ │ │ +1108 int fvarChannel, │ │ │ │ │ +1109 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +1110 void * deviceContext = NULL) { │ │ │ │ │ +1111 │ │ │ │ │ +1112 (void)instance; // unused │ │ │ │ │ +1113 (void)deviceContext; // unused │ │ │ │ │ +1114 │ │ │ │ │ +1115 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +1116 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +1117 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +1118 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +1119 numPatchCoords, │ │ │ │ │ +1120 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +1121 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ +1122 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +1123 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ +1124 } │ │ │ │ │ +1125 │ │ │ │ │ +1186 template │ │ │ │ │ +_1_1_8_8 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ +1189 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ +1190 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ +1191 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ +1192 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ +1193 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ +1194 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ +1195 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ +1196 int numPatchCoords, │ │ │ │ │ +1197 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ +1198 PATCH_TABLE *patchTable, │ │ │ │ │ +1199 int fvarChannel, │ │ │ │ │ +1200 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ +1201 void * deviceContext = NULL) { │ │ │ │ │ +1202 │ │ │ │ │ +1203 (void)instance; // unused │ │ │ │ │ +1204 (void)deviceContext; // unused │ │ │ │ │ +1205 │ │ │ │ │ +1206 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ +1207 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ +1208 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ +1209 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ +1210 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ +1211 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ +1212 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ +1213 numPatchCoords, │ │ │ │ │ +1214 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ +1215 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ +1216 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ +1217 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ +1218 } │ │ │ │ │ +1219 │ │ │ │ │ +1225 │ │ │ │ │ +_1_2_2_7 static void _S_y_n_c_h_r_o_n_i_z_e(void * /*deviceContext = NULL*/) { │ │ │ │ │ +1228 // nothing. │ │ │ │ │ +1229 } │ │ │ │ │ +1230}; │ │ │ │ │ +1231 │ │ │ │ │ +1232 │ │ │ │ │ +1233} // end namespace Osd │ │ │ │ │ +1234 │ │ │ │ │ +1235} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +1236using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +1237 │ │ │ │ │ +1238} // end namespace OpenSubdiv │ │ │ │ │ +1239 │ │ │ │ │ +1240 │ │ │ │ │ +1241#endif // OPENSUBDIV3_OSD_CPU_EVALUATOR_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ data buffers.... │ │ │ │ │ DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_s_t_r_i_d_e │ │ │ │ │ -int stride │ │ │ │ │ -stride to the next element │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_1_0_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_R_e_s_e_t │ │ │ │ │ -void Reset() │ │ │ │ │ -Resets the descriptor to default. │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_8_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -BufferDescriptor() │ │ │ │ │ -Default Constructor. │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ -BufferDescriptor(int o, int l, int s) │ │ │ │ │ -Constructor. │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_l_e_n_g_t_h │ │ │ │ │ -int length │ │ │ │ │ -number or length of the data │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_1_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_o_p_e_r_a_t_o_r_!_= │ │ │ │ │ -bool operator!=(BufferDescriptor const &other) const │ │ │ │ │ -True if the descriptors are not identical. │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_9_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_o_p_e_r_a_t_o_r_=_= │ │ │ │ │ -bool operator==(BufferDescriptor const &other) const │ │ │ │ │ -True if the descriptors are identical. │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_I_s_V_a_l_i_d │ │ │ │ │ -bool IsValid() const │ │ │ │ │ -True if the descriptor values are internally consistent. │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_7_5 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_G_e_t_L_o_c_a_l_O_f_f_s_e_t │ │ │ │ │ -int GetLocalOffset() const │ │ │ │ │ -Returns the relative offset within a stride. │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_7_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_o_f_f_s_e_t │ │ │ │ │ -int offset │ │ │ │ │ -offset to desired element data │ │ │ │ │ -DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_9_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_3_9 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ +numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int │ │ │ │ │ +fvarChannel, CpuEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_0_3_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ +DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, int fvarChannel, CpuEvaluator const │ │ │ │ │ +*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_1_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int │ │ │ │ │ +*offsets, const int *indices, const float *weights, int start, int end) │ │ │ │ │ +Static eval stencils function which takes raw CPU pointers for input and │ │ │ │ │ +output. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ +const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ +DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, │ │ │ │ │ +CpuEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_1_8_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const │ │ │ │ │ +*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_9_7_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ +&duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int │ │ │ │ │ +*offsets, const int *indices, const float *weights, const float *duWeights, │ │ │ │ │ +const float *dvWeights, int start, int end) │ │ │ │ │ +Static eval stencils function with derivatives, which takes raw CPU pointers │ │ │ │ │ +for input and output. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ +&duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, │ │ │ │ │ +BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, │ │ │ │ │ +float *dvv, BufferDescriptor const &dvvDesc, const int *sizes, const int │ │ │ │ │ +*offsets, const int *indices, const float *weights, const float *duWeights, │ │ │ │ │ +const float *dvWeights, const float *duuWeights, const float *duvWeights, const │ │ │ │ │ +float *dvvWeights, int start, int end) │ │ │ │ │ +Static eval stencils function with derivatives, which takes raw CPU pointers │ │ │ │ │ +for input and output. │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ +&duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, │ │ │ │ │ +BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, │ │ │ │ │ +float *dvv, BufferDescriptor const &dvvDesc, int numPatchCoords, PatchCoord │ │ │ │ │ +const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, │ │ │ │ │ +PatchParam const *patchParamBuffer) │ │ │ │ │ +Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ +values on given PatchT... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ +PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const │ │ │ │ │ +*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_4_5_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ +*patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function with derivatives. This function has a same │ │ │ │ │ +signature as other device kern... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_5_1_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ +&duDesc, float *dv, BufferDescriptor const &dvDesc, int numPatchCoords, │ │ │ │ │ +PatchCoord const *patchCoords, PatchArray const *patchArrays, const int │ │ │ │ │ +*patchIndexBuffer, PatchParam const *patchParamBuffer) │ │ │ │ │ +Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ +values on given PatchT... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ +&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ +*dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, │ │ │ │ │ +const CpuEvaluator *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic static eval stencils function with derivatives. This function has a │ │ │ │ │ +same signature as other d... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_3_0_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ +float *dst, BufferDescriptor const &dstDesc, int numPatchCoords, const │ │ │ │ │ +PatchCoord *patchCoords, const PatchArray *patchArrays, const int │ │ │ │ │ +*patchIndexBuffer, const PatchParam *patchParamBuffer) │ │ │ │ │ +Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ +values on given PatchT... │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_8_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ +static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ +numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, │ │ │ │ │ +CpuEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic limit eval function. This function has a same signature as other device │ │ │ │ │ +kernels have so that ... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_8_2_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_S_y_n_c_h_r_o_n_i_z_e │ │ │ │ │ +static void Synchronize(void *) │ │ │ │ │ +synchronize all asynchronous computation invoked on this device. │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_2_2_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE │ │ │ │ │ +const *stencilTable, const CpuEvaluator *instance=NULL, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +Generic static eval stencils function. This function has a same signature as │ │ │ │ │ +other device kernels hav... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_7_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ +static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ +DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ +BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ +&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ +*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ +BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ +*patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void │ │ │ │ │ +*deviceContext=NULL) │ │ │ │ │ +Generic limit eval function with derivatives. This function has a same │ │ │ │ │ +signature as other device kern... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_6_0_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ +static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ +&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ +*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ +BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const │ │ │ │ │ +CpuEvaluator *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ +Generic static eval stencils function with derivatives. This function has a │ │ │ │ │ +same signature as other d... │ │ │ │ │ +DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_6_8 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_C_o_o_r_d │ │ │ │ │ +Coordinates set on a patch table. │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_A_r_r_a_y │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_6_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_P_a_r_a_m │ │ │ │ │ +DDeeffiinniittiioonn _t_y_p_e_s_._h_:_1_2_7 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h │ │ │ │ │ + * _c_p_u_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00899.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/cpuEvaluator.h File Reference │ │ │ │ +OpenSubdiv: opensubdiv/osd/bufferDescriptor.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -90,27 +90,26 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ Classes | │ │ │ │ Namespaces
│ │ │ │ -
cpuEvaluator.h File Reference
│ │ │ │ +
bufferDescriptor.h File Reference
│ │ │ │
│ │ │ │
│ │ │ │
#include "../version.h"
│ │ │ │ -#include "../osd/bufferDescriptor.h"
│ │ │ │ -#include "../osd/types.h"
│ │ │ │ -#include <cstddef>
│ │ │ │ +#include <string.h>
│ │ │ │
│ │ │ │

Go to the source code of this file.

│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  CpuEvaluator
struct  BufferDescriptor
 BufferDescriptor is a struct which describes buffer elements in interleaved data buffers. Almost all Osd Evaluator APIs take BufferDescriptors along with device-specific buffer objects. More...
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -119,13 +118,13 @@ │ │ │ │ │ │ │ │

│ │ │ │ Namespaces

namespace  OpenSubdiv
 
namespace  OpenSubdiv::OPENSUBDIV_VERSION
 
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,25 +1,26 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ _C_l_a_s_s_e_s | _N_a_m_e_s_p_a_c_e_s │ │ │ │ │ -cpuEvaluator.h File Reference │ │ │ │ │ +bufferDescriptor.h File Reference │ │ │ │ │ #include "../version.h" │ │ │ │ │ -#include "_._._/_o_s_d_/_b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h" │ │ │ │ │ -#include "_._._/_o_s_d_/_t_y_p_e_s_._h" │ │ │ │ │ -#include │ │ │ │ │ +#include │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _s_o_u_r_c_e_ _c_o_d_e_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ CCllaasssseess │ │ │ │ │ -class   _C_p_u_E_v_a_l_u_a_t_o_r │ │ │ │ │ +struct   _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ + _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r is a struct which describes buffer elements in │ │ │ │ │ +  interleaved data buffers. Almost all _O_s_d Evaluator APIs take │ │ │ │ │ + BufferDescriptors along with device-specific buffer objects. _M_o_r_e_._._. │ │ │ │ │   │ │ │ │ │ NNaammeessppaacceess │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N │ │ │ │ │   │ │ │ │ │ namespace   _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d │ │ │ │ │   │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _c_p_u_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ + * _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00899.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,3 +1,3 @@ │ │ │ │ │ var a00899 = [ │ │ │ │ │ - ["CpuEvaluator", "a01165.html", null] │ │ │ │ │ + ["BufferDescriptor", "a01141.html", "a01141"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00899_source.html │ │ │ │ @@ -1,15 +1,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -OpenSubdiv: opensubdiv/osd/cpuEvaluator.h Source File │ │ │ │ +OpenSubdiv: opensubdiv/osd/bufferDescriptor.h Source File │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -92,15 +92,15 @@ │ │ │ │
No Matches
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ -
cpuEvaluator.h
│ │ │ │ +
bufferDescriptor.h
│ │ │ │
│ │ │ │
│ │ │ │ Go to the documentation of this file.
1//
│ │ │ │
2// Copyright 2015 Pixar
│ │ │ │
3//
│ │ │ │
4// Licensed under the Apache License, Version 2.0 (the "Apache License")
│ │ │ │
5// with the following modification; you may not use this file except in
│ │ │ │ @@ -119,529 +119,112 @@ │ │ │ │
18// Unless required by applicable law or agreed to in writing, software
│ │ │ │
19// distributed under the Apache License with the above modification is
│ │ │ │
20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
│ │ │ │
21// KIND, either express or implied. See the Apache License for the specific
│ │ │ │
22// language governing permissions and limitations under the Apache License.
│ │ │ │
23//
│ │ │ │
24
│ │ │ │ -
25#ifndef OPENSUBDIV3_OSD_CPU_EVALUATOR_H
│ │ │ │ -
26#define OPENSUBDIV3_OSD_CPU_EVALUATOR_H
│ │ │ │ +
25#ifndef OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H
│ │ │ │ +
26#define OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H
│ │ │ │
27
│ │ │ │
28#include "../version.h"
│ │ │ │ -
29#include "../osd/bufferDescriptor.h"
│ │ │ │ -
30#include "../osd/types.h"
│ │ │ │ -
31
│ │ │ │ -
32#include <cstddef>
│ │ │ │ +
29#include <string.h>
│ │ │ │ +
30
│ │ │ │ +
31namespace OpenSubdiv {
│ │ │ │ +
32namespace OPENSUBDIV_VERSION {
│ │ │ │
33
│ │ │ │ -
34namespace OpenSubdiv {
│ │ │ │ -
35namespace OPENSUBDIV_VERSION {
│ │ │ │ -
36
│ │ │ │ -
37namespace Osd {
│ │ │ │ -
38
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
40public:
│ │ │ │ +
│ │ │ │ +
34namespace Osd {
│ │ │ │ +
35
│ │ │ │
46
│ │ │ │ -
71 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
72 static bool EvalStencils(
│ │ │ │ -
73 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
74 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
75 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
76 const CpuEvaluator *instance = NULL,
│ │ │ │ -
77 void * deviceContext = NULL) {
│ │ │ │ -
78
│ │ │ │ -
79 (void)instance; // unused
│ │ │ │ -
80 (void)deviceContext; // unused
│ │ │ │ -
81
│ │ │ │ -
82 if (stencilTable->GetNumStencils() == 0)
│ │ │ │ -
83 return false;
│ │ │ │ +
47// example:
│ │ │ │ +
48// n
│ │ │ │ +
49// -----+----------------------------------------+-------------------------
│ │ │ │ +
50// | vertex 0 |
│ │ │ │ +
51// -----+----------------------------------------+-------------------------
│ │ │ │ +
52// | X Y Z R G B A Xu Yu Zu Xv Yv Zv |
│ │ │ │ +
53// -----+----------------------------------------+-------------------------
│ │ │ │ +
54// <------------- stride = 13 -------------->
│ │ │ │ +
55//
│ │ │ │ +
56// - XYZ (offset = n+0, length = 3, stride = 13)
│ │ │ │ +
57// - RGBA (offset = n+3, length = 4, stride = 13)
│ │ │ │ +
58// - uTangent (offset = n+7, length = 3, stride = 13)
│ │ │ │ +
59// - vTangent (offset = n+10, length = 3, stride = 13)
│ │ │ │ +
60//
│ │ │ │ +
│ │ │ │ + │ │ │ │ +
62
│ │ │ │ + │ │ │ │ +
65
│ │ │ │ +
67 BufferDescriptor(int o, int l, int s) : offset(o), length(l), stride(s) { }
│ │ │ │ +
68
│ │ │ │ +
│ │ │ │ +
70 int GetLocalOffset() const {
│ │ │ │ +
71 return stride > 0 ? offset % stride : 0;
│ │ │ │ +
72 }
│ │ │ │ +
│ │ │ │ +
73
│ │ │ │ +
│ │ │ │ +
75 bool IsValid() const {
│ │ │ │ +
76 return ((length > 0) &&
│ │ │ │ + │ │ │ │ +
78 }
│ │ │ │ +
│ │ │ │ +
79
│ │ │ │ +
│ │ │ │ +
81 void Reset() {
│ │ │ │ +
82 offset = length = stride = 0;
│ │ │ │ +
83 }
│ │ │ │ +
│ │ │ │
84
│ │ │ │ -
85 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
86 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
87 &stencilTable->GetSizes()[0],
│ │ │ │ -
88 &stencilTable->GetOffsets()[0],
│ │ │ │ -
89 &stencilTable->GetControlIndices()[0],
│ │ │ │ -
90 &stencilTable->GetWeights()[0],
│ │ │ │ -
91 /*start = */ 0,
│ │ │ │ -
92 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ -
93 }
│ │ │ │ -
│ │ │ │ -
94
│ │ │ │ -
121 static bool EvalStencils(
│ │ │ │ -
122 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
123 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
124 const int * sizes,
│ │ │ │ -
125 const int * offsets,
│ │ │ │ -
126 const int * indices,
│ │ │ │ -
127 const float * weights,
│ │ │ │ -
128 int start, int end);
│ │ │ │ -
129
│ │ │ │ -
167 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
168 static bool EvalStencils(
│ │ │ │ -
169 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
170 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
171 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
172 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
173 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
174 const CpuEvaluator *instance = NULL,
│ │ │ │ -
175 void * deviceContext = NULL) {
│ │ │ │ -
176
│ │ │ │ -
177 (void)instance; // unused
│ │ │ │ -
178 (void)deviceContext; // unused
│ │ │ │ -
179
│ │ │ │ -
180 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
181 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
182 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
183 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
184 &stencilTable->GetSizes()[0],
│ │ │ │ -
185 &stencilTable->GetOffsets()[0],
│ │ │ │ -
186 &stencilTable->GetControlIndices()[0],
│ │ │ │ -
187 &stencilTable->GetWeights()[0],
│ │ │ │ -
188 &stencilTable->GetDuWeights()[0],
│ │ │ │ -
189 &stencilTable->GetDvWeights()[0],
│ │ │ │ -
190 /*start = */ 0,
│ │ │ │ -
191 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ -
192 }
│ │ │ │ -
│ │ │ │ -
193
│ │ │ │ -
234 static bool EvalStencils(
│ │ │ │ -
235 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
236 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
237 float *du, BufferDescriptor const &duDesc,
│ │ │ │ -
238 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ -
239 const int * sizes,
│ │ │ │ -
240 const int * offsets,
│ │ │ │ -
241 const int * indices,
│ │ │ │ -
242 const float * weights,
│ │ │ │ -
243 const float * duWeights,
│ │ │ │ -
244 const float * dvWeights,
│ │ │ │ -
245 int start, int end);
│ │ │ │ -
246
│ │ │ │ -
302 template <typename SRC_BUFFER, typename DST_BUFFER, typename STENCIL_TABLE>
│ │ │ │ -
│ │ │ │ -
303 static bool EvalStencils(
│ │ │ │ -
304 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
305 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
306 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
307 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
308 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
309 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
310 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
311 STENCIL_TABLE const *stencilTable,
│ │ │ │ -
312 const CpuEvaluator *instance = NULL,
│ │ │ │ -
313 void * deviceContext = NULL) {
│ │ │ │ -
314
│ │ │ │ -
315 (void)instance; // unused
│ │ │ │ -
316 (void)deviceContext; // unused
│ │ │ │ -
317
│ │ │ │ -
318 return EvalStencils(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
319 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
320 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
321 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
322 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ -
323 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ -
324 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ -
325 &stencilTable->GetSizes()[0],
│ │ │ │ -
326 &stencilTable->GetOffsets()[0],
│ │ │ │ -
327 &stencilTable->GetControlIndices()[0],
│ │ │ │ -
328 &stencilTable->GetWeights()[0],
│ │ │ │ -
329 &stencilTable->GetDuWeights()[0],
│ │ │ │ -
330 &stencilTable->GetDvWeights()[0],
│ │ │ │ -
331 &stencilTable->GetDuuWeights()[0],
│ │ │ │ -
332 &stencilTable->GetDuvWeights()[0],
│ │ │ │ -
333 &stencilTable->GetDvvWeights()[0],
│ │ │ │ -
334 /*start = */ 0,
│ │ │ │ -
335 /*end = */ stencilTable->GetNumStencils());
│ │ │ │ -
336 }
│ │ │ │ -
│ │ │ │ -
337
│ │ │ │ -
399 static bool EvalStencils(
│ │ │ │ -
400 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
401 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
402 float *du, BufferDescriptor const &duDesc,
│ │ │ │ -
403 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ -
404 float *duu, BufferDescriptor const &duuDesc,
│ │ │ │ -
405 float *duv, BufferDescriptor const &duvDesc,
│ │ │ │ -
406 float *dvv, BufferDescriptor const &dvvDesc,
│ │ │ │ -
407 const int * sizes,
│ │ │ │ -
408 const int * offsets,
│ │ │ │ -
409 const int * indices,
│ │ │ │ -
410 const float * weights,
│ │ │ │ -
411 const float * duWeights,
│ │ │ │ -
412 const float * dvWeights,
│ │ │ │ -
413 const float * duuWeights,
│ │ │ │ -
414 const float * duvWeights,
│ │ │ │ -
415 const float * dvvWeights,
│ │ │ │ -
416 int start, int end);
│ │ │ │ -
417
│ │ │ │ -
423
│ │ │ │ -
452 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
453 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
454 static bool EvalPatches(
│ │ │ │ -
455 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
456 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
457 int numPatchCoords,
│ │ │ │ -
458 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
459 PATCH_TABLE *patchTable,
│ │ │ │ -
460 CpuEvaluator const *instance = NULL,
│ │ │ │ -
461 void * deviceContext = NULL) {
│ │ │ │ -
462
│ │ │ │ -
463 (void)instance; // unused
│ │ │ │ -
464 (void)deviceContext; // unused
│ │ │ │ -
465
│ │ │ │ -
466 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
467 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
468 numPatchCoords,
│ │ │ │ -
469 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
470 patchTable->GetPatchArrayBuffer(),
│ │ │ │ -
471 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
472 patchTable->GetPatchParamBuffer());
│ │ │ │ -
473 }
│ │ │ │ -
│ │ │ │ -
474
│ │ │ │ -
515 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
516 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
517 static bool EvalPatches(
│ │ │ │ -
518 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
519 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
520 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
521 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
522 int numPatchCoords,
│ │ │ │ -
523 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
524 PATCH_TABLE *patchTable,
│ │ │ │ -
525 CpuEvaluator const *instance = NULL,
│ │ │ │ -
526 void * deviceContext = NULL) {
│ │ │ │ -
527
│ │ │ │ -
528 (void)instance; // unused
│ │ │ │ -
529 (void)deviceContext; // unused
│ │ │ │ -
530
│ │ │ │ -
531 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop.
│ │ │ │ -
532 // ideally all buffer classes should have templated by datatype
│ │ │ │ -
533 // so that downcast isn't needed there.
│ │ │ │ -
534 // (e.g. Osd::CpuBuffer<PatchCoord> )
│ │ │ │ -
535 //
│ │ │ │ -
536 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
537 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
538 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
539 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
540 numPatchCoords,
│ │ │ │ -
541 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
542 patchTable->GetPatchArrayBuffer(),
│ │ │ │ -
543 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
544 patchTable->GetPatchParamBuffer());
│ │ │ │ -
545 }
│ │ │ │ -
│ │ │ │ -
546
│ │ │ │ -
605 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
606 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ -
607 static bool EvalPatches(
│ │ │ │ -
608 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
609 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
610 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
611 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
612 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
613 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
614 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
615 int numPatchCoords,
│ │ │ │ -
616 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
617 PATCH_TABLE *patchTable,
│ │ │ │ -
618 CpuEvaluator const *instance = NULL,
│ │ │ │ -
619 void * deviceContext = NULL) {
│ │ │ │ -
620
│ │ │ │ -
621 (void)instance; // unused
│ │ │ │ -
622 (void)deviceContext; // unused
│ │ │ │ -
623
│ │ │ │ -
624 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop.
│ │ │ │ -
625 // ideally all buffer classes should have templated by datatype
│ │ │ │ -
626 // so that downcast isn't needed there.
│ │ │ │ -
627 // (e.g. Osd::CpuBuffer<PatchCoord> )
│ │ │ │ -
628 //
│ │ │ │ -
629 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
630 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
631 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
632 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
633 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ -
634 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ -
635 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ -
636 numPatchCoords,
│ │ │ │ -
637 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
638 patchTable->GetPatchArrayBuffer(),
│ │ │ │ -
639 patchTable->GetPatchIndexBuffer(),
│ │ │ │ -
640 patchTable->GetPatchParamBuffer());
│ │ │ │ -
641 }
│ │ │ │ -
│ │ │ │ -
642
│ │ │ │ -
670 static bool EvalPatches(
│ │ │ │ -
671 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
672 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
673 int numPatchCoords,
│ │ │ │ -
674 const PatchCoord *patchCoords,
│ │ │ │ -
675 const PatchArray *patchArrays,
│ │ │ │ -
676 const int *patchIndexBuffer,
│ │ │ │ -
677 const PatchParam *patchParamBuffer);
│ │ │ │ -
678
│ │ │ │ -
716 static bool EvalPatches(
│ │ │ │ -
717 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
718 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
719 float *du, BufferDescriptor const &duDesc,
│ │ │ │ -
720 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ -
721 int numPatchCoords,
│ │ │ │ -
722 PatchCoord const *patchCoords,
│ │ │ │ -
723 PatchArray const *patchArrays,
│ │ │ │ -
724 const int *patchIndexBuffer,
│ │ │ │ -
725 PatchParam const *patchParamBuffer);
│ │ │ │ -
726
│ │ │ │ -
779 static bool EvalPatches(
│ │ │ │ -
780 const float *src, BufferDescriptor const &srcDesc,
│ │ │ │ -
781 float *dst, BufferDescriptor const &dstDesc,
│ │ │ │ -
782 float *du, BufferDescriptor const &duDesc,
│ │ │ │ -
783 float *dv, BufferDescriptor const &dvDesc,
│ │ │ │ -
784 float *duu, BufferDescriptor const &duuDesc,
│ │ │ │ -
785 float *duv, BufferDescriptor const &duvDesc,
│ │ │ │ -
786 float *dvv, BufferDescriptor const &dvvDesc,
│ │ │ │ -
787 int numPatchCoords,
│ │ │ │ -
788 PatchCoord const *patchCoords,
│ │ │ │ -
789 PatchArray const *patchArrays,
│ │ │ │ -
790 const int *patchIndexBuffer,
│ │ │ │ -
791 PatchParam const *patchParamBuffer);
│ │ │ │ -
792
│ │ │ │ -
821 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
822 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
824 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
825 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
826 int numPatchCoords,
│ │ │ │ -
827 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
828 PATCH_TABLE *patchTable,
│ │ │ │ -
829 CpuEvaluator const *instance = NULL,
│ │ │ │ -
830 void * deviceContext = NULL) {
│ │ │ │ -
831
│ │ │ │ -
832 (void)instance; // unused
│ │ │ │ -
833 (void)deviceContext; // unused
│ │ │ │ -
834
│ │ │ │ -
835 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
836 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
837 numPatchCoords,
│ │ │ │ -
838 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
839 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ -
840 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
841 patchTable->GetPatchParamBuffer());
│ │ │ │ -
842 }
│ │ │ │ -
│ │ │ │ -
843
│ │ │ │ -
884 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
885 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
887 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
888 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
889 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
890 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
891 int numPatchCoords,
│ │ │ │ -
892 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
893 PATCH_TABLE *patchTable,
│ │ │ │ -
894 CpuEvaluator const *instance = NULL,
│ │ │ │ -
895 void * deviceContext = NULL) {
│ │ │ │ -
896
│ │ │ │ -
897 (void)instance; // unused
│ │ │ │ -
898 (void)deviceContext; // unused
│ │ │ │ -
899
│ │ │ │ -
900 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
901 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
902 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
903 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
904 numPatchCoords,
│ │ │ │ -
905 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
906 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ -
907 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
908 patchTable->GetPatchParamBuffer());
│ │ │ │ -
909 }
│ │ │ │ -
│ │ │ │ -
910
│ │ │ │ -
969 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
970 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
972 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
973 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
974 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
975 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
976 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
977 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
978 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
979 int numPatchCoords,
│ │ │ │ -
980 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
981 PATCH_TABLE *patchTable,
│ │ │ │ -
982 CpuEvaluator const *instance = NULL,
│ │ │ │ -
983 void * deviceContext = NULL) {
│ │ │ │ -
984
│ │ │ │ -
985 (void)instance; // unused
│ │ │ │ -
986 (void)deviceContext; // unused
│ │ │ │ -
987
│ │ │ │ -
988 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
989 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
990 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
991 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
992 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ -
993 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ -
994 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ -
995 numPatchCoords,
│ │ │ │ -
996 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
997 patchTable->GetVaryingPatchArrayBuffer(),
│ │ │ │ -
998 patchTable->GetVaryingPatchIndexBuffer(),
│ │ │ │ -
999 patchTable->GetPatchParamBuffer());
│ │ │ │ -
1000 }
│ │ │ │ -
│ │ │ │ -
1001
│ │ │ │ -
1032 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1033 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1035 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1036 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1037 int numPatchCoords,
│ │ │ │ -
1038 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1039 PATCH_TABLE *patchTable,
│ │ │ │ -
1040 int fvarChannel,
│ │ │ │ -
1041 CpuEvaluator const *instance = NULL,
│ │ │ │ -
1042 void * deviceContext = NULL) {
│ │ │ │ -
1043
│ │ │ │ -
1044 (void)instance; // unused
│ │ │ │ -
1045 (void)deviceContext; // unused
│ │ │ │ -
1046
│ │ │ │ -
1047 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
1048 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
1049 numPatchCoords,
│ │ │ │ -
1050 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
1051 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ -
1052 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
1053 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ -
1054 }
│ │ │ │ -
│ │ │ │ -
1055
│ │ │ │ -
1098 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1099 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1101 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1102 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1103 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1104 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1105 int numPatchCoords,
│ │ │ │ -
1106 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1107 PATCH_TABLE *patchTable,
│ │ │ │ -
1108 int fvarChannel,
│ │ │ │ -
1109 CpuEvaluator const *instance = NULL,
│ │ │ │ -
1110 void * deviceContext = NULL) {
│ │ │ │ -
1111
│ │ │ │ -
1112 (void)instance; // unused
│ │ │ │ -
1113 (void)deviceContext; // unused
│ │ │ │ -
1114
│ │ │ │ -
1115 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
1116 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
1117 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
1118 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
1119 numPatchCoords,
│ │ │ │ -
1120 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
1121 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ -
1122 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
1123 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ -
1124 }
│ │ │ │ -
│ │ │ │ -
1125
│ │ │ │ -
1186 template <typename SRC_BUFFER, typename DST_BUFFER,
│ │ │ │ -
1187 typename PATCHCOORD_BUFFER, typename PATCH_TABLE>
│ │ │ │ -
│ │ │ │ - │ │ │ │ -
1189 SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc,
│ │ │ │ -
1190 DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc,
│ │ │ │ -
1191 DST_BUFFER *duBuffer, BufferDescriptor const &duDesc,
│ │ │ │ -
1192 DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc,
│ │ │ │ -
1193 DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc,
│ │ │ │ -
1194 DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc,
│ │ │ │ -
1195 DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc,
│ │ │ │ -
1196 int numPatchCoords,
│ │ │ │ -
1197 PATCHCOORD_BUFFER *patchCoords,
│ │ │ │ -
1198 PATCH_TABLE *patchTable,
│ │ │ │ -
1199 int fvarChannel,
│ │ │ │ -
1200 CpuEvaluator const *instance = NULL,
│ │ │ │ -
1201 void * deviceContext = NULL) {
│ │ │ │ -
1202
│ │ │ │ -
1203 (void)instance; // unused
│ │ │ │ -
1204 (void)deviceContext; // unused
│ │ │ │ -
1205
│ │ │ │ -
1206 return EvalPatches(srcBuffer->BindCpuBuffer(), srcDesc,
│ │ │ │ -
1207 dstBuffer->BindCpuBuffer(), dstDesc,
│ │ │ │ -
1208 duBuffer->BindCpuBuffer(), duDesc,
│ │ │ │ -
1209 dvBuffer->BindCpuBuffer(), dvDesc,
│ │ │ │ -
1210 duuBuffer->BindCpuBuffer(), duuDesc,
│ │ │ │ -
1211 duvBuffer->BindCpuBuffer(), duvDesc,
│ │ │ │ -
1212 dvvBuffer->BindCpuBuffer(), dvvDesc,
│ │ │ │ -
1213 numPatchCoords,
│ │ │ │ -
1214 (const PatchCoord*)patchCoords->BindCpuBuffer(),
│ │ │ │ -
1215 patchTable->GetFVarPatchArrayBuffer(fvarChannel),
│ │ │ │ -
1216 patchTable->GetFVarPatchIndexBuffer(fvarChannel),
│ │ │ │ -
1217 patchTable->GetFVarPatchParamBuffer(fvarChannel));
│ │ │ │ -
1218 }
│ │ │ │ -
│ │ │ │ -
1219
│ │ │ │ -
1225
│ │ │ │ -
│ │ │ │ -
1227 static void Synchronize(void * /*deviceContext = NULL*/) {
│ │ │ │ -
1228 // nothing.
│ │ │ │ -
1229 }
│ │ │ │ -
│ │ │ │ -
1230};
│ │ │ │ -
│ │ │ │ -
1231
│ │ │ │ -
1232
│ │ │ │ -
1233} // end namespace Osd
│ │ │ │ -
1234
│ │ │ │ -
1235} // end namespace OPENSUBDIV_VERSION
│ │ │ │ -
1236using namespace OPENSUBDIV_VERSION;
│ │ │ │ -
1237
│ │ │ │ -
1238} // end namespace OpenSubdiv
│ │ │ │ -
1239
│ │ │ │ -
1240
│ │ │ │ -
1241#endif // OPENSUBDIV3_OSD_CPU_EVALUATOR_H
│ │ │ │ - │ │ │ │ -
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ - │ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, int start, int end)
Static eval stencils function which takes raw CPU pointers for input and output.
│ │ │ │ -
static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │ -
static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, float *dvv, BufferDescriptor const &dvvDesc, const int *sizes, const int *offsets, const int *indices, const float *weights, const float *duWeights, const float *dvWeights, const float *duuWeights, const float *duvWeights, const float *dvvWeights, int start, int end)
Static eval stencils function with derivatives, which takes raw CPU pointers for input and output.
│ │ │ │ -
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, float *dvv, BufferDescriptor const &dvvDesc, int numPatchCoords, PatchCoord const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, PatchParam const *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ -
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const &duDesc, float *dv, BufferDescriptor const &dvDesc, int numPatchCoords, PatchCoord const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, PatchParam const *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, const CpuEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │ -
static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrays, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)
Static limit eval function. It takes an array of PatchCoord and evaluate limit values on given PatchT...
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function. This function has a same signature as other device kernels have so that ...
│ │ │ │ -
static void Synchronize(void *)
synchronize all asynchronous computation invoked on this device.
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, const CpuEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function. This function has a same signature as other device kernels hav...
│ │ │ │ -
static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL)
Generic limit eval function with derivatives. This function has a same signature as other device kern...
│ │ │ │ -
static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const CpuEvaluator *instance=NULL, void *deviceContext=NULL)
Generic static eval stencils function with derivatives. This function has a same signature as other d...
│ │ │ │ -
Coordinates set on a patch table.
Definition types.h:42
│ │ │ │ - │ │ │ │ - │ │ │ │ +
│ │ │ │ +
86 bool operator == (BufferDescriptor const &other) const {
│ │ │ │ +
87 return (offset == other.offset &&
│ │ │ │ +
88 length == other.length &&
│ │ │ │ +
89 stride == other.stride);
│ │ │ │ +
90 }
│ │ │ │ +
│ │ │ │ +
91
│ │ │ │ +
│ │ │ │ +
93 bool operator != (BufferDescriptor const &other) const {
│ │ │ │ +
94 return !(this->operator==(other));
│ │ │ │ +
95 }
│ │ │ │ +
│ │ │ │ +
96
│ │ │ │ +
98 int offset;
│ │ │ │ + │ │ │ │ + │ │ │ │ +
103};
│ │ │ │ +
│ │ │ │ +
104
│ │ │ │ +
105} // end namespace Osd
│ │ │ │ +
│ │ │ │ +
106
│ │ │ │ +
107} // end namespace OPENSUBDIV_VERSION
│ │ │ │ +
108using namespace OPENSUBDIV_VERSION;
│ │ │ │ +
109
│ │ │ │ +
110} // end namespace OpenSubdiv
│ │ │ │ +
111
│ │ │ │ +
112#endif // OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H
│ │ │ │ + │ │ │ │ +
BufferDescriptor is a struct which describes buffer elements in interleaved data buffers....
│ │ │ │ + │ │ │ │ +
void Reset()
Resets the descriptor to default.
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ +
bool operator!=(BufferDescriptor const &other) const
True if the descriptors are not identical.
│ │ │ │ +
bool operator==(BufferDescriptor const &other) const
True if the descriptors are identical.
│ │ │ │ +
bool IsValid() const
True if the descriptor values are internally consistent.
│ │ │ │ +
int GetLocalOffset() const
Returns the relative offset within a stride.
│ │ │ │ + │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ [Logo] OpenSubdiv │ │ │ │ │ Loading... │ │ │ │ │ Searching... │ │ │ │ │ No Matches │ │ │ │ │ -cpuEvaluator.h │ │ │ │ │ +bufferDescriptor.h │ │ │ │ │ _G_o_ _t_o_ _t_h_e_ _d_o_c_u_m_e_n_t_a_t_i_o_n_ _o_f_ _t_h_i_s_ _f_i_l_e_. │ │ │ │ │ 1// │ │ │ │ │ 2// Copyright 2015 Pixar │ │ │ │ │ 3// │ │ │ │ │ 4// Licensed under the Apache License, Version 2.0 (the "Apache License") │ │ │ │ │ 5// with the following modification; you may not use this file except in │ │ │ │ │ 6// compliance with the Apache License and the following modification to it: │ │ │ │ │ @@ -24,655 +24,125 @@ │ │ │ │ │ 18// Unless required by applicable law or agreed to in writing, software │ │ │ │ │ 19// distributed under the Apache License with the above modification is │ │ │ │ │ 20// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY │ │ │ │ │ 21// KIND, either express or implied. See the Apache License for the specific │ │ │ │ │ 22// language governing permissions and limitations under the Apache License. │ │ │ │ │ 23// │ │ │ │ │ 24 │ │ │ │ │ -25#ifndef OPENSUBDIV3_OSD_CPU_EVALUATOR_H │ │ │ │ │ -26#define OPENSUBDIV3_OSD_CPU_EVALUATOR_H │ │ │ │ │ +25#ifndef OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H │ │ │ │ │ +26#define OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H │ │ │ │ │ 27 │ │ │ │ │ 28#include "../version.h" │ │ │ │ │ -29#include "../osd/bufferDescriptor.h" │ │ │ │ │ -30#include "../osd/types.h" │ │ │ │ │ -31 │ │ │ │ │ -32#include │ │ │ │ │ +29#include │ │ │ │ │ +30 │ │ │ │ │ +31namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ +32namespace OPENSUBDIV_VERSION { │ │ │ │ │ 33 │ │ │ │ │ -34namespace _O_p_e_n_S_u_b_d_i_v { │ │ │ │ │ -35namespace OPENSUBDIV_VERSION { │ │ │ │ │ -36 │ │ │ │ │ -37namespace Osd { │ │ │ │ │ -38 │ │ │ │ │ -_3_9class _C_p_u_E_v_a_l_u_a_t_o_r { │ │ │ │ │ -40public: │ │ │ │ │ +_3_4namespace Osd { │ │ │ │ │ +35 │ │ │ │ │ 46 │ │ │ │ │ -71 template │ │ │ │ │ -_7_2 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -73 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -74 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -75 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -76 const _C_p_u_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ -77 void * deviceContext = NULL) { │ │ │ │ │ -78 │ │ │ │ │ -79 (void)instance; // unused │ │ │ │ │ -80 (void)deviceContext; // unused │ │ │ │ │ -81 │ │ │ │ │ -82 if (stencilTable->GetNumStencils() == 0) │ │ │ │ │ -83 return false; │ │ │ │ │ +47// example: │ │ │ │ │ +48// n │ │ │ │ │ +49// -----+----------------------------------------+------------------------- │ │ │ │ │ +50// | vertex 0 | │ │ │ │ │ +51// -----+----------------------------------------+------------------------- │ │ │ │ │ +52// | X Y Z R G B A Xu Yu Zu Xv Yv Zv | │ │ │ │ │ +53// -----+----------------------------------------+------------------------- │ │ │ │ │ +54// <------------- stride = 13 --------------> │ │ │ │ │ +55// │ │ │ │ │ +56// - XYZ (offset = n+0, length = 3, stride = 13) │ │ │ │ │ +57// - RGBA (offset = n+3, length = 4, stride = 13) │ │ │ │ │ +58// - uTangent (offset = n+7, length = 3, stride = 13) │ │ │ │ │ +59// - vTangent (offset = n+10, length = 3, stride = 13) │ │ │ │ │ +60// │ │ │ │ │ +_6_1struct _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r { │ │ │ │ │ +62 │ │ │ │ │ +_6_4 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r() : _o_f_f_s_e_t(0), _l_e_n_g_t_h(0), _s_t_r_i_d_e(0) { } │ │ │ │ │ +65 │ │ │ │ │ +_6_7 _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r(int o, int l, int s) : _o_f_f_s_e_t(o), _l_e_n_g_t_h(l), _s_t_r_i_d_e(s) { } │ │ │ │ │ +68 │ │ │ │ │ +_7_0 int _G_e_t_L_o_c_a_l_O_f_f_s_e_t() const { │ │ │ │ │ +71 return _s_t_r_i_d_e > 0 ? _o_f_f_s_e_t % _s_t_r_i_d_e : 0; │ │ │ │ │ +72 } │ │ │ │ │ +73 │ │ │ │ │ +_7_5 bool _I_s_V_a_l_i_d() const { │ │ │ │ │ +76 return ((_l_e_n_g_t_h > 0) && │ │ │ │ │ +77 (_l_e_n_g_t_h <= _s_t_r_i_d_e - _G_e_t_L_o_c_a_l_O_f_f_s_e_t())); │ │ │ │ │ +78 } │ │ │ │ │ +79 │ │ │ │ │ +_8_1 void _R_e_s_e_t() { │ │ │ │ │ +82 _o_f_f_s_e_t = _l_e_n_g_t_h = _s_t_r_i_d_e = 0; │ │ │ │ │ +83 } │ │ │ │ │ 84 │ │ │ │ │ -85 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -86 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -87 &stencilTable->GetSizes()[0], │ │ │ │ │ -88 &stencilTable->GetOffsets()[0], │ │ │ │ │ -89 &stencilTable->GetControlIndices()[0], │ │ │ │ │ -90 &stencilTable->GetWeights()[0], │ │ │ │ │ -91 /*start = */ 0, │ │ │ │ │ -92 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ -93 } │ │ │ │ │ -94 │ │ │ │ │ -_1_2_1 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -122 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -123 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -124 const int * sizes, │ │ │ │ │ -125 const int * offsets, │ │ │ │ │ -126 const int * indices, │ │ │ │ │ -127 const float * weights, │ │ │ │ │ -128 int start, int end); │ │ │ │ │ -129 │ │ │ │ │ -167 template │ │ │ │ │ -_1_6_8 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -169 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -170 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -171 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -172 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -173 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -174 const _C_p_u_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ -175 void * deviceContext = NULL) { │ │ │ │ │ -176 │ │ │ │ │ -177 (void)instance; // unused │ │ │ │ │ -178 (void)deviceContext; // unused │ │ │ │ │ -179 │ │ │ │ │ -180 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -181 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -182 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -183 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -184 &stencilTable->GetSizes()[0], │ │ │ │ │ -185 &stencilTable->GetOffsets()[0], │ │ │ │ │ -186 &stencilTable->GetControlIndices()[0], │ │ │ │ │ -187 &stencilTable->GetWeights()[0], │ │ │ │ │ -188 &stencilTable->GetDuWeights()[0], │ │ │ │ │ -189 &stencilTable->GetDvWeights()[0], │ │ │ │ │ -190 /*start = */ 0, │ │ │ │ │ -191 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ -192 } │ │ │ │ │ -193 │ │ │ │ │ -_2_3_4 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -235 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -236 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -237 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -238 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -239 const int * sizes, │ │ │ │ │ -240 const int * offsets, │ │ │ │ │ -241 const int * indices, │ │ │ │ │ -242 const float * weights, │ │ │ │ │ -243 const float * duWeights, │ │ │ │ │ -244 const float * dvWeights, │ │ │ │ │ -245 int start, int end); │ │ │ │ │ -246 │ │ │ │ │ -302 template │ │ │ │ │ -_3_0_3 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -304 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -305 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -306 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -307 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -308 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -309 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -310 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -311 STENCIL_TABLE const *stencilTable, │ │ │ │ │ -312 const _C_p_u_E_v_a_l_u_a_t_o_r *instance = NULL, │ │ │ │ │ -313 void * deviceContext = NULL) { │ │ │ │ │ -314 │ │ │ │ │ -315 (void)instance; // unused │ │ │ │ │ -316 (void)deviceContext; // unused │ │ │ │ │ -317 │ │ │ │ │ -318 return _E_v_a_l_S_t_e_n_c_i_l_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -319 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -320 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -321 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -322 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ -323 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ -324 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ -325 &stencilTable->GetSizes()[0], │ │ │ │ │ -326 &stencilTable->GetOffsets()[0], │ │ │ │ │ -327 &stencilTable->GetControlIndices()[0], │ │ │ │ │ -328 &stencilTable->GetWeights()[0], │ │ │ │ │ -329 &stencilTable->GetDuWeights()[0], │ │ │ │ │ -330 &stencilTable->GetDvWeights()[0], │ │ │ │ │ -331 &stencilTable->GetDuuWeights()[0], │ │ │ │ │ -332 &stencilTable->GetDuvWeights()[0], │ │ │ │ │ -333 &stencilTable->GetDvvWeights()[0], │ │ │ │ │ -334 /*start = */ 0, │ │ │ │ │ -335 /*end = */ stencilTable->GetNumStencils()); │ │ │ │ │ -336 } │ │ │ │ │ -337 │ │ │ │ │ -_3_9_9 static bool _E_v_a_l_S_t_e_n_c_i_l_s( │ │ │ │ │ -400 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -401 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -402 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -403 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -404 float *duu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -405 float *duv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -406 float *dvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -407 const int * sizes, │ │ │ │ │ -408 const int * offsets, │ │ │ │ │ -409 const int * indices, │ │ │ │ │ -410 const float * weights, │ │ │ │ │ -411 const float * duWeights, │ │ │ │ │ -412 const float * dvWeights, │ │ │ │ │ -413 const float * duuWeights, │ │ │ │ │ -414 const float * duvWeights, │ │ │ │ │ -415 const float * dvvWeights, │ │ │ │ │ -416 int start, int end); │ │ │ │ │ -417 │ │ │ │ │ -423 │ │ │ │ │ -452 template │ │ │ │ │ -_4_5_4 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -455 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -456 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -457 int numPatchCoords, │ │ │ │ │ -458 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -459 PATCH_TABLE *patchTable, │ │ │ │ │ -460 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -461 void * deviceContext = NULL) { │ │ │ │ │ -462 │ │ │ │ │ -463 (void)instance; // unused │ │ │ │ │ -464 (void)deviceContext; // unused │ │ │ │ │ -465 │ │ │ │ │ -466 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -467 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -468 numPatchCoords, │ │ │ │ │ -469 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -470 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ -471 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -472 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -473 } │ │ │ │ │ -474 │ │ │ │ │ -515 template │ │ │ │ │ -_5_1_7 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -518 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -519 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -520 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -521 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -522 int numPatchCoords, │ │ │ │ │ -523 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -524 PATCH_TABLE *patchTable, │ │ │ │ │ -525 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -526 void * deviceContext = NULL) { │ │ │ │ │ -527 │ │ │ │ │ -528 (void)instance; // unused │ │ │ │ │ -529 (void)deviceContext; // unused │ │ │ │ │ -530 │ │ │ │ │ -531 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop. │ │ │ │ │ -532 // ideally all buffer classes should have templated by datatype │ │ │ │ │ -533 // so that downcast isn't needed there. │ │ │ │ │ -534 // (e.g. Osd::CpuBuffer ) │ │ │ │ │ -535 // │ │ │ │ │ -536 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -537 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -538 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -539 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -540 numPatchCoords, │ │ │ │ │ -541 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -542 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ -543 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -544 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -545 } │ │ │ │ │ -546 │ │ │ │ │ -605 template │ │ │ │ │ -_6_0_7 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -608 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -609 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -610 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -611 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -612 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -613 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -614 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -615 int numPatchCoords, │ │ │ │ │ -616 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -617 PATCH_TABLE *patchTable, │ │ │ │ │ -618 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -619 void * deviceContext = NULL) { │ │ │ │ │ -620 │ │ │ │ │ -621 (void)instance; // unused │ │ │ │ │ -622 (void)deviceContext; // unused │ │ │ │ │ -623 │ │ │ │ │ -624 // XXX: PatchCoords is somewhat abusing vertex primvar buffer interop. │ │ │ │ │ -625 // ideally all buffer classes should have templated by datatype │ │ │ │ │ -626 // so that downcast isn't needed there. │ │ │ │ │ -627 // (e.g. Osd::CpuBuffer ) │ │ │ │ │ -628 // │ │ │ │ │ -629 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -630 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -631 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -632 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -633 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ -634 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ -635 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ -636 numPatchCoords, │ │ │ │ │ -637 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -638 patchTable->GetPatchArrayBuffer(), │ │ │ │ │ -639 patchTable->GetPatchIndexBuffer(), │ │ │ │ │ -640 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -641 } │ │ │ │ │ -642 │ │ │ │ │ -_6_7_0 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -671 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -672 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -673 int numPatchCoords, │ │ │ │ │ -674 const _P_a_t_c_h_C_o_o_r_d *patchCoords, │ │ │ │ │ -675 const _P_a_t_c_h_A_r_r_a_y *patchArrays, │ │ │ │ │ -676 const int *patchIndexBuffer, │ │ │ │ │ -677 const _P_a_t_c_h_P_a_r_a_m *patchParamBuffer); │ │ │ │ │ -678 │ │ │ │ │ -_7_1_6 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -717 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -718 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -719 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -720 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -721 int numPatchCoords, │ │ │ │ │ -722 _P_a_t_c_h_C_o_o_r_d const *patchCoords, │ │ │ │ │ -723 _P_a_t_c_h_A_r_r_a_y const *patchArrays, │ │ │ │ │ -724 const int *patchIndexBuffer, │ │ │ │ │ -725 _P_a_t_c_h_P_a_r_a_m const *patchParamBuffer); │ │ │ │ │ -726 │ │ │ │ │ -_7_7_9 static bool _E_v_a_l_P_a_t_c_h_e_s( │ │ │ │ │ -780 const float *src, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -781 float *dst, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -782 float *du, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -783 float *dv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -784 float *duu, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -785 float *duv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -786 float *dvv, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -787 int numPatchCoords, │ │ │ │ │ -788 _P_a_t_c_h_C_o_o_r_d const *patchCoords, │ │ │ │ │ -789 _P_a_t_c_h_A_r_r_a_y const *patchArrays, │ │ │ │ │ -790 const int *patchIndexBuffer, │ │ │ │ │ -791 _P_a_t_c_h_P_a_r_a_m const *patchParamBuffer); │ │ │ │ │ -792 │ │ │ │ │ -821 template │ │ │ │ │ -_8_2_3 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -824 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -825 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -826 int numPatchCoords, │ │ │ │ │ -827 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -828 PATCH_TABLE *patchTable, │ │ │ │ │ -829 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -830 void * deviceContext = NULL) { │ │ │ │ │ -831 │ │ │ │ │ -832 (void)instance; // unused │ │ │ │ │ -833 (void)deviceContext; // unused │ │ │ │ │ -834 │ │ │ │ │ -835 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -836 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -837 numPatchCoords, │ │ │ │ │ -838 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -839 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ -840 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -841 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -842 } │ │ │ │ │ -843 │ │ │ │ │ -884 template │ │ │ │ │ -_8_8_6 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -887 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -888 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -889 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -890 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -891 int numPatchCoords, │ │ │ │ │ -892 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -893 PATCH_TABLE *patchTable, │ │ │ │ │ -894 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -895 void * deviceContext = NULL) { │ │ │ │ │ -896 │ │ │ │ │ -897 (void)instance; // unused │ │ │ │ │ -898 (void)deviceContext; // unused │ │ │ │ │ -899 │ │ │ │ │ -900 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -901 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -902 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -903 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -904 numPatchCoords, │ │ │ │ │ -905 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -906 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ -907 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -908 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -909 } │ │ │ │ │ -910 │ │ │ │ │ -969 template │ │ │ │ │ -_9_7_1 static bool _E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g( │ │ │ │ │ -972 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -973 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -974 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -975 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -976 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -977 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -978 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -979 int numPatchCoords, │ │ │ │ │ -980 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -981 PATCH_TABLE *patchTable, │ │ │ │ │ -982 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -983 void * deviceContext = NULL) { │ │ │ │ │ -984 │ │ │ │ │ -985 (void)instance; // unused │ │ │ │ │ -986 (void)deviceContext; // unused │ │ │ │ │ -987 │ │ │ │ │ -988 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -989 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -990 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -991 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -992 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ -993 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ -994 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ -995 numPatchCoords, │ │ │ │ │ -996 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -997 patchTable->GetVaryingPatchArrayBuffer(), │ │ │ │ │ -998 patchTable->GetVaryingPatchIndexBuffer(), │ │ │ │ │ -999 patchTable->GetPatchParamBuffer()); │ │ │ │ │ -1000 } │ │ │ │ │ -1001 │ │ │ │ │ -1032 template │ │ │ │ │ -_1_0_3_4 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1035 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1036 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1037 int numPatchCoords, │ │ │ │ │ -1038 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1039 PATCH_TABLE *patchTable, │ │ │ │ │ -1040 int fvarChannel, │ │ │ │ │ -1041 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -1042 void * deviceContext = NULL) { │ │ │ │ │ -1043 │ │ │ │ │ -1044 (void)instance; // unused │ │ │ │ │ -1045 (void)deviceContext; // unused │ │ │ │ │ -1046 │ │ │ │ │ -1047 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -1048 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -1049 numPatchCoords, │ │ │ │ │ -1050 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -1051 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ -1052 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -1053 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ -1054 } │ │ │ │ │ -1055 │ │ │ │ │ -1098 template │ │ │ │ │ -_1_1_0_0 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1101 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1102 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1103 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1104 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1105 int numPatchCoords, │ │ │ │ │ -1106 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1107 PATCH_TABLE *patchTable, │ │ │ │ │ -1108 int fvarChannel, │ │ │ │ │ -1109 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -1110 void * deviceContext = NULL) { │ │ │ │ │ -1111 │ │ │ │ │ -1112 (void)instance; // unused │ │ │ │ │ -1113 (void)deviceContext; // unused │ │ │ │ │ -1114 │ │ │ │ │ -1115 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -1116 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -1117 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -1118 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -1119 numPatchCoords, │ │ │ │ │ -1120 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -1121 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ -1122 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -1123 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ -1124 } │ │ │ │ │ -1125 │ │ │ │ │ -1186 template │ │ │ │ │ -_1_1_8_8 static bool _E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g( │ │ │ │ │ -1189 SRC_BUFFER *srcBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &srcDesc, │ │ │ │ │ -1190 DST_BUFFER *dstBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dstDesc, │ │ │ │ │ -1191 DST_BUFFER *duBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duDesc, │ │ │ │ │ -1192 DST_BUFFER *dvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvDesc, │ │ │ │ │ -1193 DST_BUFFER *duuBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duuDesc, │ │ │ │ │ -1194 DST_BUFFER *duvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &duvDesc, │ │ │ │ │ -1195 DST_BUFFER *dvvBuffer, _B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &dvvDesc, │ │ │ │ │ -1196 int numPatchCoords, │ │ │ │ │ -1197 PATCHCOORD_BUFFER *patchCoords, │ │ │ │ │ -1198 PATCH_TABLE *patchTable, │ │ │ │ │ -1199 int fvarChannel, │ │ │ │ │ -1200 _C_p_u_E_v_a_l_u_a_t_o_r const *instance = NULL, │ │ │ │ │ -1201 void * deviceContext = NULL) { │ │ │ │ │ -1202 │ │ │ │ │ -1203 (void)instance; // unused │ │ │ │ │ -1204 (void)deviceContext; // unused │ │ │ │ │ -1205 │ │ │ │ │ -1206 return _E_v_a_l_P_a_t_c_h_e_s(srcBuffer->BindCpuBuffer(), srcDesc, │ │ │ │ │ -1207 dstBuffer->BindCpuBuffer(), dstDesc, │ │ │ │ │ -1208 duBuffer->BindCpuBuffer(), duDesc, │ │ │ │ │ -1209 dvBuffer->BindCpuBuffer(), dvDesc, │ │ │ │ │ -1210 duuBuffer->BindCpuBuffer(), duuDesc, │ │ │ │ │ -1211 duvBuffer->BindCpuBuffer(), duvDesc, │ │ │ │ │ -1212 dvvBuffer->BindCpuBuffer(), dvvDesc, │ │ │ │ │ -1213 numPatchCoords, │ │ │ │ │ -1214 (const _P_a_t_c_h_C_o_o_r_d*)patchCoords->BindCpuBuffer(), │ │ │ │ │ -1215 patchTable->GetFVarPatchArrayBuffer(fvarChannel), │ │ │ │ │ -1216 patchTable->GetFVarPatchIndexBuffer(fvarChannel), │ │ │ │ │ -1217 patchTable->GetFVarPatchParamBuffer(fvarChannel)); │ │ │ │ │ -1218 } │ │ │ │ │ -1219 │ │ │ │ │ -1225 │ │ │ │ │ -_1_2_2_7 static void _S_y_n_c_h_r_o_n_i_z_e(void * /*deviceContext = NULL*/) { │ │ │ │ │ -1228 // nothing. │ │ │ │ │ -1229 } │ │ │ │ │ -1230}; │ │ │ │ │ -1231 │ │ │ │ │ -1232 │ │ │ │ │ -1233} // end namespace Osd │ │ │ │ │ -1234 │ │ │ │ │ -1235} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ -1236using namespace OPENSUBDIV_VERSION; │ │ │ │ │ -1237 │ │ │ │ │ -1238} // end namespace OpenSubdiv │ │ │ │ │ -1239 │ │ │ │ │ -1240 │ │ │ │ │ -1241#endif // OPENSUBDIV3_OSD_CPU_EVALUATOR_H │ │ │ │ │ +_8_6 bool _o_p_e_r_a_t_o_r_ _=_=_ (_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &other) const { │ │ │ │ │ +87 return (_o_f_f_s_e_t == other._o_f_f_s_e_t && │ │ │ │ │ +88 _l_e_n_g_t_h == other._l_e_n_g_t_h && │ │ │ │ │ +89 _s_t_r_i_d_e == other._s_t_r_i_d_e); │ │ │ │ │ +90 } │ │ │ │ │ +91 │ │ │ │ │ +_9_3 bool _o_p_e_r_a_t_o_r_ _!_=_ (_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r const &other) const { │ │ │ │ │ +94 return !(this->_o_p_e_r_a_t_o_r_=_=(other)); │ │ │ │ │ +95 } │ │ │ │ │ +96 │ │ │ │ │ +_9_8 int _o_f_f_s_e_t; │ │ │ │ │ +_1_0_0 int _l_e_n_g_t_h; │ │ │ │ │ +_1_0_2 int _s_t_r_i_d_e; │ │ │ │ │ +103}; │ │ │ │ │ +104 │ │ │ │ │ +105} // end namespace Osd │ │ │ │ │ +106 │ │ │ │ │ +107} // end namespace OPENSUBDIV_VERSION │ │ │ │ │ +108using namespace OPENSUBDIV_VERSION; │ │ │ │ │ +109 │ │ │ │ │ +110} // end namespace OpenSubdiv │ │ │ │ │ +111 │ │ │ │ │ +112#endif // OPENSUBDIV3_OSD_BUFFER_DESCRIPTOR_H │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v │ │ │ │ │ DDeeffiinniittiioonn _l_i_m_i_t_s_._h_:_3_2 │ │ │ │ │ _O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ BufferDescriptor is a struct which describes buffer elements in interleaved │ │ │ │ │ data buffers.... │ │ │ │ │ DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_3_9 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ -numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int │ │ │ │ │ -fvarChannel, CpuEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_0_3_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ -DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, int fvarChannel, CpuEvaluator const │ │ │ │ │ -*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_1_0_0 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, const int *sizes, const int │ │ │ │ │ -*offsets, const int *indices, const float *weights, int start, int end) │ │ │ │ │ -Static eval stencils function which takes raw CPU pointers for input and │ │ │ │ │ -output. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_F_a_c_e_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesFaceVarying(SRC_BUFFER *srcBuffer, BufferDescriptor │ │ │ │ │ -const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, │ │ │ │ │ -DST_BUFFER *duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, int fvarChannel, │ │ │ │ │ -CpuEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_1_8_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const │ │ │ │ │ -*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_9_7_1 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ -&duDesc, float *dv, BufferDescriptor const &dvDesc, const int *sizes, const int │ │ │ │ │ -*offsets, const int *indices, const float *weights, const float *duWeights, │ │ │ │ │ -const float *dvWeights, int start, int end) │ │ │ │ │ -Static eval stencils function with derivatives, which takes raw CPU pointers │ │ │ │ │ -for input and output. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ -&duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, │ │ │ │ │ -BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, │ │ │ │ │ -float *dvv, BufferDescriptor const &dvvDesc, const int *sizes, const int │ │ │ │ │ -*offsets, const int *indices, const float *weights, const float *duWeights, │ │ │ │ │ -const float *dvWeights, const float *duuWeights, const float *duvWeights, const │ │ │ │ │ -float *dvvWeights, int start, int end) │ │ │ │ │ -Static eval stencils function with derivatives, which takes raw CPU pointers │ │ │ │ │ -for input and output. │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ -&duDesc, float *dv, BufferDescriptor const &dvDesc, float *duu, │ │ │ │ │ -BufferDescriptor const &duuDesc, float *duv, BufferDescriptor const &duvDesc, │ │ │ │ │ -float *dvv, BufferDescriptor const &dvvDesc, int numPatchCoords, PatchCoord │ │ │ │ │ -const *patchCoords, PatchArray const *patchArrays, const int *patchIndexBuffer, │ │ │ │ │ -PatchParam const *patchParamBuffer) │ │ │ │ │ -Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ -values on given PatchT... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int numPatchCoords, │ │ │ │ │ -PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const │ │ │ │ │ -*instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_4_5_4 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, int numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE │ │ │ │ │ -*patchTable, CpuEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function with derivatives. This function has a same │ │ │ │ │ -signature as other device kern... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_5_1_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, float *du, BufferDescriptor const │ │ │ │ │ -&duDesc, float *dv, BufferDescriptor const &dvDesc, int numPatchCoords, │ │ │ │ │ -PatchCoord const *patchCoords, PatchArray const *patchArrays, const int │ │ │ │ │ -*patchIndexBuffer, PatchParam const *patchParamBuffer) │ │ │ │ │ -Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ -values on given PatchT... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const │ │ │ │ │ -&duuDesc, DST_BUFFER *duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER │ │ │ │ │ -*dvvBuffer, BufferDescriptor const &dvvDesc, STENCIL_TABLE const *stencilTable, │ │ │ │ │ -const CpuEvaluator *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic static eval stencils function with derivatives. This function has a │ │ │ │ │ -same signature as other d... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_3_0_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(const float *src, BufferDescriptor const &srcDesc, │ │ │ │ │ -float *dst, BufferDescriptor const &dstDesc, int numPatchCoords, const │ │ │ │ │ -PatchCoord *patchCoords, const PatchArray *patchArrays, const int │ │ │ │ │ -*patchIndexBuffer, const PatchParam *patchParamBuffer) │ │ │ │ │ -Static limit eval function. It takes an array of PatchCoord and evaluate limit │ │ │ │ │ -values on given PatchT... │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_8_8_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s_V_a_r_y_i_n_g │ │ │ │ │ -static bool EvalPatchesVarying(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, int │ │ │ │ │ -numPatchCoords, PATCHCOORD_BUFFER *patchCoords, PATCH_TABLE *patchTable, │ │ │ │ │ -CpuEvaluator const *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic limit eval function. This function has a same signature as other device │ │ │ │ │ -kernels have so that ... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_8_2_3 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_S_y_n_c_h_r_o_n_i_z_e │ │ │ │ │ -static void Synchronize(void *) │ │ │ │ │ -synchronize all asynchronous computation invoked on this device. │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_2_2_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE │ │ │ │ │ -const *stencilTable, const CpuEvaluator *instance=NULL, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -Generic static eval stencils function. This function has a same signature as │ │ │ │ │ -other device kernels hav... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_7_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_P_a_t_c_h_e_s │ │ │ │ │ -static bool EvalPatches(SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, │ │ │ │ │ -DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER *duBuffer, │ │ │ │ │ -BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, BufferDescriptor const │ │ │ │ │ -&dvDesc, DST_BUFFER *duuBuffer, BufferDescriptor const &duuDesc, DST_BUFFER │ │ │ │ │ -*duvBuffer, BufferDescriptor const &duvDesc, DST_BUFFER *dvvBuffer, │ │ │ │ │ -BufferDescriptor const &dvvDesc, int numPatchCoords, PATCHCOORD_BUFFER │ │ │ │ │ -*patchCoords, PATCH_TABLE *patchTable, CpuEvaluator const *instance=NULL, void │ │ │ │ │ -*deviceContext=NULL) │ │ │ │ │ -Generic limit eval function with derivatives. This function has a same │ │ │ │ │ -signature as other device kern... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_6_0_7 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_C_p_u_E_v_a_l_u_a_t_o_r_:_:_E_v_a_l_S_t_e_n_c_i_l_s │ │ │ │ │ -static bool EvalStencils(SRC_BUFFER *srcBuffer, BufferDescriptor const │ │ │ │ │ -&srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, DST_BUFFER │ │ │ │ │ -*duBuffer, BufferDescriptor const &duDesc, DST_BUFFER *dvBuffer, │ │ │ │ │ -BufferDescriptor const &dvDesc, STENCIL_TABLE const *stencilTable, const │ │ │ │ │ -CpuEvaluator *instance=NULL, void *deviceContext=NULL) │ │ │ │ │ -Generic static eval stencils function with derivatives. This function has a │ │ │ │ │ -same signature as other d... │ │ │ │ │ -DDeeffiinniittiioonn _c_p_u_E_v_a_l_u_a_t_o_r_._h_:_1_6_8 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_C_o_o_r_d │ │ │ │ │ -Coordinates set on a patch table. │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_4_2 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_A_r_r_a_y │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_6_6 │ │ │ │ │ -_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_P_a_t_c_h_P_a_r_a_m │ │ │ │ │ -DDeeffiinniittiioonn _t_y_p_e_s_._h_:_1_2_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_s_t_r_i_d_e │ │ │ │ │ +int stride │ │ │ │ │ +stride to the next element │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_1_0_2 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_R_e_s_e_t │ │ │ │ │ +void Reset() │ │ │ │ │ +Resets the descriptor to default. │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_8_1 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +BufferDescriptor() │ │ │ │ │ +Default Constructor. │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_4 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r │ │ │ │ │ +BufferDescriptor(int o, int l, int s) │ │ │ │ │ +Constructor. │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_6_7 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_l_e_n_g_t_h │ │ │ │ │ +int length │ │ │ │ │ +number or length of the data │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_1_0_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_o_p_e_r_a_t_o_r_!_= │ │ │ │ │ +bool operator!=(BufferDescriptor const &other) const │ │ │ │ │ +True if the descriptors are not identical. │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_9_3 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_o_p_e_r_a_t_o_r_=_= │ │ │ │ │ +bool operator==(BufferDescriptor const &other) const │ │ │ │ │ +True if the descriptors are identical. │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_8_6 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_I_s_V_a_l_i_d │ │ │ │ │ +bool IsValid() const │ │ │ │ │ +True if the descriptor values are internally consistent. │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_7_5 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_G_e_t_L_o_c_a_l_O_f_f_s_e_t │ │ │ │ │ +int GetLocalOffset() const │ │ │ │ │ +Returns the relative offset within a stride. │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_7_0 │ │ │ │ │ +_O_p_e_n_S_u_b_d_i_v_:_:_O_P_E_N_S_U_B_D_I_V___V_E_R_S_I_O_N_:_:_O_s_d_:_:_B_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_:_:_o_f_f_s_e_t │ │ │ │ │ +int offset │ │ │ │ │ +offset to desired element data │ │ │ │ │ +DDeeffiinniittiioonn _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h_:_9_8 │ │ │ │ │ * _o_p_e_n_s_u_b_d_i_v │ │ │ │ │ * _o_s_d │ │ │ │ │ - * _c_p_u_E_v_a_l_u_a_t_o_r_._h │ │ │ │ │ + * _b_u_f_f_e_r_D_e_s_c_r_i_p_t_o_r_._h │ │ │ │ │ * Generated on Thu Jan 2 2025 08:47:46 for OpenSubdiv by _[_d_o_x_y_g_e_n_]1.9.8 │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00902_source.html │ │ │ │ @@ -170,15 +170,15 @@ │ │ │ │
82
│ │ │ │
83} // end namespace OPENSUBDIV_VERSION
│ │ │ │
84using namespace OPENSUBDIV_VERSION;
│ │ │ │
85
│ │ │ │
86} // end namespace OpenSubdiv
│ │ │ │
87
│ │ │ │
88#endif // OPENSUBDIV3_OSD_CUDA_VERTEX_BUFFER_H
│ │ │ │ - │ │ │ │ + │ │ │ │
Concrete vertex buffer class for Cuda subdivision.
│ │ │ │ │ │ │ │ │ │ │ │
int GetNumElements() const
Returns how many elements defined in this vertex buffer.
│ │ │ │
void UpdateData(const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
│ │ │ │
int GetNumVertices() const
Returns how many vertices allocated in this vertex buffer.
│ │ │ │
static CudaVertexBuffer * Create(int numElements, int numVertices, void *deviceContext=NULL)
Creator. Returns NULL if error.
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00912.html │ │ │ │ @@ -342,15 +342,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
typedef MeshInterface<MTLPatchTable> MTLMeshInterface
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 38 of file mtlMesh.h.

│ │ │ │ +

Definition at line 38 of file mtlMesh.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ PatchArrayVector

│ │ │ │ │ │ │ │
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/a00917.html │ │ │ │ @@ -97,29 +97,29 @@ │ │ │ │
Limits Struct Reference
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

Simple struct with limits related to topology. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <limits.h>

│ │ │ │ +

#include <limits.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Static Public Member Functions

static int MaxValence ()
 Returns the maximum allowable valence for a vertex.
 
static int MaxFaceSize ()
 Returns the maximum allowable size for a face (number of vertices)
 
│ │ │ │

Detailed Description

│ │ │ │

Simple struct with limits related to topology.

│ │ │ │ │ │ │ │ -

Definition at line 40 of file limits.h.

│ │ │ │ +

Definition at line 40 of file limits.h.

│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ MaxFaceSize()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -138,15 +138,15 @@ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

Returns the maximum allowable size for a face (number of vertices)

│ │ │ │ │ │ │ │ -

Definition at line 46 of file limits.h.

│ │ │ │ +

Definition at line 46 of file limits.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ MaxValence()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -167,20 +167,20 @@ │ │ │ │ inlinestatic

│ │ │ │
│ │ │ │ │ │ │ │

Returns the maximum allowable valence for a vertex.

│ │ │ │ │ │ │ │ -

Definition at line 42 of file limits.h.

│ │ │ │ +

Definition at line 42 of file limits.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this struct was generated from the following file:
    │ │ │ │ -
  • opensubdiv/bfr/limits.h
  • │ │ │ │ +
  • opensubdiv/bfr/limits.h
  • │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Simple class defining the 2D parameterization of a face. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <parameterization.h>

│ │ │ │ +

#include <parameterization.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Types

enum  Type {
│ │ │ │   QUAD │ │ │ │ ,
│ │ │ │   TRI │ │ │ │ @@ -192,15 +192,15 @@ │ │ │ │
 
│ │ │ │

Detailed Description

│ │ │ │

Simple class defining the 2D parameterization of a face.

│ │ │ │

Parameterization is a simple class that provides information about the parameterization of a face in a local (u,v) coordinate system. It is defined by the size of a face (i.e. its number of vertices) and the subdivision scheme that determines its limit surface.

│ │ │ │

As an example of how the subdivision scheme is essential in determining the Parameterization, consider the case of a triangle. A triangle is regular for the Loop scheme and so has a very simple parameterization as a triangular patch. But for the Catmull-Clark scheme, a triangle is an irregular face that must first be subdivided – making its limit surface a piecewise collection of quadrilateral patches.

│ │ │ │ │ │ │ │ -

Definition at line 52 of file parameterization.h.

│ │ │ │ +

Definition at line 52 of file parameterization.h.

│ │ │ │

Member Enumeration Documentation

│ │ │ │ │ │ │ │

◆ Type

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -217,15 +217,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
TRI 

Triangle.

│ │ │ │
QUAD_SUBFACES 

Partitioned into quadrilateral sub-faces.

│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 62 of file parameterization.h.

│ │ │ │ +

Definition at line 62 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Parameterization() [1/3]

│ │ │ │ │ │ │ │ @@ -277,15 +277,15 @@ │ │ │ │ inline

│ │ │ │
│ │ │ │ │ │ │ │

Default construction produces an invalid instance.

│ │ │ │ │ │ │ │ -

Definition at line 84 of file parameterization.h.

│ │ │ │ +

Definition at line 84 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Parameterization() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -371,15 +371,15 @@ │ │ │ │ inline
│ │ │ │
│ │ │ │ │ │ │ │

Convert (u,v) to a sub-face (return value) and its normalized (u,v) coordinate.

│ │ │ │ │ │ │ │ -

Definition at line 229 of file parameterization.h.

│ │ │ │ +

Definition at line 229 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ConvertCoordToSubFace()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -413,15 +413,15 @@ │ │ │ │ inline

│ │ │ │
│ │ │ │ │ │ │ │

Convert (u,v) to a sub-face (return value) and its local (u,v) coordinate.

│ │ │ │ │ │ │ │ -

Definition at line 215 of file parameterization.h.

│ │ │ │ +

Definition at line 215 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ConvertNormalizedSubFaceToCoord()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -461,15 +461,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Convert a sub-face and its normalized (u,v) coordinate to (u,v)

│ │ │ │ │ │ │ │ -

Definition at line 235 of file parameterization.h.

│ │ │ │ +

Definition at line 235 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ConvertSubFaceToCoord()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -509,15 +509,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Convert a sub-face and its local (u,v) coordinate to (u,v)

│ │ │ │ │ │ │ │ -

Definition at line 221 of file parameterization.h.

│ │ │ │ +

Definition at line 221 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetCenterCoord()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -598,15 +598,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the size (number of vertices) of the corresponding face.

│ │ │ │ │ │ │ │ -

Definition at line 101 of file parameterization.h.

│ │ │ │ +

Definition at line 101 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetSubFace()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -630,15 +630,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the integer sub-face containing the given (u,v)

│ │ │ │ │ │ │ │ -

Definition at line 202 of file parameterization.h.

│ │ │ │ +

Definition at line 202 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetType()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -659,15 +659,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the type of parameterization assigned.

│ │ │ │ │ │ │ │ -

Definition at line 98 of file parameterization.h.

│ │ │ │ +

Definition at line 98 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexCoord()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -720,15 +720,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns if Parameterization has been partitioned into sub-faces.

│ │ │ │ │ │ │ │ -

Definition at line 196 of file parameterization.h.

│ │ │ │ +

Definition at line 196 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsValid()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -749,15 +749,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns true if correctly initialized.

│ │ │ │ │ │ │ │ -

Definition at line 81 of file parameterization.h.

│ │ │ │ +

Definition at line 81 of file parameterization.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ operator=()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -780,15 +780,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Intermediate subclass of SurfaceFactory with Far::TopologyRefiner as the mesh. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <refinerSurfaceFactory.h>

│ │ │ │ +

#include <refinerSurfaceFactory.h>

│ │ │ │
│ │ │ │ Inheritance diagram for RefinerSurfaceFactoryBase:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ SurfaceFactory │ │ │ │ @@ -236,15 +236,15 @@ │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Intermediate subclass of SurfaceFactory with Far::TopologyRefiner as the mesh.

│ │ │ │

RefinerSurfaceFactoryBase is an intermediate subclass of SurfaceFactory using Far::TopologyRefiner as the connected mesh representation.

│ │ │ │

The SurfaceFactoryMeshAdapter interface for TopologyRefiner is provided in full, along with some public extensions specific to TopologyRefiner.

│ │ │ │

Additional caching expectations of SurfaceFactory are NOT specified here. These are deferred to subclasses to implement different behaviors of the factory's internal caching. A template for such subclasses is additionally provided – allowing clients desiring a thread-safe cache to simply declare a subclass for a preferred thread-safe type.

│ │ │ │ │ │ │ │ -

Definition at line 58 of file refinerSurfaceFactory.h.

│ │ │ │ +

Definition at line 58 of file refinerSurfaceFactory.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ RefinerSurfaceFactoryBase()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -317,15 +317,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

Return the instance of the mesh.

│ │ │ │ │ │ │ │ -

Definition at line 79 of file refinerSurfaceFactory.h.

│ │ │ │ +

Definition at line 79 of file refinerSurfaceFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetNumFaces()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -346,15 +346,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the number of faces.

│ │ │ │ │ │ │ │ -

Definition at line 82 of file refinerSurfaceFactory.h.

│ │ │ │ +

Definition at line 82 of file refinerSurfaceFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetNumFVarChannels()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -375,20 +375,20 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the number of face-varying channels.

│ │ │ │ │ │ │ │ -

Definition at line 85 of file refinerSurfaceFactory.h.

│ │ │ │ +

Definition at line 85 of file refinerSurfaceFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Template for concrete subclasses of RefinerSurfaceFactoryBase. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <refinerSurfaceFactory.h>

│ │ │ │ +

#include <refinerSurfaceFactory.h>

│ │ │ │
│ │ │ │ Inheritance diagram for RefinerSurfaceFactory< CACHE_TYPE >:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ RefinerSurfaceFactoryBase │ │ │ │ @@ -241,15 +241,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
CACHE_TYPEA subclass of SurfaceFactoryCache
│ │ │ │ │ │ │ │ │ │ │ │

Note a default template parameter uses the base SurfaceFactoryCache for convenience, but which is not thread-safe.

│ │ │ │ │ │ │ │ -

Definition at line 157 of file refinerSurfaceFactory.h.

│ │ │ │ +

Definition at line 157 of file refinerSurfaceFactory.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ RefinerSurfaceFactory()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -279,15 +279,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 159 of file refinerSurfaceFactory.h.

│ │ │ │ +

Definition at line 159 of file refinerSurfaceFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ ~RefinerSurfaceFactory()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -311,15 +311,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Encapsulates the limit surface for a face of a mesh. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <surface.h>

│ │ │ │ +

#include <surface.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Classes

struct  PointDescriptor
 Simple struct defining the size and stride of points in arrays. More...
 
│ │ │ │ @@ -228,15 +228,15 @@ │ │ │ │ │ │ │ │
REALFloating point precision (float or double only)
│ │ │ │ │ │ │ │ │ │ │ │

Instances of Surface are created or initialized by a subclass of the SurfaceFactory. Since existing instances can be re-initialized, they should be tested for validity after such re-initialization.

│ │ │ │

All Surfaces are assigned a Parameterization based on the subdivision scheme and the size of the face, which can then be used for evaluation and tessellation of the surface.

│ │ │ │ │ │ │ │ -

Definition at line 59 of file surface.h.

│ │ │ │ +

Definition at line 59 of file surface.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ Index

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -246,15 +246,15 @@ │ │ │ │ typedef int Index │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Integer type representing a mesh index.

│ │ │ │ │ │ │ │ -

Definition at line 72 of file surface.h.

│ │ │ │ +

Definition at line 72 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Surface() [1/2]

│ │ │ │ │ │ │ │ @@ -531,15 +531,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Clear a previously initialized Surface.

│ │ │ │ │ │ │ │ -

Definition at line 89 of file surface.h.

│ │ │ │ +

Definition at line 89 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ComputePatchPoints()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -581,15 +581,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
patchPointsArray of patch point data to be modified
patchPointDescThe size and stride of patch point data
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 331 of file surface.h.

│ │ │ │ +

Definition at line 331 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Evaluate() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -635,15 +635,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Evaluation of position.

│ │ │ │ │ │ │ │ -

Definition at line 372 of file surface.h.

│ │ │ │ +

Definition at line 372 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Evaluate() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -701,15 +701,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Overload of evaluation for 1st derivatives.

│ │ │ │ │ │ │ │ -

Definition at line 382 of file surface.h.

│ │ │ │ +

Definition at line 382 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Evaluate() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -785,15 +785,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Overload of evaluation for 2nd derivatives.

│ │ │ │ │ │ │ │ -

Definition at line 392 of file surface.h.

│ │ │ │ +

Definition at line 392 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvaluateStencil() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -827,15 +827,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Evaluation of the limit stencil for position.

│ │ │ │ │ │ │ │ -

Definition at line 416 of file surface.h.

│ │ │ │ +

Definition at line 416 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvaluateStencil() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -881,15 +881,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Overload of limit stencil evaluation for 1st derivatives.

│ │ │ │ │ │ │ │ -

Definition at line 423 of file surface.h.

│ │ │ │ +

Definition at line 423 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvaluateStencil() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -953,15 +953,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Overload of limit stencil evaluation for 2nd derivatives.

│ │ │ │ │ │ │ │ -

Definition at line 431 of file surface.h.

│ │ │ │ +

Definition at line 431 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GatherControlPoints()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1067,15 +1067,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the size of the face.

│ │ │ │ │ │ │ │ -

Definition at line 109 of file surface.h.

│ │ │ │ +

Definition at line 109 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumControlPoints()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1098,15 +1098,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the number of control points affecting the Surface.

│ │ │ │ │ │ │ │ -

Definition at line 137 of file surface.h.

│ │ │ │ +

Definition at line 137 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumPatchPoints()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1150,15 +1150,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the Parameterization.

│ │ │ │ │ │ │ │ -

Definition at line 106 of file surface.h.

│ │ │ │ +

Definition at line 106 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsLinear()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1181,15 +1181,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the Surface is linear.

│ │ │ │ │ │ │ │ -

Definition at line 115 of file surface.h.

│ │ │ │ +

Definition at line 115 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsRegular()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1212,15 +1212,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the Surface is a single regular patch.

│ │ │ │ │ │ │ │ -

Definition at line 112 of file surface.h.

│ │ │ │ +

Definition at line 112 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsValid()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1243,15 +1243,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return true if successfully initialized.

│ │ │ │ │ │ │ │ -

Definition at line 86 of file surface.h.

│ │ │ │ +

Definition at line 86 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ operator=()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1336,15 +1336,15 @@ │ │ │ │ patchPointsOutput array of patch point data │ │ │ │ patchPointDescThe size and stride of patch point data │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

Note that this method requires the mesh data be in a contiguous array. If a large data set is fragmented into blocks or pages, this method cannot be used. The control points will need to be gathered explicitly as the subset of patch points, after which the method to compute the remaining patch points can be used.

│ │ │ │ │ │ │ │ -

Definition at line 345 of file surface.h.

│ │ │ │ +

Definition at line 345 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Friends And Related Symbol Documentation

│ │ │ │ │ │ │ │

◆ SurfaceFactory

│ │ │ │ │ │ │ │ @@ -1363,20 +1363,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 315 of file surface.h.

│ │ │ │ +

Definition at line 315 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file:
    │ │ │ │ -
  • opensubdiv/bfr/surface.h
  • │ │ │ │ +
  • opensubdiv/bfr/surface.h
  • │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Simple struct defining the size and stride of points in arrays. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <surface.h>

│ │ │ │ +

#include <surface.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -120,15 +120,15 @@ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 PointDescriptor ()
 
 PointDescriptor (int n)
 
int stride
 
│ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ struct OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface< REAL >::PointDescriptor

Simple struct defining the size and stride of points in arrays.

│ │ │ │ │ │ │ │ -

Definition at line 63 of file surface.h.

│ │ │ │ +

Definition at line 63 of file surface.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ PointDescriptor() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -147,15 +147,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 64 of file surface.h.

│ │ │ │ +

Definition at line 64 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ PointDescriptor() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -177,15 +177,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 65 of file surface.h.

│ │ │ │ +

Definition at line 65 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ PointDescriptor() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -217,15 +217,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 66 of file surface.h.

│ │ │ │ +

Definition at line 66 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ size

│ │ │ │ │ │ │ │ @@ -236,15 +236,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
int size
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 68 of file surface.h.

│ │ │ │ +

Definition at line 68 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ stride

│ │ │ │ │ │ │ │
│ │ │ │ @@ -254,20 +254,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
int stride
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 68 of file surface.h.

│ │ │ │ +

Definition at line 68 of file surface.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file:
    │ │ │ │ -
  • opensubdiv/bfr/surface.h
  • │ │ │ │ +
  • opensubdiv/bfr/surface.h
  • │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Container used internally by SurfaceFactory to store reusable information. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <surfaceFactoryCache.h>

│ │ │ │ +

#include <surfaceFactoryCache.h>

│ │ │ │
│ │ │ │ Inheritance diagram for SurfaceFactoryCache:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ SurfaceFactoryCacheThreaded< MUTEX_TYPE, READ_LOCK_GUARD_TYPE, WRITE_LOCK_GUARD_TYPE > │ │ │ │ @@ -124,15 +124,15 @@ │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Container used internally by SurfaceFactory to store reusable information.

│ │ │ │

SurfaceFactoryCache is a container for storing/caching instances of the internal representation of complex patches used by SurfaceFactory so that they can be quickly identified and retrieved for reuse.

│ │ │ │

It is intended for internal use by SurfaceFactory. Public access is available but limited to construction only – allowing an instance to be reused by assigning it to more than one SurfaceFactory.

│ │ │ │ │ │ │ │ -

Definition at line 59 of file surfaceFactoryCache.h.

│ │ │ │ +

Definition at line 59 of file surfaceFactoryCache.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ SurfaceFactoryCache() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -222,15 +222,15 @@ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Template for declaring thread-safe subclasses of SurfaceFactoryCache. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <surfaceFactoryCache.h>

│ │ │ │ +

#include <surfaceFactoryCache.h>

│ │ │ │
│ │ │ │ Inheritance diagram for SurfaceFactoryCacheThreaded< MUTEX_TYPE, READ_LOCK_GUARD_TYPE, WRITE_LOCK_GUARD_TYPE >:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ SurfaceFactoryCache │ │ │ │ @@ -137,15 +137,15 @@ │ │ │ │ MUTEX_TYPEA mutex type with supported lock guards │ │ │ │ READ_LOCK_GUARD_TYPEA scoped lock guard allowing potentially shared access for read operations. │ │ │ │ WRITE_LOCK_GUARD_TYPEA scoped lock guard allowing exclusive access for write operations. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 118 of file surfaceFactoryCache.h.

│ │ │ │ +

Definition at line 118 of file surfaceFactoryCache.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ SurfaceFactoryCacheThreaded()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -164,15 +164,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 120 of file surfaceFactoryCache.h.

│ │ │ │ +

Definition at line 120 of file surfaceFactoryCache.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ ~SurfaceFactoryCacheThreaded()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -196,15 +196,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Abstract interface adapting SurfaceFactory to a connected mesh representation. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <surfaceFactoryMeshAdapter.h>

│ │ │ │ +

#include <surfaceFactoryMeshAdapter.h>

│ │ │ │
│ │ │ │ Inheritance diagram for SurfaceFactoryMeshAdapter:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ SurfaceFactory │ │ │ │ @@ -171,15 +171,15 @@ │ │ │ │   │ │ │ │ virtual bool getFaceNeighborhoodFVarValueIndicesIfRegular (Index faceIndex, FVarID fvarID, Index fvarValueIndices[]) const │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Abstract interface adapting SurfaceFactory to a connected mesh representation.

│ │ │ │ │ │ │ │ -

Definition at line 65 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ +

Definition at line 65 of file surfaceFactoryMeshAdapter.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ FVarID

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -189,15 +189,15 @@ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

Type used to identify and specify face-varying primvars.

│ │ │ │

A face-varying ID is used to specify face-varying primvars for evaluation so that they can be identified by the subclass for the mesh. It can be assigned as either a positive integer ID or pointer, with the subclass determining its interpretation.

│ │ │ │

Often only one face-varying primvar is of interest, so a default can be assigned to the factory to avoid repeated specification.

│ │ │ │ │ │ │ │ -

Definition at line 80 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ +

Definition at line 80 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Index

│ │ │ │ │ │ │ │
│ │ │ │ @@ -207,15 +207,15 @@ │ │ │ │ typedef int Index │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Integer type representing a mesh index.

│ │ │ │ │ │ │ │ -

Definition at line 68 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ +

Definition at line 68 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ getFaceFVarValueIndices()

│ │ │ │ │ │ │ │ @@ -296,15 +296,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotectedvirtual │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 224 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ +

Definition at line 224 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ getFaceNeighborhoodVertexIndicesIfRegular()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -334,15 +334,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotectedvirtual │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 218 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ +

Definition at line 218 of file surfaceFactoryMeshAdapter.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ getFaceSize()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -571,15 +571,15 @@ │ │ │ │
│ │ │ │ │ │ │ │

Describe the topology of incident faces around a face-vertex.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Factory for constructing a PatchTable from a TopologyRefiner. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <patchTableFactory.h>

│ │ │ │ +

#include <patchTableFactory.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -124,29 +124,29 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Classes

struct  Options
 Public options for the PatchTable factory. More...
 
struct  PatchFaceTag
static PatchTableCreate (TopologyRefiner const &refiner, Options options=Options(), ConstIndexArray selectedFaces=ConstIndexArray())
 Instantiates a PatchTable from a client-provided TopologyRefiner.
 
│ │ │ │

Detailed Description

│ │ │ │

Factory for constructing a PatchTable from a TopologyRefiner.

│ │ │ │ │ │ │ │ -

Definition at line 40 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 40 of file patchTableFactory.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ PatchTagVector

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
typedef std::vector<PatchFaceTag> PatchTagVector
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 208 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 208 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ Create()

│ │ │ │ │ │ │ │ @@ -200,15 +200,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
Returns
A new instance of PatchTable
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Public options for the PatchTable factory. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <patchTableFactory.h>

│ │ │ │ +

#include <patchTableFactory.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Types

enum  EndCapType {
│ │ │ │   ENDCAP_NONE = 0 │ │ │ │ ,
│ │ │ │   ENDCAP_BILINEAR_BASIS │ │ │ │ @@ -208,15 +208,15 @@ │ │ │ │
int const * fvarChannelIndices
 List containing the indices of the channels selected for the factory.
 
│ │ │ │

Detailed Description

│ │ │ │

Public options for the PatchTable factory.

│ │ │ │ │ │ │ │ -

Definition at line 45 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 45 of file patchTableFactory.h.

│ │ │ │

Member Enumeration Documentation

│ │ │ │ │ │ │ │

◆ EndCapType

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -237,15 +237,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
ENDCAP_GREGORY_BASIS 

use Gregory patches (highest quality, recommended default)

│ │ │ │
ENDCAP_LEGACY_GREGORY 

legacy option for 2.x style Gregory patches (Catmark only)

│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 55 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 55 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Options()

│ │ │ │ │ │ │ │ @@ -266,15 +266,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 63 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 63 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetEndCapType()

│ │ │ │ │ │ │ │ @@ -296,15 +296,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Get endcap basis type.

│ │ │ │ │ │ │ │ -

Definition at line 85 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 85 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetRefineAdaptiveOptions()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -325,15 +325,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Determine adaptive refinement options to match assigned patch options.

│ │ │ │ │ │ │ │ -

Definition at line 100 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 100 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetEndCapType()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -355,15 +355,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set endcap basis type.

│ │ │ │ │ │ │ │ -

Definition at line 88 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 88 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetFVarPatchPrecision() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -403,15 +403,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 215 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 215 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetMaxIsolationLevel()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -433,15 +433,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set maximum isolation level.

│ │ │ │ │ │ │ │ -

Definition at line 91 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 91 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetPatchPrecision() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -481,15 +481,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 212 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 212 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ endCapType

│ │ │ │ │ │ │ │ @@ -500,15 +500,15 @@ │ │ │ │ unsigned int endCapType │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

EndCapType.

│ │ │ │ │ │ │ │ -

Definition at line 120 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 120 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ fvarChannelIndices

│ │ │ │ │ │ │ │
│ │ │ │ @@ -518,15 +518,15 @@ │ │ │ │ int const* fvarChannelIndices │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

List containing the indices of the channels selected for the factory.

│ │ │ │ │ │ │ │ -

Definition at line 140 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 140 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ fvarPatchPrecisionDouble

│ │ │ │ │ │ │ │
│ │ │ │ @@ -536,15 +536,15 @@ │ │ │ │ unsigned int fvarPatchPrecisionDouble │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate double-precision stencils for face-varying patches.

│ │ │ │ │ │ │ │ -

Definition at line 133 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 133 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateAllLevels

│ │ │ │ │ │ │ │
│ │ │ │ @@ -554,15 +554,15 @@ │ │ │ │ unsigned int generateAllLevels │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate levels from 'firstLevel' to 'maxLevel' (Uniform mode only)

│ │ │ │ │ │ │ │ -

Definition at line 110 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 110 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateFVarLegacyLinearPatches

│ │ │ │ │ │ │ │
│ │ │ │ @@ -572,15 +572,15 @@ │ │ │ │ unsigned int generateFVarLegacyLinearPatches │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate all linear face-varying patches (legacy)

│ │ │ │ │ │ │ │ -

Definition at line 136 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 136 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateFVarTables

│ │ │ │ │ │ │ │
│ │ │ │ @@ -590,15 +590,15 @@ │ │ │ │ unsigned int generateFVarTables │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate face-varying patch tables.

│ │ │ │ │ │ │ │ -

Definition at line 129 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 129 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateLegacySharpCornerPatches

│ │ │ │ │ │ │ │
│ │ │ │ @@ -608,15 +608,15 @@ │ │ │ │ unsigned int generateLegacySharpCornerPatches │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate sharp regular patches at smooth corners (legacy)

│ │ │ │ │ │ │ │ -

Definition at line 137 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 137 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateVaryingLocalPoints

│ │ │ │ │ │ │ │
│ │ │ │ @@ -626,15 +626,15 @@ │ │ │ │ unsigned int generateVaryingLocalPoints │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate local points with varying patches.

│ │ │ │ │ │ │ │ -

Definition at line 126 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 126 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateVaryingTables

│ │ │ │ │ │ │ │
│ │ │ │ @@ -644,15 +644,15 @@ │ │ │ │ unsigned int generateVaryingTables │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate varying patch tables.

│ │ │ │ │ │ │ │ -

Definition at line 125 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 125 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ includeBaseLevelIndices

│ │ │ │ │ │ │ │
│ │ │ │ @@ -662,15 +662,15 @@ │ │ │ │ unsigned int includeBaseLevelIndices │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Include base level in patch point indices (Uniform mode only)

│ │ │ │ │ │ │ │ -

Definition at line 111 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 111 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ includeFVarBaseLevelIndices

│ │ │ │ │ │ │ │
│ │ │ │ @@ -680,15 +680,15 @@ │ │ │ │ unsigned int includeFVarBaseLevelIndices │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Include base level in face-varying patch point indices (Uniform mode only)

│ │ │ │ │ │ │ │ -

Definition at line 112 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 112 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ maxIsolationLevel

│ │ │ │ │ │ │ │
│ │ │ │ @@ -698,15 +698,15 @@ │ │ │ │ unsigned int maxIsolationLevel │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Cap adaptive feature isolation to the given level (max. 10)

│ │ │ │ │ │ │ │ -

Definition at line 117 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 117 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ numFVarChannels

│ │ │ │ │ │ │ │
│ │ │ │ @@ -716,15 +716,15 @@ │ │ │ │ int numFVarChannels │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Number of channel indices and interpolation modes passed.

│ │ │ │ │ │ │ │ -

Definition at line 139 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 139 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ patchPrecisionDouble

│ │ │ │ │ │ │ │
│ │ │ │ @@ -734,15 +734,15 @@ │ │ │ │ unsigned int patchPrecisionDouble │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate double-precision stencils for vertex patches.

│ │ │ │ │ │ │ │ -

Definition at line 132 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 132 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ shareEndCapPatchPoints

│ │ │ │ │ │ │ │
│ │ │ │ @@ -751,15 +751,15 @@ │ │ │ │ │ │ │ │ unsigned int shareEndCapPatchPoints │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Share endcap patch points among adjacent endcap patches. currently only work with GregoryBasis.

│ │ │ │ │ │ │ │ -

Definition at line 121 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 121 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ triangulateQuads

│ │ │ │ │ │ │ │
│ │ │ │ @@ -769,15 +769,15 @@ │ │ │ │ unsigned int triangulateQuads │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Triangulate 'QUADS' primitives (Uniform mode only)

│ │ │ │ │ │ │ │ -

Definition at line 113 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 113 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ useInfSharpPatch

│ │ │ │ │ │ │ │
│ │ │ │ @@ -787,15 +787,15 @@ │ │ │ │ unsigned int useInfSharpPatch │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Use infinitely-sharp patch.

│ │ │ │ │ │ │ │ -

Definition at line 116 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 116 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ useSingleCreasePatch

│ │ │ │ │ │ │ │
│ │ │ │ @@ -805,20 +805,20 @@ │ │ │ │ unsigned int useSingleCreasePatch │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Use single crease patch.

│ │ │ │ │ │ │ │ -

Definition at line 115 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 115 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Obsolete internal struct not intended for public use – due to be deprecated. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <patchTableFactory.h>

│ │ │ │ +

#include <patchTableFactory.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -133,15 +133,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

void clear ()
 
void assignBoundaryPropertiesFromEdgeMask (int boundaryEdgeMask)
 
 
unsigned int _isSingleCrease: 1
 
│ │ │ │

Detailed Description

│ │ │ │

Obsolete internal struct not intended for public use – due to be deprecated.

│ │ │ │ │ │ │ │ -

Definition at line 192 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 192 of file patchTableFactory.h.

│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ assignBoundaryPropertiesFromEdgeMask()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -219,15 +219,15 @@ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
unsigned int _boundaryCount
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 199 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 199 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ _boundaryIndex

│ │ │ │ │ │ │ │
│ │ │ │ @@ -235,15 +235,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
unsigned int _boundaryIndex
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 198 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 198 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ _boundaryMask

│ │ │ │ │ │ │ │
│ │ │ │ @@ -251,15 +251,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
unsigned int _boundaryMask
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 197 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 197 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _hasBoundaryEdge

│ │ │ │ │ │ │ │
│ │ │ │ @@ -267,15 +267,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
unsigned int _hasBoundaryEdge
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 200 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 200 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _hasPatch

│ │ │ │ │ │ │ │
│ │ │ │ @@ -283,15 +283,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
unsigned int _hasPatch
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 194 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 194 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _isRegular

│ │ │ │ │ │ │ │
│ │ │ │ @@ -299,15 +299,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
unsigned int _isRegular
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 195 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 195 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _isSingleCrease

│ │ │ │ │ │ │ │
│ │ │ │ @@ -315,15 +315,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
unsigned int _isSingleCrease
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 201 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 201 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _transitionMask

│ │ │ │ │ │ │ │
│ │ │ │ @@ -331,20 +331,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
unsigned int _transitionMask
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 196 of file patchTableFactory.h.

│ │ │ │ +

Definition at line 196 of file patchTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Applies refinement operations to generic primvar data. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <primvarRefiner.h>

│ │ │ │ +

#include <primvarRefiner.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -159,15 +159,15 @@ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 PrimvarRefinerReal (TopologyRefiner const &refiner)
 
 ~PrimvarRefinerReal ()
 
void LimitFaceVarying (T const &src, U &dst, int channel=0) const
 
│ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Far::PrimvarRefinerReal< REAL >

Applies refinement operations to generic primvar data.

│ │ │ │ │ │ │ │ -

Definition at line 56 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 56 of file primvarRefiner.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ PrimvarRefinerReal()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -187,15 +187,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 59 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 59 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ ~PrimvarRefinerReal()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -216,15 +216,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 60 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 60 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetTopologyRefiner()

│ │ │ │ │ │ │ │ @@ -246,15 +246,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 62 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 62 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Interpolate()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -305,15 +305,15 @@ │ │ │ │ levelThe refinement level │ │ │ │ srcSource primvar buffer (templating control vertex data) │ │ │ │ dstDestination primvar buffer (templating refined vertex data) │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 267 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 267 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ InterpolateFaceUniform()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -365,15 +365,15 @@ │ │ │ │ levelThe refinement level │ │ │ │ srcSource primvar buffer │ │ │ │ dstDestination primvar buffer │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 394 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 394 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ InterpolateFaceVarying()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -423,15 +423,15 @@ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Apply face-varying interpolation weights to a primvar buffer associated with a particular face-varying channel.

│ │ │ │

Unlike vertex and varying primvar buffers, there is not a 1-to-1 correspondence between vertices and face-varying values – typically there are more face-varying values than vertices. Each face-varying channel is also independent in how its values relate to the vertices.

│ │ │ │

The destination buffer must allocate an array of data for all the refined values, i.e. at least refiner.GetLevel(level).GetNumFVarValues(channel).

│ │ │ │ │ │ │ │ -

Definition at line 293 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 293 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ InterpolateVarying()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -483,15 +483,15 @@ │ │ │ │ levelThe refinement level │ │ │ │ srcSource primvar buffer (templating control vertex data) │ │ │ │ dstDestination primvar buffer (templating refined vertex data) │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 412 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 412 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Limit() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -535,15 +535,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
srcSource primvar buffer (refined data) for last level
dstPosDestination primvar buffer (data at the limit)
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 319 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 319 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Limit() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -589,15 +589,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 344 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 344 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ LimitFaceVarying()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -637,20 +637,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 369 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 369 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <primvarRefiner.h>

│ │ │ │ +

#include <primvarRefiner.h>

│ │ │ │
│ │ │ │ Inheritance diagram for PrimvarRefiner:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ PrimvarRefinerReal< float > │ │ │ │ @@ -138,15 +138,15 @@ │ │ │ │ void Limit (T const &src, U &dstPos, U1 &dstTan1, U2 &dstTan2) const │ │ │ │   │ │ │ │ void LimitFaceVarying (T const &src, U &dst, int channel=0) const │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │
│ │ │ │ -

Definition at line 1265 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 1265 of file primvarRefiner.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ PrimvarRefiner()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -164,20 +164,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inline
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 1267 of file primvarRefiner.h.

│ │ │ │ +

Definition at line 1267 of file primvarRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

A specialized factory for StencilTable. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTableFactory.h>

│ │ │ │ +

#include <stencilTableFactory.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Classes

struct  Options
 
│ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ @@ -140,15 +140,15 @@ │ │ │ │

 Utility function for stencil splicing for local point face-varying stencils.
 
│ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTableFactoryReal< REAL >

A specialized factory for StencilTable.

│ │ │ │ │ │ │ │ -

Definition at line 51 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 51 of file stencilTableFactory.h.

│ │ │ │

Member Enumeration Documentation

│ │ │ │ │ │ │ │

◆ Mode

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -164,15 +164,15 @@ │ │ │ │ │ │ │ │ INTERPOLATE_VARYING 

varying primvar stencils

│ │ │ │ │ │ │ │ INTERPOLATE_FACE_VARYING 

face-varying primvar stencils

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 55 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 55 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ AppendLocalPointStencilTable()

│ │ │ │ │ │ │ │ @@ -357,15 +357,15 @@ │ │ │ │ baseStencilTableInput StencilTable for refined vertices │ │ │ │ localPointStencilTableStencilTable for the change of basis patch points. │ │ │ │ factorizeIf factorize is set to true, endcap stencils will be factorized with supporting vertices from baseStencil table so that the endcap points can be computed directly from control vertices. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 148 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 148 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Create() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -458,16 +458,16 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following files: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

A specialized factory for LimitStencilTable. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTableFactory.h>

│ │ │ │ +

#include <stencilTableFactory.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -135,15 +135,15 @@ │ │ │ │

│ │ │ │ Classes

struct  LocationArray
 Descriptor for limit surface locations. More...
 
struct  Options
│ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilTableFactoryReal< REAL >

A specialized factory for LimitStencilTable.

│ │ │ │

The LimitStencilTableFactory creates a table of limit stencils. Limit stencils can interpolate any arbitrary location on the limit surface. The stencils will be bilinear if the surface is refined uniformly, and bicubic if feature adaptive isolation is used instead.

│ │ │ │

Surface locations are expressed as a combination of ptex face index and normalized (s,t) patch coordinates. The factory exposes the LocationArray struct as a container for these location descriptors.

│ │ │ │ │ │ │ │ -

Definition at line 209 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 209 of file stencilTableFactory.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ LocationArrayVec

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -151,15 +151,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
typedef std::vector<LocationArray> LocationArrayVec
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 244 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 244 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Enumeration Documentation

│ │ │ │ │ │ │ │

◆ Mode

│ │ │ │ │ │ │ │ @@ -178,15 +178,15 @@ │ │ │ │ │ │ │ │ INTERPOLATE_VARYING 

varying primvar stencils

│ │ │ │ │ │ │ │ INTERPOLATE_FACE_VARYING 

face-varying primvar stencils

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 213 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 213 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ Create()

│ │ │ │ │ │ │ │ @@ -252,16 +252,16 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
The documentation for this class was generated from the following files: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Vertex stencil descriptor. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTable.h>

│ │ │ │ +

#include <stencilTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for StencilReal< REAL >:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ LimitStencilReal< float > │ │ │ │ @@ -160,15 +160,15 @@ │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilReal< REAL >

Vertex stencil descriptor.

│ │ │ │

Allows access and manipulation of a single stencil in a StencilTable.

│ │ │ │ │ │ │ │ -

Definition at line 53 of file stencilTable.h.

│ │ │ │ +

Definition at line 53 of file stencilTable.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ StencilReal() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -189,15 +189,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Default constructor.

│ │ │ │ │ │ │ │ -

Definition at line 57 of file stencilTable.h.

│ │ │ │ +

Definition at line 57 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ StencilReal() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -245,15 +245,15 @@ │ │ │ │ sizeTable pointer to the size of the stencil │ │ │ │ indicesTable pointer to the vertex indices of the stencil │ │ │ │ weightsTable pointer to the vertex weights of the stencil │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 67 of file stencilTable.h.

│ │ │ │ +

Definition at line 67 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ StencilReal() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -277,15 +277,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Copy constructor.

│ │ │ │ │ │ │ │ -

Definition at line 71 of file stencilTable.h.

│ │ │ │ +

Definition at line 71 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetSize()

│ │ │ │ │ │ │ │ @@ -309,15 +309,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the size of the stencil.

│ │ │ │ │ │ │ │ -

Definition at line 78 of file stencilTable.h.

│ │ │ │ +

Definition at line 78 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetSizePtr()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -340,15 +340,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the size of the stencil as a pointer.

│ │ │ │ │ │ │ │ -

Definition at line 83 of file stencilTable.h.

│ │ │ │ +

Definition at line 83 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexIndices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -371,15 +371,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the control vertices' indices.

│ │ │ │ │ │ │ │ -

Definition at line 88 of file stencilTable.h.

│ │ │ │ +

Definition at line 88 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -402,15 +402,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the interpolation weights.

│ │ │ │ │ │ │ │ -

Definition at line 93 of file stencilTable.h.

│ │ │ │ +

Definition at line 93 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Next()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -433,15 +433,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Advance to the next stencil in the table.

│ │ │ │ │ │ │ │ -

Definition at line 98 of file stencilTable.h.

│ │ │ │ +

Definition at line 98 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Friends And Related Symbol Documentation

│ │ │ │ │ │ │ │

◆ LimitStencilTableFactoryReal< REAL >

│ │ │ │ │ │ │ │ @@ -460,15 +460,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 98 of file stencilTable.h.

│ │ │ │ +

Definition at line 98 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ StencilTableFactoryReal< REAL >

│ │ │ │ │ │ │ │
│ │ │ │ @@ -486,15 +486,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 98 of file stencilTable.h.

│ │ │ │ +

Definition at line 98 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ _indices

│ │ │ │ │ │ │ │ @@ -513,15 +513,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 110 of file stencilTable.h.

│ │ │ │ +

Definition at line 110 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _size

│ │ │ │ │ │ │ │
│ │ │ │ @@ -539,15 +539,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 109 of file stencilTable.h.

│ │ │ │ +

Definition at line 109 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _weights

│ │ │ │ │ │ │ │
│ │ │ │ @@ -565,20 +565,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 111 of file stencilTable.h.

│ │ │ │ +

Definition at line 111 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Vertex stencil class wrapping the template for compatibility. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTable.h>

│ │ │ │ +

#include <stencilTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for Stencil:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ StencilReal< float > │ │ │ │ @@ -161,15 +161,15 @@ │ │ │ │   │ │ │ │ float * _weights │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Vertex stencil class wrapping the template for compatibility.

│ │ │ │ │ │ │ │ -

Definition at line 116 of file stencilTable.h.

│ │ │ │ +

Definition at line 116 of file stencilTable.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ BaseStencil

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -183,15 +183,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ protected
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 118 of file stencilTable.h.

│ │ │ │ +

Definition at line 118 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Stencil() [1/3]

│ │ │ │ │ │ │ │ @@ -211,15 +211,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 121 of file stencilTable.h.

│ │ │ │ +

Definition at line 121 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Stencil() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -239,15 +239,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 122 of file stencilTable.h.

│ │ │ │ +

Definition at line 122 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Stencil() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -283,20 +283,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 123 of file stencilTable.h.

│ │ │ │ +

Definition at line 123 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Table of subdivision stencils. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTable.h>

│ │ │ │ +

#include <stencilTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for StencilTableReal< REAL >:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ LimitStencilTableReal< float > │ │ │ │ @@ -209,15 +209,15 @@ │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTableReal< REAL >

Table of subdivision stencils.

│ │ │ │

Stencils are the most direct method of evaluation of locations on the limit of a surface. Every point of a limit surface can be computed by linearly blending a collection of coarse control vertices.

│ │ │ │

A stencil assigns a series of control vertex indices with a blending weight that corresponds to a unique parametric location of the limit surface. When the control vertices move in space, the limit location can be very efficiently recomputed simply by applying the blending weights to the series of coarse control vertices.

│ │ │ │ │ │ │ │ -

Definition at line 141 of file stencilTable.h.

│ │ │ │ +

Definition at line 141 of file stencilTable.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ StencilTableReal() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -304,15 +304,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinevirtual │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 153 of file stencilTable.h.

│ │ │ │ +

Definition at line 153 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ StencilTableReal() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -333,15 +333,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 255 of file stencilTable.h.

│ │ │ │ +

Definition at line 255 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ StencilTableReal() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -363,15 +363,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 256 of file stencilTable.h.

│ │ │ │ +

Definition at line 256 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ Clear()

│ │ │ │ │ │ │ │ @@ -414,15 +414,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 714 of file stencilTable.h.

│ │ │ │ +

Definition at line 714 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ generateOffsets()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -443,15 +443,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 678 of file stencilTable.h.

│ │ │ │ +

Definition at line 678 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetControlIndices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -474,15 +474,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the indices of the control vertices.

│ │ │ │ │ │ │ │ -

Definition at line 179 of file stencilTable.h.

│ │ │ │ +

Definition at line 179 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumControlVertices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -505,15 +505,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the number of control vertices indexed in the table.

│ │ │ │ │ │ │ │ -

Definition at line 161 of file stencilTable.h.

│ │ │ │ +

Definition at line 161 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumStencils()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -536,15 +536,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the number of stencils in the table.

│ │ │ │ │ │ │ │ -

Definition at line 156 of file stencilTable.h.

│ │ │ │ +

Definition at line 156 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetOffsets()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -567,15 +567,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the offset to a given stencil (factory may leave empty)

│ │ │ │ │ │ │ │ -

Definition at line 174 of file stencilTable.h.

│ │ │ │ +

Definition at line 174 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetSizes()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -598,15 +598,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the number of control vertices of each stencil in the table.

│ │ │ │ │ │ │ │ -

Definition at line 169 of file stencilTable.h.

│ │ │ │ +

Definition at line 169 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetStencil()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -630,15 +630,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns a Stencil at index i in the table.

│ │ │ │ │ │ │ │ -

Definition at line 722 of file stencilTable.h.

│ │ │ │ +

Definition at line 722 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -661,15 +661,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the stencil interpolation weights.

│ │ │ │ │ │ │ │ -

Definition at line 184 of file stencilTable.h.

│ │ │ │ +

Definition at line 184 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ operator[]()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -693,15 +693,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the stencil at index i in the table.

│ │ │ │ │ │ │ │ -

Definition at line 734 of file stencilTable.h.

│ │ │ │ +

Definition at line 734 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ reserve()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -733,15 +733,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 698 of file stencilTable.h.

│ │ │ │ +

Definition at line 698 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ resize()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -773,15 +773,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 690 of file stencilTable.h.

│ │ │ │ +

Definition at line 690 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ shrinkToFit()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -802,15 +802,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 706 of file stencilTable.h.

│ │ │ │ +

Definition at line 706 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ update() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -862,15 +862,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 650 of file stencilTable.h.

│ │ │ │ +

Definition at line 650 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ update() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -934,15 +934,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 618 of file stencilTable.h.

│ │ │ │ +

Definition at line 618 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateValues() [1/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1000,15 +1000,15 @@ │ │ │ │ dstValuesDestination buffer for the interpolated primvar data │ │ │ │ startIndex of first destination value to update │ │ │ │ endIndex of last destination value to update │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 205 of file stencilTable.h.

│ │ │ │ +

Definition at line 205 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateValues() [2/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1054,15 +1054,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 217 of file stencilTable.h.

│ │ │ │ +

Definition at line 217 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateValues() [3/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1120,15 +1120,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 210 of file stencilTable.h.

│ │ │ │ +

Definition at line 210 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateValues() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1186,15 +1186,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 221 of file stencilTable.h.

│ │ │ │ +

Definition at line 221 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Friends And Related Symbol Documentation

│ │ │ │ │ │ │ │

◆ Far::PatchTableBuilder

│ │ │ │ │ │ │ │ @@ -1213,15 +1213,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 261 of file stencilTable.h.

│ │ │ │ +

Definition at line 261 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ StencilTableFactoryReal< REAL >

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1239,15 +1239,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 256 of file stencilTable.h.

│ │ │ │ +

Definition at line 256 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ _indices

│ │ │ │ │ │ │ │ @@ -1266,15 +1266,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 267 of file stencilTable.h.

│ │ │ │ +

Definition at line 267 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _numControlVertices

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1292,15 +1292,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 263 of file stencilTable.h.

│ │ │ │ +

Definition at line 263 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _offsets

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1318,15 +1318,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 266 of file stencilTable.h.

│ │ │ │ +

Definition at line 266 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _sizes

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1344,15 +1344,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 265 of file stencilTable.h.

│ │ │ │ +

Definition at line 265 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _weights

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1370,20 +1370,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 268 of file stencilTable.h.

│ │ │ │ +

Definition at line 268 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Stencil table class wrapping the template for compatibility. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTable.h>

│ │ │ │ +

#include <stencilTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for StencilTable:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ StencilTableReal< float > │ │ │ │ @@ -208,15 +208,15 @@ │ │ │ │   │ │ │ │ std::vector< float > _weights │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Stencil table class wrapping the template for compatibility.

│ │ │ │ │ │ │ │ -

Definition at line 273 of file stencilTable.h.

│ │ │ │ +

Definition at line 273 of file stencilTable.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ BaseTable

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -230,15 +230,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ protected
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 275 of file stencilTable.h.

│ │ │ │ +

Definition at line 275 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ StencilTable() [1/3]

│ │ │ │ │ │ │ │ @@ -258,15 +258,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 286 of file stencilTable.h.

│ │ │ │ +

Definition at line 286 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ StencilTable() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -286,15 +286,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 287 of file stencilTable.h.

│ │ │ │ +

Definition at line 287 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ StencilTable() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -354,15 +354,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 288 of file stencilTable.h.

│ │ │ │ +

Definition at line 288 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetStencil()

│ │ │ │ │ │ │ │ @@ -383,15 +383,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 278 of file stencilTable.h.

│ │ │ │ +

Definition at line 278 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ operator[]()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -411,20 +411,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 281 of file stencilTable.h.

│ │ │ │ +

Definition at line 281 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Limit point stencil descriptor. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTable.h>

│ │ │ │ +

#include <stencilTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for LimitStencilReal< REAL >:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ StencilReal< REAL > │ │ │ │ @@ -179,15 +179,15 @@ │ │ │ │ REAL * _weights │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilReal< REAL >

Limit point stencil descriptor.

│ │ │ │ │ │ │ │ -

Definition at line 303 of file stencilTable.h.

│ │ │ │ +

Definition at line 303 of file stencilTable.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ LimitStencilReal()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -268,15 +268,15 @@ │ │ │ │ duuWeightsTable pointer to the 'uu' derivative weights │ │ │ │ duvWeightsTable pointer to the 'uv' derivative weights │ │ │ │ dvvWeightsTable pointer to the 'vv' derivative weights │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 324 of file stencilTable.h.

│ │ │ │ +

Definition at line 324 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetDuuWeights()

│ │ │ │ │ │ │ │ @@ -300,15 +300,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the uu derivative weights.

│ │ │ │ │ │ │ │ -

Definition at line 351 of file stencilTable.h.

│ │ │ │ +

Definition at line 351 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDuvWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -331,15 +331,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the uv derivative weights.

│ │ │ │ │ │ │ │ -

Definition at line 356 of file stencilTable.h.

│ │ │ │ +

Definition at line 356 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDuWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -362,15 +362,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the u derivative weights.

│ │ │ │ │ │ │ │ -

Definition at line 341 of file stencilTable.h.

│ │ │ │ +

Definition at line 341 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDvvWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -393,15 +393,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the vv derivative weights.

│ │ │ │ │ │ │ │ -

Definition at line 361 of file stencilTable.h.

│ │ │ │ +

Definition at line 361 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetDvWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -424,15 +424,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the v derivative weights.

│ │ │ │ │ │ │ │ -

Definition at line 346 of file stencilTable.h.

│ │ │ │ +

Definition at line 346 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Next()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -455,15 +455,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Advance to the next stencil in the table.

│ │ │ │ │ │ │ │ -

Definition at line 366 of file stencilTable.h.

│ │ │ │ +

Definition at line 366 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Friends And Related Symbol Documentation

│ │ │ │ │ │ │ │

◆ LimitStencilTableFactoryReal< REAL >

│ │ │ │ │ │ │ │ @@ -482,15 +482,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 366 of file stencilTable.h.

│ │ │ │ +

Definition at line 366 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ StencilTableFactoryReal< REAL >

│ │ │ │ │ │ │ │
│ │ │ │ @@ -508,20 +508,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 366 of file stencilTable.h.

│ │ │ │ +

Definition at line 366 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Limit point stencil class wrapping the template for compatibility. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTable.h>

│ │ │ │ +

#include <stencilTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for LimitStencil:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ LimitStencilReal< float > │ │ │ │ @@ -182,15 +182,15 @@ │ │ │ │   │ │ │ │ REAL * _weights │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Limit point stencil class wrapping the template for compatibility.

│ │ │ │ │ │ │ │ -

Definition at line 392 of file stencilTable.h.

│ │ │ │ +

Definition at line 392 of file stencilTable.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ BaseStencil

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -204,15 +204,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ protected
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 394 of file stencilTable.h.

│ │ │ │ +

Definition at line 394 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ LimitStencil() [1/2]

│ │ │ │ │ │ │ │ @@ -233,15 +233,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 397 of file stencilTable.h.

│ │ │ │ +

Definition at line 397 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ LimitStencil() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -307,20 +307,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 398 of file stencilTable.h.

│ │ │ │ +

Definition at line 398 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Table of limit subdivision stencils. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTable.h>

│ │ │ │ +

#include <stencilTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for LimitStencilTableReal< REAL >:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ StencilTableReal< REAL > │ │ │ │ @@ -257,15 +257,15 @@ │ │ │ │ std::vector< REAL > _weights │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilTableReal< REAL >

Table of limit subdivision stencils.

│ │ │ │ │ │ │ │ -

Definition at line 409 of file stencilTable.h.

│ │ │ │ +

Definition at line 409 of file stencilTable.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ LimitStencilTableReal()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -406,15 +406,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the 'uu' derivative stencil interpolation weights.

│ │ │ │ │ │ │ │ -

Definition at line 444 of file stencilTable.h.

│ │ │ │ +

Definition at line 444 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDuvWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -437,15 +437,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the 'uv' derivative stencil interpolation weights.

│ │ │ │ │ │ │ │ -

Definition at line 449 of file stencilTable.h.

│ │ │ │ +

Definition at line 449 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDuWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -468,15 +468,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the 'u' derivative stencil interpolation weights.

│ │ │ │ │ │ │ │ -

Definition at line 434 of file stencilTable.h.

│ │ │ │ +

Definition at line 434 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDvvWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -499,15 +499,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the 'vv' derivative stencil interpolation weights.

│ │ │ │ │ │ │ │ -

Definition at line 454 of file stencilTable.h.

│ │ │ │ +

Definition at line 454 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDvWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -530,15 +530,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the 'v' derivative stencil interpolation weights.

│ │ │ │ │ │ │ │ -

Definition at line 439 of file stencilTable.h.

│ │ │ │ +

Definition at line 439 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetLimitStencil()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -562,15 +562,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns a LimitStencil at index i in the table.

│ │ │ │ │ │ │ │ -

Definition at line 749 of file stencilTable.h.

│ │ │ │ +

Definition at line 749 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ operator[]()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -594,15 +594,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the limit stencil at index i in the table.

│ │ │ │ │ │ │ │ -

Definition at line 782 of file stencilTable.h.

│ │ │ │ +

Definition at line 782 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Update2ndDerivs() [1/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -674,15 +674,15 @@ │ │ │ │ vvderivsDestination buffer for the interpolated 'vv' derivative primvar data │ │ │ │ startIndex of first destination derivative to update │ │ │ │ endIndex of last destination derivative to update │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 528 of file stencilTable.h.

│ │ │ │ +

Definition at line 528 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Update2ndDerivs() [2/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -740,15 +740,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 548 of file stencilTable.h.

│ │ │ │ +

Definition at line 548 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Update2ndDerivs() [3/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -818,15 +818,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 538 of file stencilTable.h.

│ │ │ │ +

Definition at line 538 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Update2ndDerivs() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -896,15 +896,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 556 of file stencilTable.h.

│ │ │ │ +

Definition at line 556 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateDerivs() [1/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -969,15 +969,15 @@ │ │ │ │ vderivsDestination buffer for the interpolated 'v' derivative primvar data │ │ │ │ startIndex of first destination derivative to update │ │ │ │ endIndex of last destination derivative to update │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 476 of file stencilTable.h.

│ │ │ │ +

Definition at line 476 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateDerivs() [2/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1029,15 +1029,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 493 of file stencilTable.h.

│ │ │ │ +

Definition at line 493 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateDerivs() [3/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1101,15 +1101,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 484 of file stencilTable.h.

│ │ │ │ +

Definition at line 484 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateDerivs() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1173,15 +1173,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 500 of file stencilTable.h.

│ │ │ │ +

Definition at line 500 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Friends And Related Symbol Documentation

│ │ │ │ │ │ │ │

◆ LimitStencilTableFactoryReal< REAL >

│ │ │ │ │ │ │ │ @@ -1200,20 +1200,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 565 of file stencilTable.h.

│ │ │ │ +

Definition at line 565 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Limit stencil table class wrapping the template for compatibility. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTable.h>

│ │ │ │ +

#include <stencilTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for LimitStencilTable:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ LimitStencilTableReal< float > │ │ │ │ @@ -257,15 +257,15 @@ │ │ │ │   │ │ │ │ std::vector< REAL > _weights │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Limit stencil table class wrapping the template for compatibility.

│ │ │ │ │ │ │ │ -

Definition at line 583 of file stencilTable.h.

│ │ │ │ +

Definition at line 583 of file stencilTable.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ BaseTable

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -279,15 +279,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ protected
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 585 of file stencilTable.h.

│ │ │ │ +

Definition at line 585 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ LimitStencilTable()

│ │ │ │ │ │ │ │ @@ -378,15 +378,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 596 of file stencilTable.h.

│ │ │ │ +

Definition at line 596 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetLimitStencil()

│ │ │ │ │ │ │ │ @@ -407,15 +407,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 588 of file stencilTable.h.

│ │ │ │ +

Definition at line 588 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ operator[]()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -435,20 +435,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 591 of file stencilTable.h.

│ │ │ │ +

Definition at line 591 of file stencilTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
StencilTableFactoryReal< REAL >::Options Struct Reference
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <stencilTableFactory.h>

│ │ │ │ +

#include <stencilTableFactory.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 Options ()
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ @@ -127,15 +127,15 @@ │ │ │ │

 
unsigned int fvarChannel
 
│ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ struct OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTableFactoryReal< REAL >::Options
│ │ │ │ -

Definition at line 61 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 61 of file stencilTableFactory.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Options()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -154,15 +154,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 63 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 63 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ factorizeIntermediateLevels

│ │ │ │ │ │ │ │ @@ -174,15 +174,15 @@ │ │ │ │ │ │ │ │ unsigned int factorizeIntermediateLevels │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

accumulate stencil weights from control vertices or from the stencils of the previous level

│ │ │ │ │ │ │ │ -

Definition at line 75 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 75 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ fvarChannel

│ │ │ │ │ │ │ │
│ │ │ │ @@ -193,15 +193,15 @@ │ │ │ │ │ │ │ │ unsigned int fvarChannel │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

face-varying channel to use when generating face-varying stencils

│ │ │ │ │ │ │ │ -

Definition at line 79 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 79 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateControlVerts

│ │ │ │ │ │ │ │
│ │ │ │ @@ -213,15 +213,15 @@ │ │ │ │ unsigned int generateControlVerts │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

generate stencils for control-vertices

│ │ │ │ │ │ │ │ -

Definition at line 73 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 73 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateIntermediateLevels

│ │ │ │ │ │ │ │
│ │ │ │ @@ -233,15 +233,15 @@ │ │ │ │ unsigned int generateIntermediateLevels │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

vertices at all levels or highest only

│ │ │ │ │ │ │ │ -

Definition at line 74 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 74 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generateOffsets

│ │ │ │ │ │ │ │
│ │ │ │ @@ -253,15 +253,15 @@ │ │ │ │ unsigned int generateOffsets │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

populate optional "_offsets" field

│ │ │ │ │ │ │ │ -

Definition at line 72 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 72 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ interpolationMode

│ │ │ │ │ │ │ │
│ │ │ │ @@ -273,15 +273,15 @@ │ │ │ │ unsigned int interpolationMode │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

interpolation mode

│ │ │ │ │ │ │ │ -

Definition at line 71 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 71 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ maxLevel

│ │ │ │ │ │ │ │
│ │ │ │ @@ -293,20 +293,20 @@ │ │ │ │ unsigned int maxLevel │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

generate stencils up to 'maxLevel'

│ │ │ │ │ │ │ │ -

Definition at line 78 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 78 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
LimitStencilTableFactoryReal< REAL >::Options Struct Reference
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <stencilTableFactory.h>

│ │ │ │ +

#include <stencilTableFactory.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 Options ()
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ @@ -120,15 +120,15 @@ │ │ │ │

unsigned int fvarChannel
 face-varying channel to use
 
│ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ struct OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilTableFactoryReal< REAL >::Options
│ │ │ │ -

Definition at line 219 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 219 of file stencilTableFactory.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Options()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -147,15 +147,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 221 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 221 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ fvarChannel

│ │ │ │ │ │ │ │ @@ -168,15 +168,15 @@ │ │ │ │ unsigned int fvarChannel │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

face-varying channel to use

│ │ │ │ │ │ │ │ -

Definition at line 229 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 229 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ generate1stDerivatives

│ │ │ │ │ │ │ │
│ │ │ │ @@ -188,15 +188,15 @@ │ │ │ │ unsigned int generate1stDerivatives │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate weights for 1st derivatives.

│ │ │ │ │ │ │ │ -

Definition at line 227 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 227 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ generate2ndDerivatives

│ │ │ │ │ │ │ │
│ │ │ │ @@ -208,15 +208,15 @@ │ │ │ │ unsigned int generate2ndDerivatives │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Generate weights for 2nd derivatives.

│ │ │ │ │ │ │ │ -

Definition at line 228 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 228 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ interpolationMode

│ │ │ │ │ │ │ │
│ │ │ │ @@ -228,20 +228,20 @@ │ │ │ │ unsigned int interpolationMode │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

interpolation mode

│ │ │ │ │ │ │ │ -

Definition at line 226 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 226 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Descriptor for limit surface locations. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTableFactory.h>

│ │ │ │ +

#include <stencilTableFactory.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 LocationArray ()
 
│ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ @@ -124,15 +124,15 @@ │ │ │ │

 array of v coordinates
 
│ │ │ │

Detailed Description

│ │ │ │
template<typename REAL>
│ │ │ │ struct OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilTableFactoryReal< REAL >::LocationArray

Descriptor for limit surface locations.

│ │ │ │ │ │ │ │ -

Definition at line 233 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 233 of file stencilTableFactory.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ LocationArray()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -151,15 +151,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 235 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 235 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ numLocations

│ │ │ │ │ │ │ │ @@ -172,15 +172,15 @@ │ │ │ │ int numLocations │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

number of (u,v) coordinates in the array

│ │ │ │ │ │ │ │ -

Definition at line 238 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 238 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ ptexIdx

│ │ │ │ │ │ │ │
│ │ │ │ @@ -192,15 +192,15 @@ │ │ │ │ int ptexIdx │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

ptex face index

│ │ │ │ │ │ │ │ -

Definition at line 237 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 237 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ s

│ │ │ │ │ │ │ │
│ │ │ │ @@ -212,15 +212,15 @@ │ │ │ │ REAL const* s │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

array of u coordinates

│ │ │ │ │ │ │ │ -

Definition at line 240 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 240 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ t

│ │ │ │ │ │ │ │
│ │ │ │ @@ -232,20 +232,20 @@ │ │ │ │ REAL const * t │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

array of v coordinates

│ │ │ │ │ │ │ │ -

Definition at line 241 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 241 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Stencil table factory class wrapping the template for compatibility. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTableFactory.h>

│ │ │ │ +

#include <stencilTableFactory.h>

│ │ │ │
│ │ │ │ Inheritance diagram for StencilTableFactory:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ StencilTableFactoryReal< float > │ │ │ │ @@ -146,15 +146,15 @@ │ │ │ │ - Public Types inherited from StencilTableFactoryReal< float > │ │ │ │ enum  Mode │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Stencil table factory class wrapping the template for compatibility.

│ │ │ │ │ │ │ │ -

Definition at line 287 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 287 of file stencilTableFactory.h.

│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ AppendLocalPointStencilTable()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -194,15 +194,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inlinestatic
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 308 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 308 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ AppendLocalPointStencilTableFaceVarying()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -250,15 +250,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 334 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 334 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ AppendLocalPointStencilTableVarying()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -300,15 +300,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 321 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 321 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Create() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -338,15 +338,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 300 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 300 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Create() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -376,20 +376,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 293 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 293 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Stencil table factory class wrapping the template for compatibility. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <stencilTableFactory.h>

│ │ │ │ +

#include <stencilTableFactory.h>

│ │ │ │
│ │ │ │ Inheritance diagram for LimitStencilTableFactory:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ LimitStencilTableFactoryReal< float > │ │ │ │ @@ -128,15 +128,15 @@ │ │ │ │   │ │ │ │ typedef std::vector< LocationArray > LocationArrayVec │ │ │ │   │ │ │ │ │ │ │ │

Detailed Description

│ │ │ │

Stencil table factory class wrapping the template for compatibility.

│ │ │ │ │ │ │ │ -

Definition at line 354 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 354 of file stencilTableFactory.h.

│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ Create()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -182,20 +182,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inlinestatic
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 360 of file stencilTableFactory.h.

│ │ │ │ +

Definition at line 360 of file stencilTableFactory.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

An interface for accessing data in a specific level of a refined topology hierarchy. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <topologyLevel.h>

│ │ │ │ +

#include <topologyLevel.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -258,15 +258,15 @@ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

Methods to inspect the overall inventory of components:

All three main component types are indexed locally within each level. For some topological relationships – notably face-vertices, which is often the only relationship of interest – the total number of entries is also made available.

│ │ │ │
int GetNumVertices () const
 ~TopologyLevel ()
 
│ │ │ │

Detailed Description

│ │ │ │

An interface for accessing data in a specific level of a refined topology hierarchy.

│ │ │ │

TopologyLevel provides an interface to data in a specific level of a topology hierarchy. Instances of TopologyLevel are created and owned by a TopologyRefiner, which will return const-references to them. Such references are only valid during the lifetime of the TopologyRefiner that created and returned them, and only for a given refinement, i.e. if the TopologyRefiner is re-refined, any references to TopoologyLevels are invalidated.

│ │ │ │ │ │ │ │ -

Definition at line 49 of file topologyLevel.h.

│ │ │ │ +

Definition at line 49 of file topologyLevel.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ TopologyLevel()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -283,15 +283,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inline
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 300 of file topologyLevel.h.

│ │ │ │ +

Definition at line 300 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ ~TopologyLevel()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -310,15 +310,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 301 of file topologyLevel.h.

│ │ │ │ +

Definition at line 301 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ DoesEdgeFVarTopologyMatch()

│ │ │ │ │ │ │ │ @@ -351,15 +351,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if face-varying topology across the edge only matches.

│ │ │ │ │ │ │ │ -

Definition at line 247 of file topologyLevel.h.

│ │ │ │ +

Definition at line 247 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ DoesFaceFVarTopologyMatch()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -391,15 +391,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if face-varying topology around a face matches.

│ │ │ │ │ │ │ │ -

Definition at line 252 of file topologyLevel.h.

│ │ │ │ +

Definition at line 252 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ DoesVertexFVarTopologyMatch()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -431,15 +431,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if face-varying topology around a vertex matches.

│ │ │ │ │ │ │ │ -

Definition at line 242 of file topologyLevel.h.

│ │ │ │ +

Definition at line 242 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ FindEdge()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -471,15 +471,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Identify the edge matching the given vertex pair.

│ │ │ │ │ │ │ │ -

Definition at line 120 of file topologyLevel.h.

│ │ │ │ +

Definition at line 120 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetEdgeChildEdges()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -501,15 +501,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the child edges (in the next level) of a given edge.

│ │ │ │ │ │ │ │ -

Definition at line 268 of file topologyLevel.h.

│ │ │ │ +

Definition at line 268 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetEdgeChildVertex()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -531,15 +531,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the child vertex (in the next level) of a given edge.

│ │ │ │ │ │ │ │ -

Definition at line 274 of file topologyLevel.h.

│ │ │ │ +

Definition at line 274 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetEdgeFaceLocalIndices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -561,15 +561,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the local indices of an edge with respect to its incident faces.

│ │ │ │ │ │ │ │ -

Definition at line 117 of file topologyLevel.h.

│ │ │ │ +

Definition at line 117 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetEdgeFaces()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -591,15 +591,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the faces incident a given edge.

│ │ │ │ │ │ │ │ -

Definition at line 102 of file topologyLevel.h.

│ │ │ │ +

Definition at line 102 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetEdgeSharpness()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -621,15 +621,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the sharpness assigned a given edge.

│ │ │ │ │ │ │ │ -

Definition at line 173 of file topologyLevel.h.

│ │ │ │ +

Definition at line 173 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetEdgeVertices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -651,15 +651,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the vertices incident a given edge.

│ │ │ │ │ │ │ │ -

Definition at line 99 of file topologyLevel.h.

│ │ │ │ +

Definition at line 99 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetFaceChildEdges()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -681,15 +681,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the child edges (in the next level) of a given face.

│ │ │ │ │ │ │ │ -

Definition at line 265 of file topologyLevel.h.

│ │ │ │ +

Definition at line 265 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetFaceChildFaces()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -711,15 +711,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the child faces (in the next level) of a given face.

│ │ │ │ │ │ │ │ -

Definition at line 262 of file topologyLevel.h.

│ │ │ │ +

Definition at line 262 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetFaceChildVertex()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -741,15 +741,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the child vertex (in the next level) of a given face.

│ │ │ │ │ │ │ │ -

Definition at line 271 of file topologyLevel.h.

│ │ │ │ +

Definition at line 271 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetFaceEdges()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -771,15 +771,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the edges incident a given face.

│ │ │ │ │ │ │ │ -

Definition at line 96 of file topologyLevel.h.

│ │ │ │ +

Definition at line 96 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetFaceFVarValues()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -811,15 +811,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the face-varying values associated with a particular face.

│ │ │ │ │ │ │ │ -

Definition at line 237 of file topologyLevel.h.

│ │ │ │ +

Definition at line 237 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetFaceParentFace()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -841,15 +841,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the parent face (in the previous level) of a given face.

│ │ │ │ │ │ │ │ -

Definition at line 280 of file topologyLevel.h.

│ │ │ │ +

Definition at line 280 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetFaceVertices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -871,15 +871,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the vertices incident a given face.

│ │ │ │ │ │ │ │ -

Definition at line 93 of file topologyLevel.h.

│ │ │ │ +

Definition at line 93 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumEdges()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -900,15 +900,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the number of edges in this level.

│ │ │ │ │ │ │ │ -

Definition at line 68 of file topologyLevel.h.

│ │ │ │ +

Definition at line 68 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFaces()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -929,15 +929,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the number of faces in this level.

│ │ │ │ │ │ │ │ -

Definition at line 65 of file topologyLevel.h.

│ │ │ │ +

Definition at line 65 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFaceVertices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -958,15 +958,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the total number of face-vertices, i.e. the sum of all vertices for all faces.

│ │ │ │ │ │ │ │ -

Definition at line 71 of file topologyLevel.h.

│ │ │ │ +

Definition at line 71 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFVarChannels()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -987,15 +987,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the number of face-varying channels (should be same for all levels)

│ │ │ │ │ │ │ │ -

Definition at line 230 of file topologyLevel.h.

│ │ │ │ +

Definition at line 230 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFVarValues()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1017,15 +1017,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the total number of face-varying values in a particular channel (the upper bound of a face-varying value index)

│ │ │ │ │ │ │ │ -

Definition at line 234 of file topologyLevel.h.

│ │ │ │ +

Definition at line 234 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumVertices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1046,15 +1046,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the number of vertices in this level.

│ │ │ │ │ │ │ │ -

Definition at line 62 of file topologyLevel.h.

│ │ │ │ +

Definition at line 62 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexChildVertex()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1076,15 +1076,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the child vertex (in the next level) of a given vertex.

│ │ │ │ │ │ │ │ -

Definition at line 277 of file topologyLevel.h.

│ │ │ │ +

Definition at line 277 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexEdgeLocalIndices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1106,15 +1106,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the local indices of a vertex with respect to its incident edges.

│ │ │ │ │ │ │ │ -

Definition at line 114 of file topologyLevel.h.

│ │ │ │ +

Definition at line 114 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexEdges()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1136,15 +1136,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the edges incident a given vertex.

│ │ │ │ │ │ │ │ -

Definition at line 108 of file topologyLevel.h.

│ │ │ │ +

Definition at line 108 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexFaceLocalIndices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1166,15 +1166,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the local indices of a vertex with respect to its incident faces.

│ │ │ │ │ │ │ │ -

Definition at line 111 of file topologyLevel.h.

│ │ │ │ +

Definition at line 111 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexFaces()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1196,15 +1196,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Access the faces incident a given vertex.

│ │ │ │ │ │ │ │ -

Definition at line 105 of file topologyLevel.h.

│ │ │ │ +

Definition at line 105 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexRule()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1226,15 +1226,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the subdivision rule assigned a given vertex specific to this level.

│ │ │ │ │ │ │ │ -

Definition at line 194 of file topologyLevel.h.

│ │ │ │ +

Definition at line 194 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexSharpness()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1256,15 +1256,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return the sharpness assigned a given vertex.

│ │ │ │ │ │ │ │ -

Definition at line 176 of file topologyLevel.h.

│ │ │ │ +

Definition at line 176 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsEdgeBoundary()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1286,15 +1286,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the edge is a boundary (only one incident face)

│ │ │ │ │ │ │ │ -

Definition at line 134 of file topologyLevel.h.

│ │ │ │ +

Definition at line 134 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsEdgeInfSharp()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1316,15 +1316,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the edge is infinitely-sharp.

│ │ │ │ │ │ │ │ -

Definition at line 179 of file topologyLevel.h.

│ │ │ │ +

Definition at line 179 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsEdgeNonManifold()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1346,15 +1346,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the edge is non-manifold.

│ │ │ │ │ │ │ │ -

Definition at line 128 of file topologyLevel.h.

│ │ │ │ +

Definition at line 128 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsEdgeSemiSharp()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1376,15 +1376,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the edge is semi-sharp.

│ │ │ │ │ │ │ │ -

Definition at line 185 of file topologyLevel.h.

│ │ │ │ +

Definition at line 185 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsFaceHole()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1406,15 +1406,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if a given face has been tagged as a hole.

│ │ │ │ │ │ │ │ -

Definition at line 191 of file topologyLevel.h.

│ │ │ │ +

Definition at line 191 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsVertexBoundary()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1436,15 +1436,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the vertex is on a boundary (at least one incident boundary edge)

│ │ │ │ │ │ │ │ -

Definition at line 137 of file topologyLevel.h.

│ │ │ │ +

Definition at line 137 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsVertexCorner()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1466,15 +1466,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the vertex is a corner (only one incident face)

│ │ │ │ │ │ │ │ -

Definition at line 140 of file topologyLevel.h.

│ │ │ │ +

Definition at line 140 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsVertexInfSharp()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1496,15 +1496,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the vertex is infinitely-sharp.

│ │ │ │ │ │ │ │ -

Definition at line 182 of file topologyLevel.h.

│ │ │ │ +

Definition at line 182 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsVertexNonManifold()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1526,15 +1526,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the vertex is non-manifold.

│ │ │ │ │ │ │ │ -

Definition at line 131 of file topologyLevel.h.

│ │ │ │ +

Definition at line 131 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsVertexSemiSharp()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1556,15 +1556,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Return if the vertex is semi-sharp.

│ │ │ │ │ │ │ │ -

Definition at line 188 of file topologyLevel.h.

│ │ │ │ +

Definition at line 188 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsVertexValenceRegular()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1589,15 +1589,15 @@ │ │ │ │
│ │ │ │ │ │ │ │

Return if the valence of the vertex is regular (must be manifold)

│ │ │ │

Note that this test only determines if the valence of the vertex is regular with respect to the assigned subdivision scheme – not if the neighborhood around the vertex is regular. The latter depends on a number of factors including the incident faces of the vertex (they must all be regular) and the presence of sharpness at the vertex itself or its incident edges.

│ │ │ │

The regularity of the valence is a necessary but not a sufficient condition in determining the regularity of the neighborhood. For example, while the valence of an interior vertex may be regular, its neighborhood is not if the vertex was made infinitely sharp. Conversely, a corner vertex is considered regular by its valence but its neighborhood is not if the vertex was not made infinitely sharp.

│ │ │ │

Whether the valence of the vertex is regular is also a property that remains the same for the vertex in all subdivision levels. In contrast, the regularity of the region around the vertex may change as the presence of irregular faces or semi-sharp features is reduced by subdivision.

│ │ │ │ │ │ │ │ -

Definition at line 162 of file topologyLevel.h.

│ │ │ │ +

Definition at line 162 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ PrintTopology()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1617,15 +1617,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 287 of file topologyLevel.h.

│ │ │ │ +

Definition at line 287 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ValidateTopology()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1644,15 +1644,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 286 of file topologyLevel.h.

│ │ │ │ +

Definition at line 286 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Friends And Related Symbol Documentation

│ │ │ │ │ │ │ │

◆ TopologyRefiner

│ │ │ │ │ │ │ │ @@ -1669,20 +1669,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 292 of file topologyLevel.h.

│ │ │ │ +

Definition at line 292 of file topologyLevel.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
The documentation for this class was generated from the following files: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Stores topology data for a specified set of refinement options. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <topologyRefiner.h>

│ │ │ │ +

#include <topologyRefiner.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -208,15 +208,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Classes

struct  AdaptiveOptions
 Adaptive refinement options. More...
 
struct  UniformOptions
 
 TopologyRefiner (TopologyRefiner const &source)
 
│ │ │ │

Detailed Description

│ │ │ │

Stores topology data for a specified set of refinement options.

│ │ │ │ │ │ │ │ -

Definition at line 51 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 51 of file topologyRefiner.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ TopologyRefiner() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -311,15 +311,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

Returns the options specified on refinement.

│ │ │ │ │ │ │ │ -

Definition at line 196 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 196 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetFVarLinearInterpolation()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -341,15 +341,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the face-varying interpolation rule set for a given channel.

│ │ │ │ │ │ │ │ -

Definition at line 298 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 298 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ getLevel() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -369,15 +369,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 236 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 236 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ getLevel() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -397,15 +397,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 237 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 237 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetLevel()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -427,15 +427,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns a handle to access data specific to a particular level.

│ │ │ │ │ │ │ │ -

Definition at line 95 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 95 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetMaxLevel()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -456,15 +456,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the highest level of refinement.

│ │ │ │ │ │ │ │ -

Definition at line 74 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 74 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetMaxValence()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -485,15 +485,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the maximum vertex valence in all levels.

│ │ │ │ │ │ │ │ -

Definition at line 77 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 77 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumEdgesTotal()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -514,15 +514,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the total number of edges in all levels.

│ │ │ │ │ │ │ │ -

Definition at line 86 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 86 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFacesTotal()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -543,15 +543,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the total number of edges in all levels.

│ │ │ │ │ │ │ │ -

Definition at line 89 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 89 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFaceVerticesTotal()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -572,15 +572,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the total number of face vertices in all levels.

│ │ │ │ │ │ │ │ -

Definition at line 92 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 92 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFVarChannels()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -601,15 +601,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the number of face-varying channels in the tables.

│ │ │ │ │ │ │ │ -

Definition at line 293 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 293 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFVarValuesTotal()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -650,15 +650,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the number of refinement levels.

│ │ │ │ │ │ │ │ -

Definition at line 71 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 71 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumVerticesTotal()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -679,15 +679,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the total number of vertices in all levels.

│ │ │ │ │ │ │ │ -

Definition at line 83 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 83 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ getRefinement() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -707,15 +707,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 239 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 239 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ getRefinement() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -735,15 +735,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 240 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 240 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetSchemeOptions()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -764,15 +764,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the subdivision options.

│ │ │ │ │ │ │ │ -

Definition at line 65 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 65 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetSchemeType()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -793,15 +793,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the subdivision scheme.

│ │ │ │ │ │ │ │ -

Definition at line 62 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 62 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetUniformOptions()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -822,15 +822,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the options specified on refinement.

│ │ │ │ │ │ │ │ -

Definition at line 149 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 149 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ HasHoles()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -851,15 +851,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns true if faces have been tagged as holes.

│ │ │ │ │ │ │ │ -

Definition at line 80 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 80 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsUniform()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -880,15 +880,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns true if uniform refinement has been applied.

│ │ │ │ │ │ │ │ -

Definition at line 68 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 68 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ RefineAdaptive()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -989,15 +989,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 226 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 226 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ PatchTableBuilder

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1013,15 +1013,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 225 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 225 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ PrimvarRefinerReal

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1039,15 +1039,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 229 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 229 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ PtexIndices

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1063,15 +1063,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 227 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 227 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ TopologyRefinerFactory

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1089,15 +1089,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 223 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 223 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ TopologyRefinerFactoryBase

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1113,20 +1113,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ friend │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 224 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 224 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Uniform refinement options. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <topologyRefiner.h>

│ │ │ │ +

#include <topologyRefiner.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -123,15 +123,15 @@ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 UniformOptions (int level)
 
void SetRefinementLevel (int level)
 Set uniform refinement level.
 
│ │ │ │

Detailed Description

│ │ │ │

Uniform refinement options.

│ │ │ │

Options for uniform refinement, including the number of levels, vertex ordering and generation of topology information.

│ │ │ │

Note the impact of the option to generate fullTopologyInLastLevel. Given subsequent levels of uniform refinement typically reguire 4x the data of the previous level, only the minimum amount of data is generated in the last level by default, i.e. a vertex and face-vertex list. If requiring topology traversal of the last level, e.g. inspecting edges or incident faces of vertices, the option to generate full topology in the last level should be enabled.

│ │ │ │ │ │ │ │ -

Definition at line 118 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 118 of file topologyRefiner.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ UniformOptions()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -149,15 +149,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inline
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 120 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 120 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ SetRefinementLevel()

│ │ │ │ │ │ │ │ @@ -180,15 +180,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set uniform refinement level.

│ │ │ │ │ │ │ │ -

Definition at line 126 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 126 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ fullTopologyInLastLevel

│ │ │ │ │ │ │ │ @@ -198,15 +198,15 @@ │ │ │ │ │ │ │ │ unsigned int fullTopologyInLastLevel │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Skip topological relationships in the last level of refinement that are not needed for interpolation (keep false if using limit).

│ │ │ │ │ │ │ │ -

Definition at line 131 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 131 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ orderVerticesFromFacesFirst

│ │ │ │ │ │ │ │
│ │ │ │ @@ -215,15 +215,15 @@ │ │ │ │ │ │ │ │ unsigned int orderVerticesFromFacesFirst │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Order child vertices from faces first instead of child vertices of vertices

│ │ │ │ │ │ │ │ -

Definition at line 129 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 129 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ refinementLevel

│ │ │ │ │ │ │ │
│ │ │ │ @@ -233,20 +233,20 @@ │ │ │ │ unsigned int refinementLevel │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Number of refinement iterations.

│ │ │ │ │ │ │ │ -

Definition at line 128 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 128 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Adaptive refinement options. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <topologyRefiner.h>

│ │ │ │ +

#include <topologyRefiner.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -129,15 +129,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 AdaptiveOptions (int level)
 
void SetIsolationLevel (int level)
 Set isolation level.
 
unsigned int orderVerticesFromFacesFirst:1
 
│ │ │ │

Detailed Description

│ │ │ │

Adaptive refinement options.

│ │ │ │ │ │ │ │ -

Definition at line 156 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 156 of file topologyRefiner.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ AdaptiveOptions()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -155,15 +155,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inline
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 158 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 158 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ SetIsolationLevel()

│ │ │ │ │ │ │ │ @@ -186,15 +186,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set isolation level.

│ │ │ │ │ │ │ │ -

Definition at line 167 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 167 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetSecondaryLevel()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -216,15 +216,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set secondary isolation level.

│ │ │ │ │ │ │ │ -

Definition at line 170 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 170 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ considerFVarChannels

│ │ │ │ │ │ │ │ @@ -234,15 +234,15 @@ │ │ │ │ │ │ │ │ unsigned int considerFVarChannels │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Inspect face-varying channels and isolate when irregular features present

│ │ │ │ │ │ │ │ -

Definition at line 180 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 180 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ isolationLevel

│ │ │ │ │ │ │ │
│ │ │ │ @@ -251,15 +251,15 @@ │ │ │ │ │ │ │ │ unsigned int isolationLevel │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Number of iterations applied to isolate extraordinary vertices and creases

│ │ │ │ │ │ │ │ -

Definition at line 172 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 172 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ orderVerticesFromFacesFirst

│ │ │ │ │ │ │ │
│ │ │ │ @@ -268,15 +268,15 @@ │ │ │ │ │ │ │ │ unsigned int orderVerticesFromFacesFirst │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Order child vertices from faces first instead of child vertices of vertices

│ │ │ │ │ │ │ │ -

Definition at line 182 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 182 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ secondaryLevel

│ │ │ │ │ │ │ │
│ │ │ │ @@ -285,15 +285,15 @@ │ │ │ │ │ │ │ │ unsigned int secondaryLevel │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Shallower level to stop isolation of smooth irregular features

│ │ │ │ │ │ │ │ -

Definition at line 174 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 174 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ useInfSharpPatch

│ │ │ │ │ │ │ │
│ │ │ │ @@ -302,15 +302,15 @@ │ │ │ │ │ │ │ │ unsigned int useInfSharpPatch │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Use infinitely sharp patches and stop isolation where applicable

│ │ │ │ │ │ │ │ -

Definition at line 178 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 178 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ useSingleCreasePatch

│ │ │ │ │ │ │ │
│ │ │ │ @@ -319,20 +319,20 @@ │ │ │ │ │ │ │ │ unsigned int useSingleCreasePatch │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Use 'single-crease' patch and stop isolation where applicable

│ │ │ │ │ │ │ │ -

Definition at line 176 of file topologyRefiner.h.

│ │ │ │ +

Definition at line 176 of file topologyRefiner.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

BufferDescriptor is a struct which describes buffer elements in interleaved data buffers. Almost all Osd Evaluator APIs take BufferDescriptors along with device-specific buffer objects. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <bufferDescriptor.h>

│ │ │ │ +

#include <bufferDescriptor.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -143,15 +143,15 @@ │ │ │ │

Detailed Description

│ │ │ │

BufferDescriptor is a struct which describes buffer elements in interleaved data buffers. Almost all Osd Evaluator APIs take BufferDescriptors along with device-specific buffer objects.

│ │ │ │

The offset of BufferDescriptor can also be used to express a batching offset if the data buffer is combined across multiple objects together.

│ │ │ │
    │ │ │ │
  • Note that each element has the same data type (float)
  • │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 61 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 61 of file bufferDescriptor.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ BufferDescriptor() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

│ │ │ │ Public Member Functions

 BufferDescriptor ()
 Default Constructor.
 
 BufferDescriptor (int o, int l, int s)
│ │ │ │ @@ -170,15 +170,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

Default Constructor.

│ │ │ │ │ │ │ │ -

Definition at line 64 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 64 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ BufferDescriptor() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -216,15 +216,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Constructor.

│ │ │ │ │ │ │ │ -

Definition at line 67 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 67 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetLocalOffset()

│ │ │ │ │ │ │ │ @@ -246,15 +246,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the relative offset within a stride.

│ │ │ │ │ │ │ │ -

Definition at line 70 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 70 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsValid()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -275,15 +275,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

True if the descriptor values are internally consistent.

│ │ │ │ │ │ │ │ -

Definition at line 75 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 75 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ operator!=()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -305,15 +305,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

True if the descriptors are not identical.

│ │ │ │ │ │ │ │ -

Definition at line 93 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 93 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ operator==()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -335,15 +335,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

True if the descriptors are identical.

│ │ │ │ │ │ │ │ -

Definition at line 86 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 86 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Reset()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -364,15 +364,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Resets the descriptor to default.

│ │ │ │ │ │ │ │ -

Definition at line 81 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 81 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ length

│ │ │ │ │ │ │ │ @@ -383,15 +383,15 @@ │ │ │ │ int length │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

number or length of the data

│ │ │ │ │ │ │ │ -

Definition at line 100 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 100 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ offset

│ │ │ │ │ │ │ │
│ │ │ │ @@ -401,15 +401,15 @@ │ │ │ │ int offset │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

offset to desired element data

│ │ │ │ │ │ │ │ -

Definition at line 98 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 98 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ stride

│ │ │ │ │ │ │ │
│ │ │ │ @@ -419,20 +419,20 @@ │ │ │ │ int stride │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

stride to the next element

│ │ │ │ │ │ │ │ -

Definition at line 102 of file bufferDescriptor.h.

│ │ │ │ +

Definition at line 102 of file bufferDescriptor.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Concrete vertex buffer class for Cpu subdivision and DirectX drawing. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <cpuD3D11VertexBuffer.h>

│ │ │ │ +

#include <cpuD3D11VertexBuffer.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -143,15 +143,15 @@ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

virtual ~CpuD3D11VertexBuffer ()
 Destructor.
 
void UpdateData (const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
 
│ │ │ │

Detailed Description

│ │ │ │

Concrete vertex buffer class for Cpu subdivision and DirectX drawing.

│ │ │ │

CpuD3D11VertexBuffer implements CpuVertexBufferInterface and D3D11VertexBufferInterface.

│ │ │ │

An instance of this buffer class can be passed to CpuEvaluator.

│ │ │ │ │ │ │ │ -

Definition at line 48 of file cpuD3D11VertexBuffer.h.

│ │ │ │ +

Definition at line 48 of file cpuD3D11VertexBuffer.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ ~CpuD3D11VertexBuffer()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -302,15 +302,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

Returns the D3D11 buffer object (for Osd::Mesh interface)

│ │ │ │ │ │ │ │ -

Definition at line 75 of file cpuD3D11VertexBuffer.h.

│ │ │ │ +

Definition at line 75 of file cpuD3D11VertexBuffer.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Create()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -430,15 +430,15 @@ │ │ │ │ │ │ │ │
│ │ │ │

This method is meant to be used in client code in order to provide coarse vertices data to Osd.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <cpuEvaluator.h>

│ │ │ │ +

#include <cpuEvaluator.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -170,15 +170,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Static Public Member Functions

template<typename SRC_BUFFER , typename DST_BUFFER , typename STENCIL_TABLE >
static bool EvalStencils (SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, const CpuEvaluator *instance=NULL, void *deviceContext=NULL)
 Generic static eval stencils function. This function has a same signature as other device kernels have so that it can be called in the same way from OsdMesh template interface.
 
 
static void Synchronize (void *)
 synchronize all asynchronous computation invoked on this device.
 
│ │ │ │

Detailed Description

│ │ │ │
│ │ │ │ -

Definition at line 39 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 39 of file cpuEvaluator.h.

│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ EvalPatches() [1/6]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -716,15 +716,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch
instancenot used in the cpu evaluator
deviceContextnot used in the cpu evaluator
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 607 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 607 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ EvalPatches() [5/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -842,15 +842,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 517 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 517 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ EvalPatches() [6/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -943,15 +943,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 454 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 454 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1118,15 +1118,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1188 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 1188 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1251,15 +1251,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1100 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 1100 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1356,15 +1356,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1034 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 1034 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1524,15 +1524,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 971 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 971 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1650,15 +1650,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 886 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 886 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1748,15 +1748,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 823 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 823 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [1/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2352,15 +2352,15 @@ │ │ │ │ stencilTableFar::StencilTable or equivalent │ │ │ │ instancenot used in the cpu kernel (declared as a typed pointer to prevent undesirable template resolution) │ │ │ │ deviceContextnot used in the cpu kernel │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 303 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 303 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [5/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2464,15 +2464,15 @@ │ │ │ │ stencilTableFar::StencilTable or equivalent │ │ │ │ instancenot used in the cpu kernel (declared as a typed pointer to prevent undesirable template resolution) │ │ │ │ deviceContextnot used in the cpu kernel │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 168 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 168 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [6/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2551,15 +2551,15 @@ │ │ │ │ stencilTableFar::StencilTable or equivalent │ │ │ │ instancenot used in the cpu kernel (declared as a typed pointer to prevent undesirable template resolution) │ │ │ │ deviceContextnot used in the cpu kernel │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 72 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 72 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Synchronize()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2584,20 +2584,20 @@ │ │ │ │
│ │ │ │ │ │ │ │

synchronize all asynchronous computation invoked on this device.

│ │ │ │
│ │ │ │

Other methods

│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 1227 of file cpuEvaluator.h.

│ │ │ │ +

Definition at line 1227 of file cpuEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Concrete vertex buffer class for CPU subdivision. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <cpuVertexBuffer.h>

│ │ │ │ +

#include <cpuVertexBuffer.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -134,15 +134,15 @@ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 ~CpuVertexBuffer ()
 Destructor.
 
void UpdateData (const float *src, int startVertex, int numVertices, void *deviceContext=NULL)
 Constructor.
 
│ │ │ │

Detailed Description

│ │ │ │

Concrete vertex buffer class for CPU subdivision.

│ │ │ │

CpuVertexBuffer implements the VertexBufferInterface. An instance of this buffer class can be passed to CpuEvaluator

│ │ │ │ │ │ │ │ -

Definition at line 42 of file cpuVertexBuffer.h.

│ │ │ │ +

Definition at line 42 of file cpuVertexBuffer.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ ~CpuVertexBuffer()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -337,15 +337,15 @@ │ │ │ │
│ │ │ │
│ │ │ │

This method is meant to be used in client code in order to provide coarse vertices data to Osd.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

CUDA patch table. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <cudaPatchTable.h>

│ │ │ │ +

#include <cudaPatchTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for CudaPatchTable:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ @@ -178,15 +178,15 @@ │ │ │ │ │ │ │ │
 
│ │ │ │

Detailed Description

│ │ │ │

CUDA patch table.

│ │ │ │

This class is a cuda buffer representation of Far::PatchTable.

│ │ │ │

CudaEvaluator consumes this table to evaluate on the patches.

│ │ │ │ │ │ │ │ -

Definition at line 51 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 51 of file cudaPatchTable.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ ~CudaPatchTable()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -315,15 +315,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

Returns the cuda memory of the array of Osd::PatchArray buffer.

│ │ │ │ │ │ │ │ -

Definition at line 81 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 81 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetFVarPatchIndexBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -345,15 +345,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the cuda memory of the array of face-varying control vertices.

│ │ │ │ │ │ │ │ -

Definition at line 86 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 86 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetFVarPatchParamBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -375,15 +375,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the cuda memory of the array of face-varying param.

│ │ │ │ │ │ │ │ -

Definition at line 91 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 91 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFVarChannels()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -404,15 +404,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the number of face-varying channels buffers.

│ │ │ │ │ │ │ │ -

Definition at line 78 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 78 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetPatchArrayBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -433,15 +433,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the cuda memory of the array of Osd::PatchArray buffer.

│ │ │ │ │ │ │ │ -

Definition at line 60 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 60 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetPatchIndexBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -462,15 +462,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the cuda memory of the patch control vertices.

│ │ │ │ │ │ │ │ -

Definition at line 63 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 63 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetPatchParamBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -491,15 +491,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the cuda memory of the array of Osd::PatchParam buffer.

│ │ │ │ │ │ │ │ -

Definition at line 66 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 66 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVaryingPatchArrayBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -520,15 +520,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the cuda memory of the array of Osd::PatchArray buffer.

│ │ │ │ │ │ │ │ -

Definition at line 69 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 69 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVaryingPatchIndexBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -549,15 +549,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Returns the cuda memory of the array of varying control vertices.

│ │ │ │ │ │ │ │ -

Definition at line 73 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 73 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ _fvarIndexBuffers

│ │ │ │ │ │ │ │ @@ -574,15 +574,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 108 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 108 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _fvarParamBuffers

│ │ │ │ │ │ │ │
│ │ │ │ @@ -598,15 +598,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 109 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 109 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _fvarPatchArrays

│ │ │ │ │ │ │ │
│ │ │ │ @@ -622,15 +622,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 107 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 107 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _indexBuffer

│ │ │ │ │ │ │ │
│ │ │ │ @@ -646,15 +646,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 101 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 101 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _patchArrays

│ │ │ │ │ │ │ │
│ │ │ │ @@ -670,15 +670,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 100 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 100 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _patchParamBuffer

│ │ │ │ │ │ │ │
│ │ │ │ @@ -694,15 +694,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 102 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 102 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _varyingIndexBuffer

│ │ │ │ │ │ │ │
│ │ │ │ @@ -718,15 +718,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 105 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 105 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ _varyingPatchArrays

│ │ │ │ │ │ │ │
│ │ │ │ @@ -742,20 +742,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ protected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 104 of file cudaPatchTable.h.

│ │ │ │ +

Definition at line 104 of file cudaPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

D3D11 stencil table. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <d3d11ComputeEvaluator.h>

│ │ │ │ +

#include <d3d11ComputeEvaluator.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -130,15 +130,15 @@ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 D3D11StencilTable (Far::StencilTable const *stencilTable, ID3D11DeviceContext *deviceContext)
 
 ~D3D11StencilTable ()
 
 
│ │ │ │

Detailed Description

│ │ │ │

D3D11 stencil table.

│ │ │ │

This class is a D3D11 Shader Resource View representation of Far::StencilTable.

│ │ │ │

D3D11ComputeEvaluator consumes this table to apply stencils

│ │ │ │ │ │ │ │ -

Definition at line 56 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 56 of file d3d11ComputeEvaluator.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ D3D11StencilTable()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -214,15 +214,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inlinestatic
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 59 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 59 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Create() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -252,15 +252,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 64 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 64 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetIndicesSRV()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -279,15 +279,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 77 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 77 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumStencils()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -306,15 +306,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 79 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 79 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetOffsetsSRV()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -333,15 +333,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 76 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 76 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetSizesSRV()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -360,15 +360,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 75 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 75 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetWeightsSRV()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -387,20 +387,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 78 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 78 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
D3D11ComputeEvaluator Class Reference
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <d3d11ComputeEvaluator.h>

│ │ │ │ +

#include <d3d11ComputeEvaluator.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Types

typedef bool Instantiatable
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ @@ -136,29 +136,29 @@ │ │ │ │

 
static void Synchronize (ID3D11DeviceContext *deviceContext)
 Wait the dispatched kernel finishes.
 
│ │ │ │

Detailed Description

│ │ │ │
│ │ │ │ -

Definition at line 96 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 96 of file d3d11ComputeEvaluator.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ Instantiatable

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
typedef bool Instantiatable
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 98 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 98 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ D3D11ComputeEvaluator()

│ │ │ │ │ │ │ │ @@ -519,15 +519,15 @@ │ │ │ │ stencilTablestencil table to be applied. The table must have SSBO interfaces. │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ deviceContextID3D11DeviceContext. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 148 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 148 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -584,15 +584,15 @@ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Dispatch the DX compute kernel on GPU asynchronously. returns false if the kernel hasn't been compiled yet.

│ │ │ │ │ │ │ │ -

Definition at line 181 of file d3d11ComputeEvaluator.h.

│ │ │ │ +

Definition at line 181 of file d3d11ComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Synchronize()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -617,15 +617,15 @@ │ │ │ │
│ │ │ │ │ │ │ │

Wait the dispatched kernel finishes.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
MTLStencilTable Class Reference
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <mtlComputeEvaluator.h>

│ │ │ │ +

#include <mtlComputeEvaluator.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -134,15 +134,15 @@ │ │ │ │ Static Public Member Functions │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

 MTLStencilTable (Far::StencilTable const *stencilTable, MTLContext *context)
 
 MTLStencilTable (Far::LimitStencilTable const *stencilTable, MTLContext *context)
 
template<typename STENCIL_TABLE , typename DEVICE_CONTEXT >
static MTLStencilTableCreate (STENCIL_TABLE *stencilTable, DEVICE_CONTEXT context)
 
│ │ │ │

Detailed Description

│ │ │ │
│ │ │ │ -

Definition at line 50 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 50 of file mtlComputeEvaluator.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ MTLStencilTable() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -246,15 +246,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inlinestatic
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 54 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 54 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDuuWeightsBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -273,15 +273,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 71 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 71 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetDuvWeightsBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -300,15 +300,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 72 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 72 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetDuWeightsBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -327,15 +327,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 69 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 69 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetDvvWeightsBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -354,15 +354,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 73 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 73 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetDvWeightsBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -381,15 +381,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 70 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 70 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetIndicesBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -408,15 +408,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 67 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 67 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumStencils()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -435,15 +435,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 75 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 75 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetOffsetsBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -462,15 +462,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 66 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 66 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetSizesBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -489,15 +489,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 65 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 65 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetWeightsBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -516,20 +516,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 68 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 68 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
MTLComputeEvaluator Class Reference
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <mtlComputeEvaluator.h>

│ │ │ │ +

#include <mtlComputeEvaluator.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Types

typedef bool Instantiatable
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ @@ -231,29 +231,29 @@ │ │ │ │

 
static void Synchronize (MTLContext *context)
 Wait for the dispatched kernel to finish.
 
│ │ │ │

Detailed Description

│ │ │ │
│ │ │ │ -

Definition at line 91 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 91 of file mtlComputeEvaluator.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ Instantiatable

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
typedef bool Instantiatable
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 94 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 94 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ MTLComputeEvaluator()

│ │ │ │ │ │ │ │ @@ -877,15 +877,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 889 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 889 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatches() [4/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1038,15 +1038,15 @@ │ │ │ │ patchCoordsarray of locations to be evaluated. │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1104 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1104 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatches() [5/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1164,15 +1164,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 786 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 786 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatches() [6/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1283,15 +1283,15 @@ │ │ │ │ patchCoordsarray of locations to be evaluated. │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1025 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1025 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatches() [7/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1384,15 +1384,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 705 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 705 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatches() [8/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1475,15 +1475,15 @@ │ │ │ │ patchCoordsarray of locations to be evaluated. must have BindVBO() method returning an array of PatchCoord struct in VBO. │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 966 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 966 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [1/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1650,15 +1650,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1991 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1991 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [2/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1818,15 +1818,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ fvarChannelface-varying channel │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 2106 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 2106 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [3/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1951,15 +1951,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1813 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1813 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [4/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2077,15 +2077,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ fvarChannelface-varying channel │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1900 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1900 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [5/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2182,15 +2182,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1672 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1672 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [6/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2280,15 +2280,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ fvarChannelface-varying channel │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1742 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1742 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [1/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2448,15 +2448,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1496 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1496 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [2/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2609,15 +2609,15 @@ │ │ │ │ patchCoordsarray of locations to be evaluated. must have BindVBO() method returning an array of PatchCoord struct in VBO. │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1606 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1606 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [3/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2735,15 +2735,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1325 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1325 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [4/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2854,15 +2854,15 @@ │ │ │ │ patchCoordsarray of locations to be evaluated. must have BindVBO() method returning an array of PatchCoord struct in VBO. │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1407 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1407 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [5/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2952,15 +2952,15 @@ │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1192 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1192 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [6/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -3043,15 +3043,15 @@ │ │ │ │ patchCoordsarray of locations to be evaluated. must have BindVBO() method returning an array of PatchCoord struct in VBO. │ │ │ │ patchTableMTLPatchTable or equivalent │ │ │ │ deviceContextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1257 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 1257 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [1/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -3544,15 +3544,15 @@ │ │ │ │ stencilTablestencil table to be applied. The table must have MTLBuffer interfaces. │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 312 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 312 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [4/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -3691,15 +3691,15 @@ │ │ │ │ dvvDescvertex buffer descriptor for the dvvBuffer │ │ │ │ stencilTablestencil table to be applied. The table must have MTLBuffer interfaces. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 504 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 504 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [5/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -3803,15 +3803,15 @@ │ │ │ │ stencilTablestencil table to be applied. The table must have MTLBuffer interfaces. │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 220 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 220 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [6/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -3908,15 +3908,15 @@ │ │ │ │ dvDescvertex buffer descriptor for the dvBuffer │ │ │ │ stencilTablestencil table to be applied. The table must have MTLBuffer interfaces. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 430 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 430 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [7/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -3995,15 +3995,15 @@ │ │ │ │ stencilTablestencil table to be applied. The table must have MTLBuffer interfaces. │ │ │ │ instancecached compiled instance. Clients are supposed to pre-compile an instance of this class and provide to this function. If it's null the kernel still compute by instantiating on-demand kernel although it may cause a performance problem. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 149 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 149 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [8/8]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -4072,15 +4072,15 @@ │ │ │ │ dstDescvertex buffer descriptor for the output buffer │ │ │ │ stencilTablestencil table to be applied. The table must have MTLBuffer interfaces. │ │ │ │ contextused to obtain the MTLDevice object and command queue to obtain command buffers from. │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 376 of file mtlComputeEvaluator.h.

│ │ │ │ +

Definition at line 376 of file mtlComputeEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Synchronize()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -4105,15 +4105,15 @@ │ │ │ │
│ │ │ │ │ │ │ │

Wait for the dispatched kernel to finish.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
MTLLegacyGregoryPatchTable Class Reference
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <mtlLegacyGregoryPatchTable.h>

│ │ │ │ +

#include <mtlLegacyGregoryPatchTable.h>

│ │ │ │
│ │ │ │ Inheritance diagram for MTLLegacyGregoryPatchTable:
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ @@ -128,15 +128,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
static MTLLegacyGregoryPatchTableCreate (Far::PatchTable const *farPatchTable, DEVICE_CONTEXT context)
 
static MTLLegacyGregoryPatchTableCreate (Far::PatchTable const *farPatchTable, MTLContext *context)
 
│ │ │ │

Detailed Description

│ │ │ │
│ │ │ │ -

Definition at line 41 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ +

Definition at line 41 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ ~MTLLegacyGregoryPatchTable()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -184,15 +184,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inlinestatic
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 48 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ +

Definition at line 48 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Create() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -248,15 +248,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 71 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ +

Definition at line 71 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetQuadOffsetsBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -275,15 +275,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 66 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ +

Definition at line 66 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -302,15 +302,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 56 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ +

Definition at line 56 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVertexValenceBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -329,15 +329,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 61 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ +

Definition at line 61 of file mtlLegacyGregoryPatchTable.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ UpdateVertexBuffer()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -374,15 +374,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Provides shader source which can be used by client code. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <mtlPatchShaderSource.h>

│ │ │ │ +

#include <mtlPatchShaderSource.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -129,15 +129,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Static Public Member Functions

static std::string GetPatchBasisShaderSource ()
 Returns shader source which can be used to evaluate position and first and second derivatives on piecewise parametric patches resulting from subdivision refinement.
 
static std::string GetPatchDrawingShaderSource ()
 
static std::string GetDomainShaderSource (Far::PatchDescriptor::Type type, Far::PatchDescriptor::Type fvarType)
 
│ │ │ │

Detailed Description

│ │ │ │

Provides shader source which can be used by client code.

│ │ │ │ │ │ │ │ -

Definition at line 40 of file mtlPatchShaderSource.h.

│ │ │ │ +

Definition at line 40 of file mtlPatchShaderSource.h.

│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetCommonShaderSource()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -400,15 +400,15 @@ │ │ │ │ │ │ │ │

Deprecated.

│ │ │ │

These methods are deprecated. Clients should determine the patch type of a face-varying patch by inspecting the face-varying patch array descriptors.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
CPUMTLVertexBuffer Class Reference
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <mtlVertexBuffer.h>

│ │ │ │ +

#include <mtlVertexBuffer.h>

│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -127,15 +127,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Member Functions

void UpdateData (const float *src, int startVertex, int numVertices, MTLContext *context)
 
int GetNumElements () const
 
 CPUMTLVertexBuffer (int numElements, int numVertices)
 
bool allocate (MTLContext *context)
 
│ │ │ │

Detailed Description

│ │ │ │
│ │ │ │ -

Definition at line 39 of file mtlVertexBuffer.h.

│ │ │ │ +

Definition at line 39 of file mtlVertexBuffer.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ CPUMTLVertexBuffer()

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -251,15 +251,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ inline
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 58 of file mtlVertexBuffer.h.

│ │ │ │ +

Definition at line 58 of file mtlVertexBuffer.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ Create()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -320,15 +320,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 45 of file mtlVertexBuffer.h.

│ │ │ │ +

Definition at line 45 of file mtlVertexBuffer.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ GetNumVertices()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -347,15 +347,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 50 of file mtlVertexBuffer.h.

│ │ │ │ +

Definition at line 50 of file mtlVertexBuffer.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ UpdateData()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -392,15 +392,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <tbbEvaluator.h>

│ │ │ │ +

#include <tbbEvaluator.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ @@ -173,15 +173,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Static Public Member Functions

template<typename SRC_BUFFER , typename DST_BUFFER , typename STENCIL_TABLE >
static bool EvalStencils (SRC_BUFFER *srcBuffer, BufferDescriptor const &srcDesc, DST_BUFFER *dstBuffer, BufferDescriptor const &dstDesc, STENCIL_TABLE const *stencilTable, TbbEvaluator const *instance=NULL, void *deviceContext=NULL)
 Generic static eval stencils function. This function has a same signature as other device kernels have so that it can be called in the same way from OsdMesh template interface.
 
 
static void SetNumThreads (int numThreads)
 Deprecated. Client code should initialize TBB.
 
│ │ │ │

Detailed Description

│ │ │ │
│ │ │ │ -

Definition at line 39 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 39 of file tbbEvaluator.h.

│ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ EvalPatches() [1/6]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -719,15 +719,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch
instancenot used in the cpu evaluator
deviceContextnot used in the cpu evaluator
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 607 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 607 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ EvalPatches() [5/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -845,15 +845,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 517 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 517 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ EvalPatches() [6/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -946,15 +946,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 454 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 454 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1121,15 +1121,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1188 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 1188 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1254,15 +1254,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1100 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 1100 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesFaceVarying() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1359,15 +1359,15 @@ │ │ │ │ fvarChannelface-varying channel │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 1034 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 1034 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1527,15 +1527,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 971 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 971 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [2/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1653,15 +1653,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 886 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 886 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalPatchesVarying() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1751,15 +1751,15 @@ │ │ │ │ patchTableCpuPatchTable or equivalent XXX: currently Far::PatchTable can't be used due to interface mismatch │ │ │ │ instancenot used in the cpu evaluator │ │ │ │ deviceContextnot used in the cpu evaluator │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 823 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 823 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [1/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2355,15 +2355,15 @@ │ │ │ │ stencilTableFar::StencilTable or equivalent │ │ │ │ instancenot used in the tbb kernel (declared as a typed pointer to prevent undesirable template resolution) │ │ │ │ deviceContextnot used in the tbb kernel │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 303 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 303 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [5/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2467,15 +2467,15 @@ │ │ │ │ stencilTableFar::StencilTable or equivalent │ │ │ │ instancenot used in the tbb kernel (declared as a typed pointer to prevent undesirable template resolution) │ │ │ │ deviceContextnot used in the tbb kernel │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 168 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 168 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EvalStencils() [6/6]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2554,15 +2554,15 @@ │ │ │ │ stencilTableFar::StencilTable or equivalent │ │ │ │ instancenot used in the tbb kernel (declared as a typed pointer to prevent undesirable template resolution) │ │ │ │ deviceContextnot used in the tbb kernel │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 72 of file tbbEvaluator.h.

│ │ │ │ +

Definition at line 72 of file tbbEvaluator.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetNumThreads()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2624,15 +2624,15 @@ │ │ │ │
│ │ │ │

Other methods

│ │ │ │
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Types, constants and utilities related to semi-sharp creasing – whose implementation is independent of the subdivision scheme. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <crease.h>

│ │ │ │ +

#include <crease.h>

│ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Types

enum  Rule {
│ │ │ │   RULE_UNKNOWN = 0 │ │ │ │ ,
│ │ │ │   RULE_SMOOTH = (1 << 0) │ │ │ │ @@ -180,15 +180,15 @@ │ │ │ │
│ │ │ │

Detailed Description

│ │ │ │

Types, constants and utilities related to semi-sharp creasing – whose implementation is independent of the subdivision scheme.

│ │ │ │

Crease is intended to be a light-weight, trivially constructed class that computes crease-related properties – typically sharpness values and associated interpolation weights. An instance of Crease is defined with a set of options that include current and future variations that will impact computations involving sharpness values.

│ │ │ │

The Crease methods do not use topological neighborhoods as input. The methods here rely more on the sharpness values and less on the topology, so we choose to work directly with the sharpness values. We also follow the trend of using primitive arrays in the interface to encourage local gathering for re-use.

│ │ │ │

Note on the need for and use of sharpness values: In general, mask queries rely on the sharpness values. The common case of a smooth vertex, when known, avoids the need to inspect them, but unless the rules are well understood, users will be expected to provided them – particularly when they expect the mask queries to do all of the work (just determining if a vertex is smooth will require inspection of incident edge sharpness). Mask queries will occasionally require the subdivided sharpness values around the child vertex. So users will be expected to either provide them up front when known, or to be gathered on demand. Any implementation of subdivision with creasing cannot avoid subdividing the sharpness values first, so keeping them available for re-use is a worthwhile consideration.

│ │ │ │ │ │ │ │ -

Definition at line 62 of file crease.h.

│ │ │ │ +

Definition at line 62 of file crease.h.

│ │ │ │

Member Enumeration Documentation

│ │ │ │ │ │ │ │

◆ Rule

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -202,15 +202,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
Enumerator
RULE_UNKNOWN 
RULE_SMOOTH 
RULE_DART 
RULE_CREASE 
RULE_CORNER 
│ │ │ │ │ │ │ │ -

Definition at line 82 of file crease.h.

│ │ │ │ +

Definition at line 82 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Crease() [1/2]

│ │ │ │ │ │ │ │ @@ -230,15 +230,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 91 of file crease.h.

│ │ │ │ +

Definition at line 91 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Crease() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -258,15 +258,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 92 of file crease.h.

│ │ │ │ +

Definition at line 92 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ~Crease()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -285,15 +285,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 93 of file crease.h.

│ │ │ │ +

Definition at line 93 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ ComputeFractionalWeightAtVertex()

│ │ │ │ │ │ │ │ @@ -362,15 +362,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 207 of file crease.h.

│ │ │ │ +

Definition at line 207 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ DetermineVertexVertexRule() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -469,15 +469,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 228 of file crease.h.

│ │ │ │ +

Definition at line 228 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsInfinite()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -497,15 +497,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 72 of file crease.h.

│ │ │ │ +

Definition at line 72 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsSemiSharp()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -525,15 +525,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 73 of file crease.h.

│ │ │ │ +

Definition at line 73 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsSharp()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -553,15 +553,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 71 of file crease.h.

│ │ │ │ +

Definition at line 71 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsSmooth()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -581,15 +581,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlinestatic │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 70 of file crease.h.

│ │ │ │ +

Definition at line 70 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ IsUniform()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -608,15 +608,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 95 of file crease.h.

│ │ │ │ +

Definition at line 95 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SharpenBoundaryEdge()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -637,15 +637,15 @@ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Optional sharp features: Since options treat certain topological features as infinitely sharp – boundaries or (in future) non-manifold features – sharpness values should be adjusted before use. The following methods will adjust (by return) specific values according to the options applied.

│ │ │ │ │ │ │ │ -

Definition at line 189 of file crease.h.

│ │ │ │ +

Definition at line 189 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SharpenBoundaryVertex()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -665,15 +665,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 200 of file crease.h.

│ │ │ │ +

Definition at line 200 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SubdivideEdgeSharpnessAtVertex()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -766,15 +766,15 @@ │ │ │ │
│ │ │ │

Sharpness subdivision: The computation of a Uniform subdivided sharpness value is as follows:

    │ │ │ │
  • Smooth edges or verts stay Smooth
  • │ │ │ │
  • Sharp edges or verts stay Sharp
  • │ │ │ │
  • semi-sharp edges or verts are decremented by 1.0 but for Chaikin (and potentially future non-uniform schemes that improve upon it) the computation is more involved. In the case of edges in particular, the sharpness of a child edge is determined by the sharpness in the neighborhood of the end vertex corresponding to the child. For this reason, an alternative to subdividing sharpness that computes all child edges around a vertex is given.
  • │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 216 of file crease.h.

│ │ │ │ +

Definition at line 216 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SubdivideVertexSharpness()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -794,15 +794,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 222 of file crease.h.

│ │ │ │ +

Definition at line 222 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Data Documentation

│ │ │ │ │ │ │ │

◆ SHARPNESS_INFINITE

│ │ │ │ │ │ │ │ @@ -819,15 +819,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ static │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 68 of file crease.h.

│ │ │ │ +

Definition at line 68 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SHARPNESS_SMOOTH

│ │ │ │ │ │ │ │
│ │ │ │ @@ -844,20 +844,20 @@ │ │ │ │ │ │ │ │ static │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │

Constants and related queries of sharpness values:

│ │ │ │ │ │ │ │ -

Definition at line 67 of file crease.h.

│ │ │ │ +

Definition at line 67 of file crease.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file:
    │ │ │ │ -
  • opensubdiv/sdc/crease.h
  • │ │ │ │ +
  • opensubdiv/sdc/crease.h
  • │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

All supported options applying to subdivision scheme. │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <options.h>

│ │ │ │ +

#include <options.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Types

enum  VtxBoundaryInterpolation {
│ │ │ │   VTX_BOUNDARY_NONE = 0 │ │ │ │ ,
│ │ │ │   VTX_BOUNDARY_EDGE_ONLY │ │ │ │ @@ -175,15 +175,15 @@ │ │ │ │
 
│ │ │ │

Detailed Description

│ │ │ │

All supported options applying to subdivision scheme.

│ │ │ │

The Options class contains all supported options that can be applied to a subdivision scheme to affect the shape of the limit surface. These differ from approximations that may be applied at a higher level, i.e. options to limit the level of feature adaptive subdivision, options to ignore fractional creasing, or creasing entirely, etc. These options define the shape of a particular limit surface, including the "shape" of primitive variable data associated with it.

│ │ │ │

The intent is that these sets of options be defined at a high level and propagated into the lowest-level computation in support of each subdivision scheme. Ideally it remains a set of bit-fields (essentially an int) and so remains light weight and easily passed around by value.

│ │ │ │ │ │ │ │ -

Definition at line 51 of file options.h.

│ │ │ │ +

Definition at line 51 of file options.h.

│ │ │ │

Member Enumeration Documentation

│ │ │ │ │ │ │ │

◆ CreasingMethod

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ @@ -195,15 +195,15 @@ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │
Enumerator
CREASE_UNIFORM 

Catmark rule.

│ │ │ │
CREASE_CHAIKIN 

Chaikin rule.

│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 68 of file options.h.

│ │ │ │ +

Definition at line 68 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ FVarLinearInterpolation

│ │ │ │ │ │ │ │
│ │ │ │ @@ -225,15 +225,15 @@ │ │ │ │ │ │ │ │ FVAR_LINEAR_BOUNDARIES 

sharpen all boundaries ("always sharp")

│ │ │ │ │ │ │ │ FVAR_LINEAR_ALL 

bilinear interpolation ("bilinear")

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 60 of file options.h.

│ │ │ │ +

Definition at line 60 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ TriangleSubdivision

│ │ │ │ │ │ │ │
│ │ │ │ @@ -247,15 +247,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
Enumerator
TRI_SUB_CATMARK 

Catmark weights (Catmark scheme only)

│ │ │ │
TRI_SUB_SMOOTH 

"smooth triangle" weights (Catmark scheme only)

│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 72 of file options.h.

│ │ │ │ +

Definition at line 72 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ VtxBoundaryInterpolation

│ │ │ │ │ │ │ │
│ │ │ │ @@ -271,15 +271,15 @@ │ │ │ │ │ │ │ │ VTX_BOUNDARY_EDGE_ONLY 

all boundary edges sharpened and interpolated

│ │ │ │ │ │ │ │ VTX_BOUNDARY_EDGE_AND_CORNER 

all boundary edges and corner vertices sharpened and interpolated

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ -

Definition at line 53 of file options.h.

│ │ │ │ +

Definition at line 53 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Options()

│ │ │ │ │ │ │ │ @@ -299,15 +299,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 79 of file options.h.

│ │ │ │ +

Definition at line 79 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ GetCreasingMethod()

│ │ │ │ │ │ │ │ @@ -329,15 +329,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Get edge crease rule.

│ │ │ │ │ │ │ │ -

Definition at line 101 of file options.h.

│ │ │ │ +

Definition at line 101 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetFVarLinearInterpolation()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -358,15 +358,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Get face-varying interpolation rule.

│ │ │ │ │ │ │ │ -

Definition at line 95 of file options.h.

│ │ │ │ +

Definition at line 95 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetTriangleSubdivision()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -387,15 +387,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Get triangle subdivision weights rule (Catmark scheme only !)

│ │ │ │ │ │ │ │ -

Definition at line 107 of file options.h.

│ │ │ │ +

Definition at line 107 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetVtxBoundaryInterpolation()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -416,15 +416,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Get vertex boundary interpolation rule.

│ │ │ │ │ │ │ │ -

Definition at line 89 of file options.h.

│ │ │ │ +

Definition at line 89 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetCreasingMethod()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -446,15 +446,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set edge crease rule.

│ │ │ │ │ │ │ │ -

Definition at line 104 of file options.h.

│ │ │ │ +

Definition at line 104 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetFVarLinearInterpolation()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -476,15 +476,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set face-varying interpolation rule.

│ │ │ │ │ │ │ │ -

Definition at line 98 of file options.h.

│ │ │ │ +

Definition at line 98 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetTriangleSubdivision()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -506,15 +506,15 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set triangle subdivision weights rule (Catmark scheme only !)

│ │ │ │ │ │ │ │ -

Definition at line 110 of file options.h.

│ │ │ │ +

Definition at line 110 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetVtxBoundaryInterpolation()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -536,20 +536,20 @@ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Set vertex boundary interpolation rule.

│ │ │ │ │ │ │ │ -

Definition at line 92 of file options.h.

│ │ │ │ +

Definition at line 92 of file options.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file:
    │ │ │ │ -
  • opensubdiv/sdc/options.h
  • │ │ │ │ +
  • opensubdiv/sdc/options.h
  • │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Scheme is a class template which provides all implementation for the subdivision schemes supported by OpenSubdiv through specializations of the methods of each. An instance of Scheme<SCHEME_TYPE> includes a set of Options that will dictate the variable aspects of its behavior.
│ │ │ │ │ │ │ │ More...

│ │ │ │ │ │ │ │ -

#include <scheme.h>

│ │ │ │ +

#include <scheme.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Classes

class  LocalMask
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ @@ -273,15 +273,15 @@ │ │ │ │
template<SchemeType SCHEME_TYPE>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Scheme< SCHEME_TYPE >

Scheme is a class template which provides all implementation for the subdivision schemes supported by OpenSubdiv through specializations of the methods of each. An instance of Scheme<SCHEME_TYPE> includes a set of Options that will dictate the variable aspects of its behavior.
│ │ │ │

│ │ │ │

The primary purpose of Scheme is to provide the mask weights for vertices generated by subdivision. Methods to determine the masks are given topological neighborhoods from which to compute the appropriate weights for neighboring components. While these neighborhoods may require sharpness values for creasing, the computation of subdivided crease values is independent of the scheme type and is also made available through the Crease class.

│ │ │ │

Mask queries are assisted by two utility classes – a Neighborhood class defining the set of relevant data in the topological neighborhood of the vertex being subdivided, and a Mask class into which the associated mask weights will be stored. Depending on where and how these queries are used, more or less information may be available. See the details of the Neighborhood classes as appropriate initialization of them is critical. It is generally best to initialize them with what data is known and accessible for immediate and efficient retrieval, but subclasses can be created to gather it lazily if desired.
│ │ │ │

│ │ │ │ │ │ │ │ -

Definition at line 66 of file scheme.h.

│ │ │ │ +

Definition at line 66 of file scheme.h.

│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ Scheme() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -300,15 +300,15 @@ │ │ │ │
│ │ │ │ inline
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 70 of file scheme.h.

│ │ │ │ +

Definition at line 70 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ Scheme() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -330,15 +330,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 72 of file scheme.h.

│ │ │ │ +

Definition at line 72 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ assignCornerLimitMask() [1/4]

│ │ │ │ │ │ │ │ @@ -445,15 +445,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 223 of file loopScheme.h.

│ │ │ │ +

Definition at line 223 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignCornerLimitMask() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -663,15 +663,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 386 of file loopScheme.h.

│ │ │ │ +

Definition at line 386 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignCornerMaskForVertex() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -701,15 +701,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 142 of file loopScheme.h.

│ │ │ │ +

Definition at line 142 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignCornerMaskForVertex() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -743,15 +743,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 331 of file scheme.h.

│ │ │ │ +

Definition at line 331 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignCreaseLimitMask() [1/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -877,15 +877,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 236 of file loopScheme.h.

│ │ │ │ +

Definition at line 236 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignCreaseLimitMask() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1073,15 +1073,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 420 of file loopScheme.h.

│ │ │ │ +

Definition at line 420 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignCreaseLimitTangentMasks() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1161,15 +1161,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 70 of file loopScheme.h.

│ │ │ │ +

Definition at line 70 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignCreaseMaskForEdge() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1203,15 +1203,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 317 of file scheme.h.

│ │ │ │ +

Definition at line 317 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignCreaseMaskForVertex() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1337,15 +1337,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 155 of file loopScheme.h.

│ │ │ │ +

Definition at line 155 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignSmoothLimitMask() [1/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1491,15 +1491,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 273 of file loopScheme.h.

│ │ │ │ +

Definition at line 273 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignSmoothLimitTangentMasks() [1/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1669,15 +1669,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 532 of file loopScheme.h.

│ │ │ │ +

Definition at line 532 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignSmoothMaskForEdge() [1/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1745,15 +1745,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 84 of file loopScheme.h.

│ │ │ │ +

Definition at line 84 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ assignSmoothMaskForEdge() [3/3]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1901,15 +1901,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inlineprotected │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 180 of file loopScheme.h.

│ │ │ │ +

Definition at line 180 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ComputeEdgeVertexMask() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -1992,15 +1992,15 @@ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Edge-vertex masks If known, the Rule for the edge and/or the derived vertex can be specified to accelerate the computation (though the Rule for the parent is trivially determined). In particular, knowing the child rule can avoid the need to subdivide the sharpness of the edge to see if it is a transitional crease that warrants fractional blending.

│ │ │ │

Whether to use the "Rules" in this interface is really debatable – the parent Rule is really based on the edge and its sharpness, while the child Rule is technically based on the neighborhood of the child vertex, but it can be deduced from the two child edges' sharpness. So the Crease methods used to compute these rules differ from those for the vertex-vertex mask. Perhaps a simple pair of new methods for Crease should be added specific to the edge-vertex case, i.e. one that takes a single sharpness (for the parent rule) and one that takes a pair (for the child).

│ │ │ │ │ │ │ │ -

Definition at line 392 of file scheme.h.

│ │ │ │ +

Definition at line 392 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ComputeFaceVertexMask()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2028,15 +2028,15 @@ │ │ │ │ const │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Face-vertex masks - trivial for all current schemes.

│ │ │ │ │ │ │ │ -

Definition at line 348 of file scheme.h.

│ │ │ │ +

Definition at line 348 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ComputeVertexLimitMask() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2072,15 +2072,15 @@ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Limit masks for vertices – position and tangents These presume that a vertex is suitably isolated for its limit to be well-defined and, unlike the refinement masks, the subdivision Rule for the vertex (presumably at its last level of refinement) is required rather than being optional. In the presence of semi-sharp creasing that has not decayed to zero, the limit is neither sharp nor smooth – in such cases the Rule specified by the caller determines the result.

│ │ │ │

For tangent masks, the direction of the first tangent (T1) is oriented towards the leading edge of the vertex, i.e. the first incident edge of the vertex (beginning the set of incident edges in counter-clockwise order). The second tangent (T2) lies within the tangent plane such that its normal can be computed as T1 x T2. So for a boundary vertex, T1 will point along the boundary in the direction of the leading edge while T2 points inward across the limit surface.

│ │ │ │

As for magnitude, no assumptions should be made of the magnitudes of the resulting tangent vectors. Common formulae often factor out scale factors that contribute to magnitude. While some attempt has been made to make magnitudes more consistent between regular corners, boundaries and the interior, the same has not been done at irregular vertices – at least not yet. This may be addressed in future, as having consistent magnitudes returned here can aid in the construction of patches from limit positions and tangents.

│ │ │ │ │ │ │ │ -

Definition at line 607 of file scheme.h.

│ │ │ │ +

Definition at line 607 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ComputeVertexLimitMask() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2124,15 +2124,15 @@ │ │ │ │ │ │ │ │ ) │ │ │ │ const │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 629 of file scheme.h.

│ │ │ │ +

Definition at line 629 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ComputeVertexVertexMask() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2214,15 +2214,15 @@ │ │ │ │ const │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Vertex-vertex masks If known, a single Rule or pair of Rules can be specified (indicating a crease transition) to accelerate the computation. Either no Rules, the first, or both should be specified. Specification of only the first Rule implies it to be true for both (wish the compiler would allow such default value specification), i.e. no transition. The case of knowing the parent Rule but deferring determination of the child Rule to this method is not supported.

│ │ │ │ │ │ │ │ -

Definition at line 512 of file scheme.h.

│ │ │ │ +

Definition at line 512 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetLocalNeighborhoodSize() [1/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2295,15 +2295,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 57 of file loopScheme.h.

│ │ │ │ +

Definition at line 57 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetLocalNeighborhoodSize() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2351,15 +2351,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 74 of file scheme.h.

│ │ │ │ +

Definition at line 74 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetRegularFaceSize() [1/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2432,15 +2432,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 51 of file loopScheme.h.

│ │ │ │ +

Definition at line 51 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetRegularFaceSize() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2540,15 +2540,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 54 of file loopScheme.h.

│ │ │ │ +

Definition at line 54 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetRegularVertexValence() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2648,15 +2648,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 48 of file loopScheme.h.

│ │ │ │ +

Definition at line 48 of file loopScheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetTopologicalSplitType() [4/4]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -2705,20 +2705,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 75 of file scheme.h.

│ │ │ │ +

Definition at line 75 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file:
    │ │ │ │ -
  • opensubdiv/sdc/scheme.h
  • │ │ │ │ +
  • opensubdiv/sdc/scheme.h
  • │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
Scheme< SCHEME_TYPE >::LocalMask< WEIGHT > Class Template Reference
│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

#include <scheme.h>

│ │ │ │ +

#include <scheme.h>

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Public Types

typedef WEIGHT Weight
 
│ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ @@ -144,15 +144,15 @@ │ │ │ │

void CombineVertexVertexMasks (Weight thisCoeff, Weight dstCoeff, USER_MASK &dst) const
 
│ │ │ │

Detailed Description

│ │ │ │
template<SchemeType SCHEME_TYPE>
│ │ │ │ template<typename WEIGHT>
│ │ │ │ class OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Scheme< SCHEME_TYPE >::LocalMask< WEIGHT >
│ │ │ │ -

Definition at line 209 of file scheme.h.

│ │ │ │ +

Definition at line 209 of file scheme.h.

│ │ │ │

Member Typedef Documentation

│ │ │ │ │ │ │ │

◆ Weight

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ @@ -162,15 +162,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
typedef WEIGHT Weight
│ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 212 of file scheme.h.

│ │ │ │ +

Definition at line 212 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │

Constructor & Destructor Documentation

│ │ │ │ │ │ │ │

◆ LocalMask()

│ │ │ │ │ │ │ │ @@ -211,15 +211,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 215 of file scheme.h.

│ │ │ │ +

Definition at line 215 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ ~LocalMask()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -242,15 +242,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 216 of file scheme.h.

│ │ │ │ +

Definition at line 216 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

Member Function Documentation

│ │ │ │ │ │ │ │

◆ AreFaceWeightsForFaceCenters()

│ │ │ │ │ │ │ │ @@ -274,15 +274,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 239 of file scheme.h.

│ │ │ │ +

Definition at line 239 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ CombineVertexVertexMasks()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -324,15 +324,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 249 of file scheme.h.

│ │ │ │ +

Definition at line 249 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EdgeWeight() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -356,15 +356,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 236 of file scheme.h.

│ │ │ │ +

Definition at line 236 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ EdgeWeight() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -388,15 +388,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 232 of file scheme.h.

│ │ │ │ +

Definition at line 232 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ FaceWeight() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -420,15 +420,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 237 of file scheme.h.

│ │ │ │ +

Definition at line 237 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ FaceWeight() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -452,15 +452,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 233 of file scheme.h.

│ │ │ │ +

Definition at line 233 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumEdgeWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -483,15 +483,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 224 of file scheme.h.

│ │ │ │ +

Definition at line 224 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumFaceWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -514,15 +514,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 225 of file scheme.h.

│ │ │ │ +

Definition at line 225 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ GetNumVertexWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -545,15 +545,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 223 of file scheme.h.

│ │ │ │ +

Definition at line 223 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetFaceWeightsForFaceCenters()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -577,15 +577,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 240 of file scheme.h.

│ │ │ │ +

Definition at line 240 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetNumEdgeWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -609,15 +609,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 228 of file scheme.h.

│ │ │ │ +

Definition at line 228 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetNumFaceWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -641,15 +641,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 229 of file scheme.h.

│ │ │ │ +

Definition at line 229 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ SetNumVertexWeights()

│ │ │ │ │ │ │ │
│ │ │ │ @@ -673,15 +673,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 227 of file scheme.h.

│ │ │ │ +

Definition at line 227 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ VertexWeight() [1/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -705,15 +705,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 235 of file scheme.h.

│ │ │ │ +

Definition at line 235 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ VertexWeight() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -737,20 +737,20 @@ │ │ │ │ │ │ │ │ │ │ │ │ inline │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ -

Definition at line 231 of file scheme.h.

│ │ │ │ +

Definition at line 231 of file scheme.h.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │
The documentation for this class was generated from the following file:
    │ │ │ │ -
  • opensubdiv/sdc/scheme.h
  • │ │ │ │ +
  • opensubdiv/sdc/scheme.h
  • │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_2483050b711c1829a6434006d0beb10c.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,42 +1,42 @@ │ │ │ │ │ var dir_2483050b711c1829a6434006d0beb10c = [ │ │ │ │ │ - ["bufferDescriptor.h", "a00896.html", "a00896"], │ │ │ │ │ + ["bufferDescriptor.h", "a00899.html", "a00899"], │ │ │ │ │ ["clEvaluator.h", "a00803.html", "a00803"], │ │ │ │ │ ["clPatchTable.h", "a00800.html", "a00800"], │ │ │ │ │ ["clVertexBuffer.h", "a00797.html", "a00797"], │ │ │ │ │ - ["cpuD3D11VertexBuffer.h", "a00842.html", "a00842"], │ │ │ │ │ - ["cpuEvaluator.h", "a00899.html", "a00899"], │ │ │ │ │ + ["cpuD3D11VertexBuffer.h", "a00845.html", "a00845"], │ │ │ │ │ + ["cpuEvaluator.h", "a00896.html", "a00896"], │ │ │ │ │ ["cpuGLVertexBuffer.h", "a00866.html", "a00866"], │ │ │ │ │ ["cpuPatchTable.h", "a00893.html", "a00893"], │ │ │ │ │ - ["cpuVertexBuffer.h", "a00887.html", "a00887"], │ │ │ │ │ + ["cpuVertexBuffer.h", "a00884.html", "a00884"], │ │ │ │ │ ["cudaEvaluator.h", "a00788.html", "a00788"], │ │ │ │ │ - ["cudaPatchTable.h", "a00794.html", "a00794"], │ │ │ │ │ + ["cudaPatchTable.h", "a00791.html", "a00791"], │ │ │ │ │ ["cudaVertexBuffer.h", "a00902.html", "a00902"], │ │ │ │ │ - ["d3d11ComputeEvaluator.h", "a00845.html", "a00845"], │ │ │ │ │ + ["d3d11ComputeEvaluator.h", "a00842.html", "a00842"], │ │ │ │ │ ["d3d11LegacyGregoryPatchTable.h", "a00839.html", "a00839"], │ │ │ │ │ ["d3d11Mesh.h", "a00830.html", "a00830"], │ │ │ │ │ ["d3d11PatchTable.h", "a00836.html", "a00836"], │ │ │ │ │ ["d3d11VertexBuffer.h", "a00833.html", "a00833"], │ │ │ │ │ ["glComputeEvaluator.h", "a00848.html", "a00848"], │ │ │ │ │ ["glLegacyGregoryPatchTable.h", "a00869.html", "a00869"], │ │ │ │ │ ["glMesh.h", "a00857.html", "a00857"], │ │ │ │ │ ["glPatchTable.h", "a00860.html", "a00860"], │ │ │ │ │ ["glslPatchShaderSource.h", "a00854.html", "a00854"], │ │ │ │ │ ["glVertexBuffer.h", "a00863.html", "a00863"], │ │ │ │ │ ["glXFBEvaluator.h", "a00851.html", "a00851"], │ │ │ │ │ ["hlslPatchShaderSource.h", "a00827.html", "a00827"], │ │ │ │ │ ["mesh.h", "a00890.html", "a00890"], │ │ │ │ │ ["mtlCommon.h", "a00806.html", "a00806"], │ │ │ │ │ - ["mtlComputeEvaluator.h", "a00821.html", "a00821"], │ │ │ │ │ - ["mtlLegacyGregoryPatchTable.h", "a00818.html", "a00818"], │ │ │ │ │ - ["mtlMesh.h", "a00812.html", "a00812"], │ │ │ │ │ - ["mtlPatchShaderSource.h", "a00809.html", "a00809"], │ │ │ │ │ + ["mtlComputeEvaluator.h", "a00824.html", "a00824"], │ │ │ │ │ + ["mtlLegacyGregoryPatchTable.h", "a00821.html", "a00821"], │ │ │ │ │ + ["mtlMesh.h", "a00809.html", "a00809"], │ │ │ │ │ + ["mtlPatchShaderSource.h", "a00812.html", "a00812"], │ │ │ │ │ ["mtlPatchTable.h", "a00815.html", "a00815"], │ │ │ │ │ - ["mtlVertexBuffer.h", "a00824.html", "a00824"], │ │ │ │ │ + ["mtlVertexBuffer.h", "a00818.html", "a00818"], │ │ │ │ │ ["ompEvaluator.h", "a00881.html", "a00881"], │ │ │ │ │ - ["ompKernel.h", "a00875.html", "a00875"], │ │ │ │ │ - ["opencl.h", "a00791.html", null], │ │ │ │ │ - ["opengl.h", "a00884.html", null], │ │ │ │ │ - ["tbbEvaluator.h", "a00878.html", "a00878"], │ │ │ │ │ - ["tbbKernel.h", "a00872.html", "a00872"], │ │ │ │ │ + ["ompKernel.h", "a00872.html", "a00872"], │ │ │ │ │ + ["opencl.h", "a00794.html", null], │ │ │ │ │ + ["opengl.h", "a00887.html", null], │ │ │ │ │ + ["tbbEvaluator.h", "a00875.html", "a00875"], │ │ │ │ │ + ["tbbKernel.h", "a00878.html", "a00878"], │ │ │ │ │ ["types.h", "a01489.html", "a01489"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_7f420b72a822828cfa8b0561c695a5cc.html │ │ │ │ @@ -103,29 +103,29 @@ │ │ │ │   │ │ │ │  patchMap.h │ │ │ │   │ │ │ │  patchParam.h │ │ │ │   │ │ │ │  patchTable.h │ │ │ │   │ │ │ │ - patchTableFactory.h │ │ │ │ + patchTableFactory.h │ │ │ │   │ │ │ │ - primvarRefiner.h │ │ │ │ + primvarRefiner.h │ │ │ │   │ │ │ │  ptexIndices.h │ │ │ │   │ │ │ │ - stencilTable.h │ │ │ │ + stencilTable.h │ │ │ │   │ │ │ │ - stencilTableFactory.h │ │ │ │ + stencilTableFactory.h │ │ │ │   │ │ │ │  topologyDescriptor.h │ │ │ │   │ │ │ │ - topologyLevel.h │ │ │ │ + topologyLevel.h │ │ │ │   │ │ │ │ - topologyRefiner.h │ │ │ │ + topologyRefiner.h │ │ │ │   │ │ │ │  topologyRefinerFactory.h │ │ │ │   │ │ │ │  types.h │ │ │ │   │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_7f420b72a822828cfa8b0561c695a5cc.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,17 +1,17 @@ │ │ │ │ │ var dir_7f420b72a822828cfa8b0561c695a5cc = [ │ │ │ │ │ ["error.h", "a00743.html", "a00743"], │ │ │ │ │ ["patchDescriptor.h", "a00740.html", "a00740"], │ │ │ │ │ ["patchMap.h", "a00734.html", "a00734"], │ │ │ │ │ ["patchParam.h", "a00737.html", "a00737"], │ │ │ │ │ ["patchTable.h", "a00731.html", "a00731"], │ │ │ │ │ - ["patchTableFactory.h", "a00725.html", "a00725"], │ │ │ │ │ - ["primvarRefiner.h", "a00728.html", "a00728"], │ │ │ │ │ + ["patchTableFactory.h", "a00728.html", "a00728"], │ │ │ │ │ + ["primvarRefiner.h", "a00719.html", "a00719"], │ │ │ │ │ ["ptexIndices.h", "a00722.html", "a00722"], │ │ │ │ │ - ["stencilTable.h", "a00716.html", "a00716"], │ │ │ │ │ - ["stencilTableFactory.h", "a00719.html", "a00719"], │ │ │ │ │ + ["stencilTable.h", "a00725.html", "a00725"], │ │ │ │ │ + ["stencilTableFactory.h", "a00716.html", "a00716"], │ │ │ │ │ ["topologyDescriptor.h", "a00713.html", "a00713"], │ │ │ │ │ - ["topologyLevel.h", "a00707.html", "a00707"], │ │ │ │ │ - ["topologyRefiner.h", "a00710.html", "a00710"], │ │ │ │ │ + ["topologyLevel.h", "a00710.html", "a00710"], │ │ │ │ │ + ["topologyRefiner.h", "a00707.html", "a00707"], │ │ │ │ │ ["topologyRefinerFactory.h", "a00704.html", "a00704"], │ │ │ │ │ ["types.h", "a01486.html", "a01486"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_bd5473d7d5841d48919aaa9ad0cb1f9b.html │ │ │ │ @@ -101,19 +101,19 @@ │ │ │ │   │ │ │ │  componentInterfaces.h │ │ │ │   │ │ │ │  fvarLevel.h │ │ │ │   │ │ │ │  fvarRefinement.h │ │ │ │   │ │ │ │ - level.h │ │ │ │ + level.h │ │ │ │   │ │ │ │ - refinement.h │ │ │ │ + refinement.h │ │ │ │   │ │ │ │ - sparseSelector.h │ │ │ │ + sparseSelector.h │ │ │ │   │ │ │ │  stackBuffer.h │ │ │ │   │ │ │ │  types.h │ │ │ │   │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_bd5473d7d5841d48919aaa9ad0cb1f9b.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,11 +1,11 @@ │ │ │ │ │ var dir_bd5473d7d5841d48919aaa9ad0cb1f9b = [ │ │ │ │ │ ["array.h", "a00767.html", "a00767"], │ │ │ │ │ ["componentInterfaces.h", "a00764.html", null], │ │ │ │ │ ["fvarLevel.h", "a00761.html", null], │ │ │ │ │ ["fvarRefinement.h", "a00758.html", null], │ │ │ │ │ - ["level.h", "a00755.html", null], │ │ │ │ │ - ["refinement.h", "a00752.html", null], │ │ │ │ │ - ["sparseSelector.h", "a00749.html", null], │ │ │ │ │ + ["level.h", "a00749.html", null], │ │ │ │ │ + ["refinement.h", "a00755.html", null], │ │ │ │ │ + ["sparseSelector.h", "a00752.html", null], │ │ │ │ │ ["stackBuffer.h", "a00746.html", null], │ │ │ │ │ ["types.h", "a01495.html", "a01495"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_f61368944c63c2c1f8c69bc232e59c39.html │ │ │ │ @@ -97,21 +97,21 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Files

 bilinearScheme.h
 
 catmarkScheme.h
 
 crease.h
 crease.h
 
 loopScheme.h
 loopScheme.h
 
 options.h
 options.h
 
 scheme.h
 scheme.h
 
 types.h
 
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_f61368944c63c2c1f8c69bc232e59c39.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,9 +1,9 @@ │ │ │ │ │ var dir_f61368944c63c2c1f8c69bc232e59c39 = [ │ │ │ │ │ ["bilinearScheme.h", "a00785.html", null], │ │ │ │ │ ["catmarkScheme.h", "a00782.html", null], │ │ │ │ │ - ["crease.h", "a00776.html", "a00776"], │ │ │ │ │ - ["loopScheme.h", "a00770.html", null], │ │ │ │ │ - ["options.h", "a00779.html", "a00779"], │ │ │ │ │ - ["scheme.h", "a00773.html", "a00773"], │ │ │ │ │ + ["crease.h", "a00779.html", "a00779"], │ │ │ │ │ + ["loopScheme.h", "a00776.html", null], │ │ │ │ │ + ["options.h", "a00773.html", "a00773"], │ │ │ │ │ + ["scheme.h", "a00770.html", "a00770"], │ │ │ │ │ ["types.h", "a01492.html", "a01492"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_fa5edef2a780a73fbfb6a11f1af88ceb.html │ │ │ │ @@ -93,27 +93,27 @@ │ │ │ │
│ │ │ │
bfr Directory Reference
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

│ │ │ │ Files

 limits.h
 limits.h
 
 parameterization.h
 parameterization.h
 
 refinerSurfaceFactory.h
 refinerSurfaceFactory.h
 
 surface.h
 surface.h
 
 surfaceFactory.h
 
 surfaceFactoryCache.h
 surfaceFactoryCache.h
 
 surfaceFactoryMeshAdapter.h
 surfaceFactoryMeshAdapter.h
 
 tessellation.h
 
 vertexDescriptor.h
 
│ │ │ │
│ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/dir_fa5edef2a780a73fbfb6a11f1af88ceb.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,11 +1,11 @@ │ │ │ │ │ var dir_fa5edef2a780a73fbfb6a11f1af88ceb = [ │ │ │ │ │ - ["limits.h", "a00698.html", "a00698"], │ │ │ │ │ - ["parameterization.h", "a00695.html", "a00695"], │ │ │ │ │ - ["refinerSurfaceFactory.h", "a00689.html", "a00689"], │ │ │ │ │ - ["surface.h", "a00692.html", "a00692"], │ │ │ │ │ + ["limits.h", "a00695.html", "a00695"], │ │ │ │ │ + ["parameterization.h", "a00698.html", "a00698"], │ │ │ │ │ + ["refinerSurfaceFactory.h", "a00692.html", "a00692"], │ │ │ │ │ + ["surface.h", "a00689.html", "a00689"], │ │ │ │ │ ["surfaceFactory.h", "a00686.html", "a00686"], │ │ │ │ │ - ["surfaceFactoryCache.h", "a00683.html", "a00683"], │ │ │ │ │ - ["surfaceFactoryMeshAdapter.h", "a00680.html", "a00680"], │ │ │ │ │ + ["surfaceFactoryCache.h", "a00680.html", "a00680"], │ │ │ │ │ + ["surfaceFactoryMeshAdapter.h", "a00683.html", "a00683"], │ │ │ │ │ ["tessellation.h", "a00677.html", "a00677"], │ │ │ │ │ ["vertexDescriptor.h", "a00674.html", "a00674"] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/files.html │ │ │ │ @@ -94,96 +94,96 @@ │ │ │ │
File List
│ │ │ │ │ │ │ │
│ │ │ │
Here is a list of all files with brief descriptions:
│ │ │ │
[detail level 123]
│ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ + │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ │ │ │ │ │ │ │ │
  opensubdiv
  bfr
 limits.h
 parameterization.h
 refinerSurfaceFactory.h
 surface.h
 limits.h
 parameterization.h
 refinerSurfaceFactory.h
 surface.h
 surfaceFactory.h
 surfaceFactoryCache.h
 surfaceFactoryMeshAdapter.h
 surfaceFactoryCache.h
 surfaceFactoryMeshAdapter.h
 tessellation.h
 vertexDescriptor.h
  far
 error.h
 patchDescriptor.h
 patchMap.h
 patchParam.h
 patchTable.h
 patchTableFactory.h
 primvarRefiner.h
 patchTableFactory.h
 primvarRefiner.h
 ptexIndices.h
 stencilTable.h
 stencilTableFactory.h
 stencilTable.h
 stencilTableFactory.h
 topologyDescriptor.h
 topologyLevel.h
 topologyRefiner.h
 topologyLevel.h
 topologyRefiner.h
 topologyRefinerFactory.h
 types.h
  osd
 bufferDescriptor.h
 bufferDescriptor.h
 clEvaluator.h
 clPatchTable.h
 clVertexBuffer.h
 cpuD3D11VertexBuffer.h
 cpuEvaluator.h
 cpuD3D11VertexBuffer.h
 cpuEvaluator.h
 cpuGLVertexBuffer.h
 cpuPatchTable.h
 cpuVertexBuffer.h
 cpuVertexBuffer.h
 cudaEvaluator.h
 cudaPatchTable.h
 cudaPatchTable.h
 cudaVertexBuffer.h
 d3d11ComputeEvaluator.h
 d3d11ComputeEvaluator.h
 d3d11LegacyGregoryPatchTable.h
 d3d11Mesh.h
 d3d11PatchTable.h
 d3d11VertexBuffer.h
 glComputeEvaluator.h
 glLegacyGregoryPatchTable.h
 glMesh.h
 glPatchTable.h
 glslPatchShaderSource.h
 glVertexBuffer.h
 glXFBEvaluator.h
 hlslPatchShaderSource.h
 mesh.h
 mtlCommon.h
 mtlComputeEvaluator.h
 mtlLegacyGregoryPatchTable.h
 mtlMesh.h
 mtlPatchShaderSource.h
 mtlComputeEvaluator.h
 mtlLegacyGregoryPatchTable.h
 mtlMesh.h
 mtlPatchShaderSource.h
 mtlPatchTable.h
 mtlVertexBuffer.h
 mtlVertexBuffer.h
 ompEvaluator.h
 ompKernel.h
 opencl.h
 opengl.h
 tbbEvaluator.h
 tbbKernel.h
 ompKernel.h
 opencl.h
 opengl.h
 tbbEvaluator.h
 tbbKernel.h
 types.h
  sdc
 bilinearScheme.h
 catmarkScheme.h
 crease.h
 loopScheme.h
 options.h
 scheme.h
 crease.h
 loopScheme.h
 options.h
 scheme.h
 types.h
  vtr
 array.h
 componentInterfaces.h
 fvarLevel.h
 fvarRefinement.h
 level.h
 refinement.h
 sparseSelector.h
 level.h
 refinement.h
 sparseSelector.h
 stackBuffer.h
 types.h
│ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/navtreeindex0.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,44 +1,44 @@ │ │ │ │ │ var NAVTREEINDEX0 = { │ │ │ │ │ "a00674.html": [2, 0, 0, 0, 8], │ │ │ │ │ "a00674_source.html": [2, 0, 0, 0, 8], │ │ │ │ │ "a00677.html": [2, 0, 0, 0, 7], │ │ │ │ │ "a00677_source.html": [2, 0, 0, 0, 7], │ │ │ │ │ - "a00680.html": [2, 0, 0, 0, 6], │ │ │ │ │ - "a00680_source.html": [2, 0, 0, 0, 6], │ │ │ │ │ - "a00683.html": [2, 0, 0, 0, 5], │ │ │ │ │ - "a00683_source.html": [2, 0, 0, 0, 5], │ │ │ │ │ + "a00680.html": [2, 0, 0, 0, 5], │ │ │ │ │ + "a00680_source.html": [2, 0, 0, 0, 5], │ │ │ │ │ + "a00683.html": [2, 0, 0, 0, 6], │ │ │ │ │ + "a00683_source.html": [2, 0, 0, 0, 6], │ │ │ │ │ "a00686.html": [2, 0, 0, 0, 4], │ │ │ │ │ "a00686_source.html": [2, 0, 0, 0, 4], │ │ │ │ │ - "a00689.html": [2, 0, 0, 0, 2], │ │ │ │ │ - "a00689_source.html": [2, 0, 0, 0, 2], │ │ │ │ │ - "a00692.html": [2, 0, 0, 0, 3], │ │ │ │ │ - "a00692_source.html": [2, 0, 0, 0, 3], │ │ │ │ │ - "a00695.html": [2, 0, 0, 0, 1], │ │ │ │ │ - "a00695_source.html": [2, 0, 0, 0, 1], │ │ │ │ │ - "a00698.html": [2, 0, 0, 0, 0], │ │ │ │ │ - "a00698_source.html": [2, 0, 0, 0, 0], │ │ │ │ │ + "a00689.html": [2, 0, 0, 0, 3], │ │ │ │ │ + "a00689_source.html": [2, 0, 0, 0, 3], │ │ │ │ │ + "a00692.html": [2, 0, 0, 0, 2], │ │ │ │ │ + "a00692_source.html": [2, 0, 0, 0, 2], │ │ │ │ │ + "a00695.html": [2, 0, 0, 0, 0], │ │ │ │ │ + "a00695_source.html": [2, 0, 0, 0, 0], │ │ │ │ │ + "a00698.html": [2, 0, 0, 0, 1], │ │ │ │ │ + "a00698_source.html": [2, 0, 0, 0, 1], │ │ │ │ │ "a00704.html": [2, 0, 0, 1, 13], │ │ │ │ │ "a00704_source.html": [2, 0, 0, 1, 13], │ │ │ │ │ - "a00707.html": [2, 0, 0, 1, 11], │ │ │ │ │ - "a00707_source.html": [2, 0, 0, 1, 11], │ │ │ │ │ - "a00710.html": [2, 0, 0, 1, 12], │ │ │ │ │ - "a00710_source.html": [2, 0, 0, 1, 12], │ │ │ │ │ + "a00707.html": [2, 0, 0, 1, 12], │ │ │ │ │ + "a00707_source.html": [2, 0, 0, 1, 12], │ │ │ │ │ + "a00710.html": [2, 0, 0, 1, 11], │ │ │ │ │ + "a00710_source.html": [2, 0, 0, 1, 11], │ │ │ │ │ "a00713.html": [2, 0, 0, 1, 10], │ │ │ │ │ "a00713_source.html": [2, 0, 0, 1, 10], │ │ │ │ │ - "a00716.html": [2, 0, 0, 1, 8], │ │ │ │ │ - "a00716_source.html": [2, 0, 0, 1, 8], │ │ │ │ │ - "a00719.html": [2, 0, 0, 1, 9], │ │ │ │ │ - "a00719_source.html": [2, 0, 0, 1, 9], │ │ │ │ │ + "a00716.html": [2, 0, 0, 1, 9], │ │ │ │ │ + "a00716_source.html": [2, 0, 0, 1, 9], │ │ │ │ │ + "a00719.html": [2, 0, 0, 1, 6], │ │ │ │ │ + "a00719_source.html": [2, 0, 0, 1, 6], │ │ │ │ │ "a00722.html": [2, 0, 0, 1, 7], │ │ │ │ │ "a00722_source.html": [2, 0, 0, 1, 7], │ │ │ │ │ - "a00725.html": [2, 0, 0, 1, 5], │ │ │ │ │ - "a00725_source.html": [2, 0, 0, 1, 5], │ │ │ │ │ - "a00728.html": [2, 0, 0, 1, 6], │ │ │ │ │ - "a00728_source.html": [2, 0, 0, 1, 6], │ │ │ │ │ + "a00725.html": [2, 0, 0, 1, 8], │ │ │ │ │ + "a00725_source.html": [2, 0, 0, 1, 8], │ │ │ │ │ + "a00728.html": [2, 0, 0, 1, 5], │ │ │ │ │ + "a00728_source.html": [2, 0, 0, 1, 5], │ │ │ │ │ "a00731.html": [2, 0, 0, 1, 4], │ │ │ │ │ "a00731_source.html": [2, 0, 0, 1, 4], │ │ │ │ │ "a00734.html": [2, 0, 0, 1, 2], │ │ │ │ │ "a00734_source.html": [2, 0, 0, 1, 2], │ │ │ │ │ "a00737.html": [2, 0, 0, 1, 3], │ │ │ │ │ "a00737.html#a3139c7c52ddf26b2403e8e95ff63eeb3": [2, 0, 0, 1, 3, 1], │ │ │ │ │ "a00737.html#a46ea68db89cc3d55c4191ef7648281ce": [2, 0, 0, 1, 3, 3], │ │ │ │ │ @@ -59,82 +59,82 @@ │ │ │ │ │ "a00743.html#ab0df38968e4f03a3f1f6d6df0f31f45aa3efe6cb2ec7e23769d53919dfb3291b5": [2, 0, 0, 1, 0, 2, 2], │ │ │ │ │ "a00743.html#ab0df38968e4f03a3f1f6d6df0f31f45aa9b2839feb039937015e9668f601e4d32": [2, 0, 0, 1, 0, 2, 3], │ │ │ │ │ "a00743.html#ab0df38968e4f03a3f1f6d6df0f31f45aabeca977bc439b451aea1325f48a52a0b": [2, 0, 0, 1, 0, 2, 0], │ │ │ │ │ "a00743.html#ab0df38968e4f03a3f1f6d6df0f31f45aac565fa39d681e2766584dd87246c3bdd": [2, 0, 0, 1, 0, 2, 4], │ │ │ │ │ "a00743_source.html": [2, 0, 0, 1, 0], │ │ │ │ │ "a00746.html": [2, 0, 0, 4, 7], │ │ │ │ │ "a00746_source.html": [2, 0, 0, 4, 7], │ │ │ │ │ - "a00749.html": [2, 0, 0, 4, 6], │ │ │ │ │ - "a00749_source.html": [2, 0, 0, 4, 6], │ │ │ │ │ - "a00752.html": [2, 0, 0, 4, 5], │ │ │ │ │ - "a00752_source.html": [2, 0, 0, 4, 5], │ │ │ │ │ - "a00755.html": [2, 0, 0, 4, 4], │ │ │ │ │ - "a00755_source.html": [2, 0, 0, 4, 4], │ │ │ │ │ + "a00749.html": [2, 0, 0, 4, 4], │ │ │ │ │ + "a00749_source.html": [2, 0, 0, 4, 4], │ │ │ │ │ + "a00752.html": [2, 0, 0, 4, 6], │ │ │ │ │ + "a00752_source.html": [2, 0, 0, 4, 6], │ │ │ │ │ + "a00755.html": [2, 0, 0, 4, 5], │ │ │ │ │ + "a00755_source.html": [2, 0, 0, 4, 5], │ │ │ │ │ "a00758.html": [2, 0, 0, 4, 3], │ │ │ │ │ "a00758_source.html": [2, 0, 0, 4, 3], │ │ │ │ │ "a00761.html": [2, 0, 0, 4, 2], │ │ │ │ │ "a00761_source.html": [2, 0, 0, 4, 2], │ │ │ │ │ "a00764.html": [2, 0, 0, 4, 1], │ │ │ │ │ "a00764_source.html": [2, 0, 0, 4, 1], │ │ │ │ │ "a00767.html": [2, 0, 0, 4, 0], │ │ │ │ │ "a00767_source.html": [2, 0, 0, 4, 0], │ │ │ │ │ - "a00770.html": [2, 0, 0, 3, 3], │ │ │ │ │ - "a00770_source.html": [2, 0, 0, 3, 3], │ │ │ │ │ - "a00773.html": [2, 0, 0, 3, 5], │ │ │ │ │ - "a00773_source.html": [2, 0, 0, 3, 5], │ │ │ │ │ - "a00776.html": [2, 0, 0, 3, 2], │ │ │ │ │ - "a00776_source.html": [2, 0, 0, 3, 2], │ │ │ │ │ - "a00779.html": [2, 0, 0, 3, 4], │ │ │ │ │ - "a00779_source.html": [2, 0, 0, 3, 4], │ │ │ │ │ + "a00770.html": [2, 0, 0, 3, 5], │ │ │ │ │ + "a00770_source.html": [2, 0, 0, 3, 5], │ │ │ │ │ + "a00773.html": [2, 0, 0, 3, 4], │ │ │ │ │ + "a00773_source.html": [2, 0, 0, 3, 4], │ │ │ │ │ + "a00776.html": [2, 0, 0, 3, 3], │ │ │ │ │ + "a00776_source.html": [2, 0, 0, 3, 3], │ │ │ │ │ + "a00779.html": [2, 0, 0, 3, 2], │ │ │ │ │ + "a00779_source.html": [2, 0, 0, 3, 2], │ │ │ │ │ "a00782.html": [2, 0, 0, 3, 1], │ │ │ │ │ "a00782_source.html": [2, 0, 0, 3, 1], │ │ │ │ │ "a00785.html": [2, 0, 0, 3, 0], │ │ │ │ │ "a00785_source.html": [2, 0, 0, 3, 0], │ │ │ │ │ "a00788.html": [2, 0, 0, 2, 9], │ │ │ │ │ "a00788_source.html": [2, 0, 0, 2, 9], │ │ │ │ │ - "a00791.html": [2, 0, 0, 2, 35], │ │ │ │ │ - "a00791_source.html": [2, 0, 0, 2, 35], │ │ │ │ │ - "a00794.html": [2, 0, 0, 2, 10], │ │ │ │ │ - "a00794_source.html": [2, 0, 0, 2, 10], │ │ │ │ │ + "a00791.html": [2, 0, 0, 2, 10], │ │ │ │ │ + "a00791_source.html": [2, 0, 0, 2, 10], │ │ │ │ │ + "a00794.html": [2, 0, 0, 2, 35], │ │ │ │ │ + "a00794_source.html": [2, 0, 0, 2, 35], │ │ │ │ │ "a00797.html": [2, 0, 0, 2, 3], │ │ │ │ │ "a00797_source.html": [2, 0, 0, 2, 3], │ │ │ │ │ "a00800.html": [2, 0, 0, 2, 2], │ │ │ │ │ "a00800_source.html": [2, 0, 0, 2, 2], │ │ │ │ │ "a00803.html": [2, 0, 0, 2, 1], │ │ │ │ │ "a00803_source.html": [2, 0, 0, 2, 1], │ │ │ │ │ "a00806.html": [2, 0, 0, 2, 26], │ │ │ │ │ "a00806_source.html": [2, 0, 0, 2, 26], │ │ │ │ │ - "a00809.html": [2, 0, 0, 2, 30], │ │ │ │ │ - "a00809_source.html": [2, 0, 0, 2, 30], │ │ │ │ │ - "a00812.html": [2, 0, 0, 2, 29], │ │ │ │ │ - "a00812.html#aa41e5b43fe46eeb0f97ff6ebdb1935aa": [2, 0, 0, 2, 29, 0], │ │ │ │ │ - "a00812_source.html": [2, 0, 0, 2, 29], │ │ │ │ │ + "a00809.html": [2, 0, 0, 2, 29], │ │ │ │ │ + "a00809.html#aa41e5b43fe46eeb0f97ff6ebdb1935aa": [2, 0, 0, 2, 29, 0], │ │ │ │ │ + "a00809_source.html": [2, 0, 0, 2, 29], │ │ │ │ │ + "a00812.html": [2, 0, 0, 2, 30], │ │ │ │ │ + "a00812_source.html": [2, 0, 0, 2, 30], │ │ │ │ │ "a00815.html": [2, 0, 0, 2, 31], │ │ │ │ │ "a00815_source.html": [2, 0, 0, 2, 31], │ │ │ │ │ - "a00818.html": [2, 0, 0, 2, 28], │ │ │ │ │ - "a00818_source.html": [2, 0, 0, 2, 28], │ │ │ │ │ - "a00821.html": [2, 0, 0, 2, 27], │ │ │ │ │ - "a00821_source.html": [2, 0, 0, 2, 27], │ │ │ │ │ - "a00824.html": [2, 0, 0, 2, 32], │ │ │ │ │ - "a00824_source.html": [2, 0, 0, 2, 32], │ │ │ │ │ + "a00818.html": [2, 0, 0, 2, 32], │ │ │ │ │ + "a00818_source.html": [2, 0, 0, 2, 32], │ │ │ │ │ + "a00821.html": [2, 0, 0, 2, 28], │ │ │ │ │ + "a00821_source.html": [2, 0, 0, 2, 28], │ │ │ │ │ + "a00824.html": [2, 0, 0, 2, 27], │ │ │ │ │ + "a00824_source.html": [2, 0, 0, 2, 27], │ │ │ │ │ "a00827.html": [2, 0, 0, 2, 24], │ │ │ │ │ "a00827_source.html": [2, 0, 0, 2, 24], │ │ │ │ │ "a00830.html": [2, 0, 0, 2, 14], │ │ │ │ │ "a00830.html#ae5c8e80d05d6eaee105d8eecfa9ab609": [2, 0, 0, 2, 14, 0], │ │ │ │ │ "a00830_source.html": [2, 0, 0, 2, 14], │ │ │ │ │ "a00833.html": [2, 0, 0, 2, 16], │ │ │ │ │ "a00833_source.html": [2, 0, 0, 2, 16], │ │ │ │ │ "a00836.html": [2, 0, 0, 2, 15], │ │ │ │ │ "a00836_source.html": [2, 0, 0, 2, 15], │ │ │ │ │ "a00839.html": [2, 0, 0, 2, 13], │ │ │ │ │ "a00839_source.html": [2, 0, 0, 2, 13], │ │ │ │ │ - "a00842.html": [2, 0, 0, 2, 4], │ │ │ │ │ - "a00842_source.html": [2, 0, 0, 2, 4], │ │ │ │ │ - "a00845.html": [2, 0, 0, 2, 12], │ │ │ │ │ - "a00845_source.html": [2, 0, 0, 2, 12], │ │ │ │ │ + "a00842.html": [2, 0, 0, 2, 12], │ │ │ │ │ + "a00842_source.html": [2, 0, 0, 2, 12], │ │ │ │ │ + "a00845.html": [2, 0, 0, 2, 4], │ │ │ │ │ + "a00845_source.html": [2, 0, 0, 2, 4], │ │ │ │ │ "a00848.html": [2, 0, 0, 2, 17], │ │ │ │ │ "a00848_source.html": [2, 0, 0, 2, 17], │ │ │ │ │ "a00851.html": [2, 0, 0, 2, 23], │ │ │ │ │ "a00851_source.html": [2, 0, 0, 2, 23], │ │ │ │ │ "a00854.html": [2, 0, 0, 2, 21], │ │ │ │ │ "a00854_source.html": [2, 0, 0, 2, 21], │ │ │ │ │ "a00857.html": [2, 0, 0, 2, 19], │ │ │ │ │ @@ -144,34 +144,34 @@ │ │ │ │ │ "a00860_source.html": [2, 0, 0, 2, 20], │ │ │ │ │ "a00863.html": [2, 0, 0, 2, 22], │ │ │ │ │ "a00863_source.html": [2, 0, 0, 2, 22], │ │ │ │ │ "a00866.html": [2, 0, 0, 2, 6], │ │ │ │ │ "a00866_source.html": [2, 0, 0, 2, 6], │ │ │ │ │ "a00869.html": [2, 0, 0, 2, 18], │ │ │ │ │ "a00869_source.html": [2, 0, 0, 2, 18], │ │ │ │ │ - "a00872.html": [2, 0, 0, 2, 38], │ │ │ │ │ - "a00872.html#a20e08be34d6183b6943ed7a1586eca4a": [2, 0, 0, 2, 38, 1], │ │ │ │ │ - "a00872.html#a4a6a0fcc01638f2a0316b32ad158b485": [2, 0, 0, 2, 38, 4], │ │ │ │ │ - "a00872.html#aa0c3c264a43eeddc5cb3a58b006d3d32": [2, 0, 0, 2, 38, 0], │ │ │ │ │ - "a00872.html#aa65ed860a2fa5935d99129a898a8f0b6": [2, 0, 0, 2, 38, 2], │ │ │ │ │ - "a00872.html#af23c35537952bfdd493441e5c42ff2ed": [2, 0, 0, 2, 38, 3], │ │ │ │ │ - "a00872_source.html": [2, 0, 0, 2, 38], │ │ │ │ │ - "a00875.html": [2, 0, 0, 2, 34], │ │ │ │ │ - "a00875.html#a44a05502feb5015035bc81b93cffb99c": [2, 0, 0, 2, 34, 0], │ │ │ │ │ - "a00875.html#a870745ff3e883b32547d4db42b3be2bd": [2, 0, 0, 2, 34, 2], │ │ │ │ │ - "a00875.html#a907dc53421460557871ddc35f77751f5": [2, 0, 0, 2, 34, 1], │ │ │ │ │ - "a00875_source.html": [2, 0, 0, 2, 34], │ │ │ │ │ - "a00878.html": [2, 0, 0, 2, 37], │ │ │ │ │ - "a00878_source.html": [2, 0, 0, 2, 37], │ │ │ │ │ + "a00872.html": [2, 0, 0, 2, 34], │ │ │ │ │ + "a00872.html#a44a05502feb5015035bc81b93cffb99c": [2, 0, 0, 2, 34, 0], │ │ │ │ │ + "a00872.html#a870745ff3e883b32547d4db42b3be2bd": [2, 0, 0, 2, 34, 2], │ │ │ │ │ + "a00872.html#a907dc53421460557871ddc35f77751f5": [2, 0, 0, 2, 34, 1], │ │ │ │ │ + "a00872_source.html": [2, 0, 0, 2, 34], │ │ │ │ │ + "a00875.html": [2, 0, 0, 2, 37], │ │ │ │ │ + "a00875_source.html": [2, 0, 0, 2, 37], │ │ │ │ │ + "a00878.html": [2, 0, 0, 2, 38], │ │ │ │ │ + "a00878.html#a20e08be34d6183b6943ed7a1586eca4a": [2, 0, 0, 2, 38, 1], │ │ │ │ │ + "a00878.html#a4a6a0fcc01638f2a0316b32ad158b485": [2, 0, 0, 2, 38, 4], │ │ │ │ │ + "a00878.html#aa0c3c264a43eeddc5cb3a58b006d3d32": [2, 0, 0, 2, 38, 0], │ │ │ │ │ + "a00878.html#aa65ed860a2fa5935d99129a898a8f0b6": [2, 0, 0, 2, 38, 2], │ │ │ │ │ + "a00878.html#af23c35537952bfdd493441e5c42ff2ed": [2, 0, 0, 2, 38, 3], │ │ │ │ │ + "a00878_source.html": [2, 0, 0, 2, 38], │ │ │ │ │ "a00881.html": [2, 0, 0, 2, 33], │ │ │ │ │ "a00881_source.html": [2, 0, 0, 2, 33], │ │ │ │ │ - "a00884.html": [2, 0, 0, 2, 36], │ │ │ │ │ - "a00884_source.html": [2, 0, 0, 2, 36], │ │ │ │ │ - "a00887.html": [2, 0, 0, 2, 8], │ │ │ │ │ - "a00887_source.html": [2, 0, 0, 2, 8], │ │ │ │ │ + "a00884.html": [2, 0, 0, 2, 8], │ │ │ │ │ + "a00884_source.html": [2, 0, 0, 2, 8], │ │ │ │ │ + "a00887.html": [2, 0, 0, 2, 36], │ │ │ │ │ + "a00887_source.html": [2, 0, 0, 2, 36], │ │ │ │ │ "a00890.html": [2, 0, 0, 2, 25], │ │ │ │ │ "a00890.html#a06ceddf21c024b341a5b946049cd701a": [2, 0, 0, 2, 25, 6], │ │ │ │ │ "a00890.html#a1af6b50e9f8ae13d3d2f9d5b03b35492": [2, 0, 0, 2, 25, 5], │ │ │ │ │ "a00890.html#a1af6b50e9f8ae13d3d2f9d5b03b35492a4124233e4f787f999c7975afceab34f3": [2, 0, 0, 2, 25, 5, 7], │ │ │ │ │ "a00890.html#a1af6b50e9f8ae13d3d2f9d5b03b35492a5676712c77d29cfdd330e2802db1c464": [2, 0, 0, 2, 25, 5, 11], │ │ │ │ │ "a00890.html#a1af6b50e9f8ae13d3d2f9d5b03b35492a8fab1b3018f94b5b2432c7435e795925": [2, 0, 0, 2, 25, 5, 6], │ │ │ │ │ "a00890.html#a1af6b50e9f8ae13d3d2f9d5b03b35492a9058d69e1089fc77f1974a76c34e2071": [2, 0, 0, 2, 25, 5, 5], │ │ │ │ │ @@ -186,18 +186,18 @@ │ │ │ │ │ "a00890.html#a33f9830228f847fae1c30c9dffe02b5a": [2, 0, 0, 2, 25, 9], │ │ │ │ │ "a00890.html#a4c2520cc1a8a5a03e3f53584629d7318": [2, 0, 0, 2, 25, 7], │ │ │ │ │ "a00890.html#a85ba9df501aea9af1ec9da1558c255bc": [2, 0, 0, 2, 25, 4], │ │ │ │ │ "a00890.html#ab5753a2b0a0995c8e2259d2c4765f7df": [2, 0, 0, 2, 25, 8], │ │ │ │ │ "a00890_source.html": [2, 0, 0, 2, 25], │ │ │ │ │ "a00893.html": [2, 0, 0, 2, 7], │ │ │ │ │ "a00893_source.html": [2, 0, 0, 2, 7], │ │ │ │ │ - "a00896.html": [2, 0, 0, 2, 0], │ │ │ │ │ - "a00896_source.html": [2, 0, 0, 2, 0], │ │ │ │ │ - "a00899.html": [2, 0, 0, 2, 5], │ │ │ │ │ - "a00899_source.html": [2, 0, 0, 2, 5], │ │ │ │ │ + "a00896.html": [2, 0, 0, 2, 5], │ │ │ │ │ + "a00896_source.html": [2, 0, 0, 2, 5], │ │ │ │ │ + "a00899.html": [2, 0, 0, 2, 0], │ │ │ │ │ + "a00899_source.html": [2, 0, 0, 2, 0], │ │ │ │ │ "a00902.html": [2, 0, 0, 2, 11], │ │ │ │ │ "a00902_source.html": [2, 0, 0, 2, 11], │ │ │ │ │ "a00905.html": [0, 0, 0], │ │ │ │ │ "a00906.html": [0, 0, 0, 0], │ │ │ │ │ "a00907.html": [0, 0, 0, 0, 0], │ │ │ │ │ "a00908.html": [0, 0, 0, 0, 1], │ │ │ │ │ "a00908.html#a200172f1c19545bc01f292afa2167e2f": [0, 0, 0, 0, 1, 32], │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_10.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -2,23 +2,23 @@ │ │ │ │ │ ['reference_0', ['reference', ['../a01353.html#a9025ff89fc9afe7d9054abb58123bbda', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Vtr::ConstArray::reference'], │ │ │ │ │ ['../a01357.html#a9025ff89fc9afe7d9054abb58123bbda', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Vtr::Array::reference'] │ │ │ │ │ ]], │ │ │ │ │ ['refine_1', ['refine', ['../a01269.html#a9a90398ba2073fe3da454f6b00deb33c', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MeshInterface::Refine()'], │ │ │ │ │ ['../a01281.html#a32c8d641fe9ea1565be646a10c5d6c85', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::Mesh::Refine()'] │ │ │ │ │ ]], │ │ │ │ │ ['refineadaptive_2', ['RefineAdaptive', ['../a01121.html#aff92309935db19988908471bee4fef4d', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner']]], │ │ │ │ │ - ['refinement_2eh_3', ['refinement.h', ['../a00752.html', 1, '']]], │ │ │ │ │ + ['refinement_2eh_3', ['refinement.h', ['../a00755.html', 1, '']]], │ │ │ │ │ ['refinementlevel_4', ['refinementLevel', ['../a01125.html#a240d1e5f5b743486e8122db6223d4562', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::UniformOptions']]], │ │ │ │ │ ['refinemesh_5', ['refinemesh', ['../a01269.html#a51f237c3f08f6ddc2ea7ba5cb0d00b36', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MeshInterface::refineMesh(Far::TopologyRefiner &refiner, int level, bool adaptive, bool singleCreasePatch)'], │ │ │ │ │ ['../a01269.html#a173851f742adc30ac139af96fe63732d', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MeshInterface::refineMesh(Far::TopologyRefiner &refiner, int level, MeshBitset bits)'] │ │ │ │ │ ]], │ │ │ │ │ ['refinersurfacefactory_6', ['refinersurfacefactory', ['../a00929.html#af74dafe122d798d4069b675c52f6665a', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::RefinerSurfaceFactory::RefinerSurfaceFactory()'], │ │ │ │ │ ['../a00929.html', 1, 'RefinerSurfaceFactory< CACHE_TYPE >'] │ │ │ │ │ ]], │ │ │ │ │ - ['refinersurfacefactory_2eh_7', ['refinerSurfaceFactory.h', ['../a00689.html', 1, '']]], │ │ │ │ │ + ['refinersurfacefactory_2eh_7', ['refinerSurfaceFactory.h', ['../a00692.html', 1, '']]], │ │ │ │ │ ['refinersurfacefactorybase_8', ['refinersurfacefactorybase', ['../a00925.html', 1, 'RefinerSurfaceFactoryBase'], │ │ │ │ │ ['../a00925.html#af457c931d6d611e35737454f2c483f84', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::RefinerSurfaceFactoryBase::RefinerSurfaceFactoryBase()'] │ │ │ │ │ ]], │ │ │ │ │ ['refineuniform_9', ['RefineUniform', ['../a01121.html#ad22b7ffd9f8f3b488e5f220cf00c8c82', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner']]], │ │ │ │ │ ['regdesc_10', ['regDesc', ['../a01325.html#a00efd3a5502664756617ee930cb4324c', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::PatchArray']]], │ │ │ │ │ ['regular_11', ['REGULAR', ['../a00973.html#a1d1cfd8ffb84e947f82999c682b666a7afc488491175a6dac9e5881e363ad4c41', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PatchDescriptor']]], │ │ │ │ │ ['reportinvalidtopology_12', ['reportInvalidTopology', ['../a01117.html#a0c4c1d44df4c480bd0adfa9e86891b39', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefinerFactory']]], │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_11.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -2,15 +2,15 @@ │ │ │ │ │ ['s_0', ['s', ['../a01321.html#a874f74a4dc1c9a0cd9c6e0d79c298f55', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::PatchCoord::s'], │ │ │ │ │ ['../a01093.html#a22a5e18d1aeafd28cdd38b543c50c688', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilTableFactoryReal::LocationArray::s'] │ │ │ │ │ ]], │ │ │ │ │ ['scheme_1', ['scheme', ['../a01341.html#add94f921c43fa14d886adfbcdcc00211', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Scheme::Scheme()'], │ │ │ │ │ ['../a01341.html', 1, 'Scheme< SCHEME_TYPE >'], │ │ │ │ │ ['../a01341.html#a5c142c4d9c6f3be66bd018713591ffcb', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Scheme::Scheme()'] │ │ │ │ │ ]], │ │ │ │ │ - ['scheme_2eh_2', ['scheme.h', ['../a00773.html', 1, '']]], │ │ │ │ │ + ['scheme_2eh_2', ['scheme.h', ['../a00770.html', 1, '']]], │ │ │ │ │ ['scheme_5fbilinear_3', ['SCHEME_BILINEAR', ['../a00913.html#aa3daa2f428c6be2b1cb394f3a525833da02558f420bac2d6bd3f8411d4b3957a0', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc']]], │ │ │ │ │ ['scheme_5fcatmark_4', ['SCHEME_CATMARK', ['../a00913.html#aa3daa2f428c6be2b1cb394f3a525833da29c9704ef8a61670dfc242b6e6b82a9f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc']]], │ │ │ │ │ ['scheme_5floop_5', ['SCHEME_LOOP', ['../a00913.html#aa3daa2f428c6be2b1cb394f3a525833da529a2651a5dcfac532e933ffefc36e99', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc']]], │ │ │ │ │ ['schemeoptions_6', ['schemeOptions', ['../a01137.html#a9ec2ab2b4bd49c6cf367dac80c8cbb94', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefinerFactory::Options']]], │ │ │ │ │ ['schemetype_7', ['schemetype', ['../a01137.html#ab4a105466e7c764e3aabaa6c44c1eeb6', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefinerFactory::Options::schemeType'], │ │ │ │ │ ['../a00913.html#aa3daa2f428c6be2b1cb394f3a525833d', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::SchemeType'] │ │ │ │ │ ]], │ │ │ │ │ @@ -77,15 +77,15 @@ │ │ │ │ │ ['shrinktofit_62', ['shrinkToFit', ['../a01061.html#a84fb9ead4f0f7458491b5d310592cea9', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTableReal']]], │ │ │ │ │ ['size_63', ['size', ['../a00937.html#a439227feff9d7f55384e8780cfc2eb82', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface::PointDescriptor::size'], │ │ │ │ │ ['../a01353.html#a60304b65bf89363bcc3165d3cde67f86', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Vtr::ConstArray::size() const'] │ │ │ │ │ ]], │ │ │ │ │ ['size_5ftype_64', ['size_type', ['../a01353.html#aafd1e3ba4133ad908bdbc99c4b356e5f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Vtr::ConstArray::size_type'], │ │ │ │ │ ['../a01357.html#aafd1e3ba4133ad908bdbc99c4b356e5f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Vtr::Array::size_type'] │ │ │ │ │ ]], │ │ │ │ │ - ['sparseselector_2eh_65', ['sparseSelector.h', ['../a00749.html', 1, '']]], │ │ │ │ │ + ['sparseselector_2eh_65', ['sparseSelector.h', ['../a00752.html', 1, '']]], │ │ │ │ │ ['split_66', ['Split', ['../a00913.html#a61ef2f8f765ba17f8036bcc0f0fa887b', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc']]], │ │ │ │ │ ['split_5fhybrid_67', ['SPLIT_HYBRID', ['../a00913.html#a61ef2f8f765ba17f8036bcc0f0fa887ba6ebca125aa2292ebbdfd6539d3656d28', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc']]], │ │ │ │ │ ['split_5fto_5fquads_68', ['SPLIT_TO_QUADS', ['../a00913.html#a61ef2f8f765ba17f8036bcc0f0fa887ba56eed514f6a5971f198c9e421054b513', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc']]], │ │ │ │ │ ['split_5fto_5ftris_69', ['SPLIT_TO_TRIS', ['../a00913.html#a61ef2f8f765ba17f8036bcc0f0fa887ba31959b36c678fcb560f478ecb7c051f5', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc']]], │ │ │ │ │ ['srcdesc_70', ['srcDesc', ['../a01277.html#a5d0b0430c7584408dbcd788f52b80fd4', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::EvaluatorCacheT::Entry']]], │ │ │ │ │ ['stackbuffer_2eh_71', ['stackBuffer.h', ['../a00746.html', 1, '']]], │ │ │ │ │ ['stencil_72', ['stencil', ['../a01057.html', 1, 'Stencil'], │ │ │ │ │ @@ -101,17 +101,17 @@ │ │ │ │ │ ['stencilreal_3c_20float_20_3e_74', ['StencilReal< float >', ['../a01053.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far']]], │ │ │ │ │ ['stenciltable_75', ['stenciltable', ['../a01065.html#a3d12830eb0d421206de500d7abc9decf', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTable::StencilTable(int numControlVerts, std::vector< int > const &offsets, std::vector< int > const &sizes, std::vector< int > const &sources, std::vector< float > const &weights, bool includeCoarseVerts, size_t firstOffset)'], │ │ │ │ │ ['../a01065.html#a54db76b34112b5cb3c623be8789dd8f4', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTable::StencilTable(int numControlVerts)'], │ │ │ │ │ ['../a01065.html#acc553d2d5624ab2a790ae9613812393e', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTable::StencilTable()'], │ │ │ │ │ ['../a01281.html#a6b90e8290c540c78bedd053e2cc42f31', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::Mesh::StencilTable'], │ │ │ │ │ ['../a01065.html', 1, 'StencilTable'] │ │ │ │ │ ]], │ │ │ │ │ - ['stenciltable_2eh_76', ['stencilTable.h', ['../a00716.html', 1, '']]], │ │ │ │ │ + ['stenciltable_2eh_76', ['stencilTable.h', ['../a00725.html', 1, '']]], │ │ │ │ │ ['stenciltablefactory_77', ['StencilTableFactory', ['../a01097.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far']]], │ │ │ │ │ - ['stenciltablefactory_2eh_78', ['stencilTableFactory.h', ['../a00719.html', 1, '']]], │ │ │ │ │ + ['stenciltablefactory_2eh_78', ['stencilTableFactory.h', ['../a00716.html', 1, '']]], │ │ │ │ │ ['stenciltablefactoryreal_79', ['StencilTableFactoryReal', ['../a01045.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far']]], │ │ │ │ │ ['stenciltablefactoryreal_3c_20float_20_3e_80', ['StencilTableFactoryReal< float >', ['../a01045.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far']]], │ │ │ │ │ ['stenciltablefactoryreal_3c_20real_20_3e_81', ['stenciltablefactoryreal< real >', ['../a01053.html#af58f6a3f9b167c3330097c1a69ca36a8', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilReal::StencilTableFactoryReal< REAL >'], │ │ │ │ │ ['../a01061.html#af58f6a3f9b167c3330097c1a69ca36a8', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTableReal::StencilTableFactoryReal< REAL >'], │ │ │ │ │ ['../a01069.html#af58f6a3f9b167c3330097c1a69ca36a8', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilReal::StencilTableFactoryReal< REAL >'] │ │ │ │ │ ]], │ │ │ │ │ ['stenciltablereal_82', ['stenciltablereal', ['../a01061.html', 1, 'StencilTableReal< REAL >'], │ │ │ │ │ @@ -128,31 +128,31 @@ │ │ │ │ │ ['subdivideedgesharpnessesaroundvertex_86', ['SubdivideEdgeSharpnessesAroundVertex', ['../a01333.html#a7c27382a0be83617c49b8587ba75b438', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Crease']]], │ │ │ │ │ ['subdivideuniformsharpness_87', ['SubdivideUniformSharpness', ['../a01333.html#a7e5126bd5cff203bcea84ef35845fb40', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Crease']]], │ │ │ │ │ ['subdividevertexsharpness_88', ['SubdivideVertexSharpness', ['../a01333.html#a03f4bc921d6ee6fad4440ac134e92e36', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Crease']]], │ │ │ │ │ ['surface_89', ['surface', ['../a00933.html#a6e1a6ad293d9318f65c2e28c468c66ba', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface::Surface()'], │ │ │ │ │ ['../a00933.html', 1, 'Surface< REAL >'], │ │ │ │ │ ['../a00933.html#aa9500016cdd5cf88992541cc263a75c9', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface::Surface()'] │ │ │ │ │ ]], │ │ │ │ │ - ['surface_2eh_90', ['surface.h', ['../a00692.html', 1, '']]], │ │ │ │ │ + ['surface_2eh_90', ['surface.h', ['../a00689.html', 1, '']]], │ │ │ │ │ ['surfacefactory_91', ['surfacefactory', ['../a00941.html#ae54ee5a9e2bcb2bfdf395084395a0719', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::SurfaceFactory::SurfaceFactory(Sdc::SchemeType schemeType, Sdc::Options const &schemeOptions, Options const &limitOptions)'], │ │ │ │ │ ['../a00941.html#a5ac6bb6255796f79debe11e25b816093', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::SurfaceFactory::SurfaceFactory(SurfaceFactory const &)=delete'], │ │ │ │ │ ['../a00933.html#a3bdc23048cdd1242d0a429413fa89256', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface::SurfaceFactory'], │ │ │ │ │ ['../a00941.html', 1, 'SurfaceFactory'] │ │ │ │ │ ]], │ │ │ │ │ ['surfacefactory_2eh_92', ['surfaceFactory.h', ['../a00686.html', 1, '']]], │ │ │ │ │ ['surfacefactorycache_93', ['surfacefactorycache', ['../a00949.html#a3f63565868cb0b0871e2db37939ec0e2', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::SurfaceFactoryCache::SurfaceFactoryCache()'], │ │ │ │ │ ['../a00949.html#a704742f6a7a07e766b5320c8d6f2f745', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::SurfaceFactoryCache::SurfaceFactoryCache(SurfaceFactoryCache const &)=delete'], │ │ │ │ │ ['../a00949.html', 1, 'SurfaceFactoryCache'] │ │ │ │ │ ]], │ │ │ │ │ - ['surfacefactorycache_2eh_94', ['surfaceFactoryCache.h', ['../a00683.html', 1, '']]], │ │ │ │ │ + ['surfacefactorycache_2eh_94', ['surfaceFactoryCache.h', ['../a00680.html', 1, '']]], │ │ │ │ │ ['surfacefactorycachethreaded_95', ['surfacefactorycachethreaded', ['../a00953.html#a9e84b6f045809c700d7dc53c3a350afe', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::SurfaceFactoryCacheThreaded::SurfaceFactoryCacheThreaded()'], │ │ │ │ │ ['../a00953.html', 1, 'SurfaceFactoryCacheThreaded< MUTEX_TYPE, READ_LOCK_GUARD_TYPE, WRITE_LOCK_GUARD_TYPE >'] │ │ │ │ │ ]], │ │ │ │ │ ['surfacefactorymeshadapter_96', ['SurfaceFactoryMeshAdapter', ['../a00957.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr']]], │ │ │ │ │ - ['surfacefactorymeshadapter_2eh_97', ['surfaceFactoryMeshAdapter.h', ['../a00680.html', 1, '']]], │ │ │ │ │ + ['surfacefactorymeshadapter_2eh_97', ['surfaceFactoryMeshAdapter.h', ['../a00683.html', 1, '']]], │ │ │ │ │ ['synchronize_98', ['synchronize', ['../a01149.html#a0529a707250f9931f945ec49d4e428d2', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CLEvaluator::Synchronize(cl_command_queue queue)'], │ │ │ │ │ ['../a01149.html#a7e77f811e9d48160701e705bb4300388', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CLEvaluator::Synchronize(DEVICE_CONTEXT deviceContext)'], │ │ │ │ │ ['../a01165.html#ae339a533e5f7a5021c5a4b40ec09c208', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CpuEvaluator::Synchronize()'], │ │ │ │ │ ['../a01317.html#a9689407af718de4263562bb3a760c1dd', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::TbbEvaluator::Synchronize()'], │ │ │ │ │ ['../a01313.html#a9689407af718de4263562bb3a760c1dd', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::OmpEvaluator::Synchronize()'], │ │ │ │ │ ['../a01293.html#a7e02041f843415c1056ea2ca3f7d0b62', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MTLComputeEvaluator::Synchronize()'], │ │ │ │ │ ['../a01281.html#ab945364bf8cadb3d1f8285551d9d49f0', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::Mesh::Synchronize()'], │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_12.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -6,16 +6,16 @@ │ │ │ │ │ ['../a00912.html#a20e08be34d6183b6943ed7a1586eca4a', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::TbbEvalPatches(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int numPatchCoords, const PatchCoord *patchCoords, const PatchArray *patchArrayBuffer, const int *patchIndexBuffer, const PatchParam *patchParamBuffer)'] │ │ │ │ │ ]], │ │ │ │ │ ['tbbevalstencils_2', ['tbbevalstencils', ['../a00912.html#aa65ed860a2fa5935d99129a898a8f0b6', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::TbbEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, float *dstDuu, BufferDescriptor const &dstDuuDesc, float *dstDuv, BufferDescriptor const &dstDuvDesc, float *dstDvv, BufferDescriptor const &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, float const *duuWeights, float const *duvWeights, float const *dvvWeights, int start, int end)'], │ │ │ │ │ ['../a00912.html#af23c35537952bfdd493441e5c42ff2ed', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::TbbEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, int start, int end)'], │ │ │ │ │ ['../a00912.html#a4a6a0fcc01638f2a0316b32ad158b485', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::TbbEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)'] │ │ │ │ │ ]], │ │ │ │ │ ['tbbevaluator_3', ['TbbEvaluator', ['../a01317.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ - ['tbbevaluator_2eh_4', ['tbbEvaluator.h', ['../a00878.html', 1, '']]], │ │ │ │ │ - ['tbbkernel_2eh_5', ['tbbKernel.h', ['../a00872.html', 1, '']]], │ │ │ │ │ + ['tbbevaluator_2eh_4', ['tbbEvaluator.h', ['../a00875.html', 1, '']]], │ │ │ │ │ + ['tbbkernel_2eh_5', ['tbbKernel.h', ['../a00878.html', 1, '']]], │ │ │ │ │ ['tessellation_6', ['tessellation', ['../a00961.html', 1, 'Tessellation'], │ │ │ │ │ ['../a00961.html#ab03191ef31cf0d8b0bcc44f226804e87', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Tessellation::Tessellation(Tessellation const &)=delete'], │ │ │ │ │ ['../a00961.html#a7a3e89992f3cc492804ec9bc184a1674', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Tessellation::Tessellation()=delete'], │ │ │ │ │ ['../a00961.html#a65ee652b3607c97bb2b04a64c55d7f99', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Tessellation::Tessellation(Parameterization const &p, int numRates, int const rates[], Options const &options=Options())'], │ │ │ │ │ ['../a00961.html#a7f0af117d53701f7ca6e3eb2368b89bb', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Tessellation::Tessellation(Parameterization const &p, int uniformRate, Options const &options=Options())'] │ │ │ │ │ ]], │ │ │ │ │ ['tessellation_2eh_7', ['tessellation.h', ['../a00677.html', 1, '']]], │ │ │ │ │ @@ -24,21 +24,21 @@ │ │ │ │ │ ['../a01105.html#a8209f1b69b0162ee2e7065d91088113d', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyDescriptor::TopologyDescriptor()'] │ │ │ │ │ ]], │ │ │ │ │ ['topologydescriptor_2eh_10', ['topologyDescriptor.h', ['../a00713.html', 1, '']]], │ │ │ │ │ ['topologyerror_11', ['TopologyError', ['../a01117.html#a5458be6ce3f2e63c8d8555f4ab3b2b62', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefinerFactory']]], │ │ │ │ │ ['topologylevel_12', ['topologylevel', ['../a01113.html', 1, 'TopologyLevel'], │ │ │ │ │ ['../a01113.html#a03a8183081b34983ade155e3636ba835', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyLevel::TopologyLevel()'] │ │ │ │ │ ]], │ │ │ │ │ - ['topologylevel_2eh_13', ['topologyLevel.h', ['../a00707.html', 1, '']]], │ │ │ │ │ + ['topologylevel_2eh_13', ['topologyLevel.h', ['../a00710.html', 1, '']]], │ │ │ │ │ ['topologyrefiner_14', ['topologyrefiner', ['../a01121.html', 1, 'TopologyRefiner'], │ │ │ │ │ ['../a01113.html#a094d2e51437ecd5ecc6a0cf2c4ce1e78', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyLevel::TopologyRefiner'], │ │ │ │ │ ['../a01121.html#a91353962838bff64448014136e0e11ff', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::TopologyRefiner(Sdc::SchemeType type, Sdc::Options options=Sdc::Options())'], │ │ │ │ │ ['../a01121.html#a13c709a24feeed80409924510e3efc5e', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::TopologyRefiner(TopologyRefiner const &source)'] │ │ │ │ │ ]], │ │ │ │ │ - ['topologyrefiner_2eh_15', ['topologyRefiner.h', ['../a00710.html', 1, '']]], │ │ │ │ │ + ['topologyrefiner_2eh_15', ['topologyRefiner.h', ['../a00707.html', 1, '']]], │ │ │ │ │ ['topologyrefinerfactory_16', ['topologyrefinerfactory', ['../a01121.html#a7efec9ae15b61001dcf6a0de284914b7', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::TopologyRefinerFactory'], │ │ │ │ │ ['../a01117.html', 1, 'TopologyRefinerFactory< MESH >'] │ │ │ │ │ ]], │ │ │ │ │ ['topologyrefinerfactory_2eh_17', ['topologyRefinerFactory.h', ['../a00704.html', 1, '']]], │ │ │ │ │ ['topologyrefinerfactorybase_18', ['topologyrefinerfactorybase', ['../a01121.html#a7b09fef2ae2989a546c50a65add2091f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::TopologyRefinerFactoryBase'], │ │ │ │ │ ['../a01133.html', 1, 'TopologyRefinerFactoryBase'] │ │ │ │ │ ]], │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_2.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -35,9 +35,9 @@ │ │ │ │ │ ]], │ │ │ │ │ ['boundcontrolpoints_13', ['BoundControlPoints', ['../a00933.html#a22604a4489ed5fdedb0ef272de0fa637', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface']]], │ │ │ │ │ ['boundcontrolpointsfrommesh_14', ['BoundControlPointsFromMesh', ['../a00933.html#a8df5cf06cea51aeb6419fd698651ae3b', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface']]], │ │ │ │ │ ['bufferdescriptor_15', ['bufferdescriptor', ['../a01141.html', 1, 'BufferDescriptor'], │ │ │ │ │ ['../a01141.html#a958068066d1d10ae2a452ac57d9c0401', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::BufferDescriptor::BufferDescriptor(int o, int l, int s)'], │ │ │ │ │ ['../a01141.html#a446218762f5de8c77d06ee61e14b6b61', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::BufferDescriptor::BufferDescriptor()'] │ │ │ │ │ ]], │ │ │ │ │ - ['bufferdescriptor_2eh_16', ['bufferDescriptor.h', ['../a00896.html', 1, '']]] │ │ │ │ │ + ['bufferdescriptor_2eh_16', ['bufferDescriptor.h', ['../a00899.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_3.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -77,37 +77,37 @@ │ │ │ │ │ ['converttocompatiblestenciltable_3c_20far_3a_3astenciltable_2c_20far_3a_3astenciltable_2c_20id3d11devicecontext_20_3e_41', ['convertToCompatibleStencilTable< Far::StencilTable, Far::StencilTable, ID3D11DeviceContext >', ['../a00912.html#ab5753a2b0a0995c8e2259d2c4765f7df', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ ['converttocompatiblestenciltable_3c_20far_3a_3astenciltable_2c_20far_3a_3astenciltable_2c_20void_20_3e_42', ['convertToCompatibleStencilTable< Far::StencilTable, Far::StencilTable, void >', ['../a00912.html#a33f9830228f847fae1c30c9dffe02b5a', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ ['cornervertexindices_43', ['cornerVertexIndices', ['../a01105.html#a3bf794743edda29fbee0653b65b75ba4', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyDescriptor']]], │ │ │ │ │ ['cornerweights_44', ['cornerWeights', ['../a01105.html#a6d938f6b0a9ff0fa377ef675aa2c7fda', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyDescriptor']]], │ │ │ │ │ ['cpud3d11vertexbuffer_45', ['cpud3d11vertexbuffer', ['../a01161.html', 1, 'CpuD3D11VertexBuffer'], │ │ │ │ │ ['../a01161.html#a632143bc1ec4fbbca2148b0e9e87bc08', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CpuD3D11VertexBuffer::CpuD3D11VertexBuffer()'] │ │ │ │ │ ]], │ │ │ │ │ - ['cpud3d11vertexbuffer_2eh_46', ['cpuD3D11VertexBuffer.h', ['../a00842.html', 1, '']]], │ │ │ │ │ + ['cpud3d11vertexbuffer_2eh_46', ['cpuD3D11VertexBuffer.h', ['../a00845.html', 1, '']]], │ │ │ │ │ ['cpuevaluator_47', ['CpuEvaluator', ['../a01165.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ - ['cpuevaluator_2eh_48', ['cpuEvaluator.h', ['../a00899.html', 1, '']]], │ │ │ │ │ + ['cpuevaluator_2eh_48', ['cpuEvaluator.h', ['../a00896.html', 1, '']]], │ │ │ │ │ ['cpuglvertexbuffer_49', ['cpuglvertexbuffer', ['../a01169.html', 1, 'CpuGLVertexBuffer'], │ │ │ │ │ ['../a01169.html#a32dd2317d622c1b079e3219f97c86955', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CpuGLVertexBuffer::CpuGLVertexBuffer()'] │ │ │ │ │ ]], │ │ │ │ │ ['cpuglvertexbuffer_2eh_50', ['cpuGLVertexBuffer.h', ['../a00866.html', 1, '']]], │ │ │ │ │ ['cpumtlvertexbuffer_51', ['cpumtlvertexbuffer', ['../a01309.html', 1, 'CPUMTLVertexBuffer'], │ │ │ │ │ ['../a01309.html#a1457f342bc3007386104aa3d29277a67', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CPUMTLVertexBuffer::CPUMTLVertexBuffer()'] │ │ │ │ │ ]], │ │ │ │ │ ['cpupatchtable_52', ['cpupatchtable', ['../a01173.html', 1, 'CpuPatchTable'], │ │ │ │ │ ['../a01173.html#a3c19d1748852f36ba69a6557e5069e08', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CpuPatchTable::CpuPatchTable()'] │ │ │ │ │ ]], │ │ │ │ │ ['cpupatchtable_2eh_53', ['cpuPatchTable.h', ['../a00893.html', 1, '']]], │ │ │ │ │ ['cpuvertexbuffer_54', ['cpuvertexbuffer', ['../a01177.html#afa9168f4f1f046aea4ff94933ac48972', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CpuVertexBuffer::CpuVertexBuffer()'], │ │ │ │ │ ['../a01177.html', 1, 'CpuVertexBuffer'] │ │ │ │ │ ]], │ │ │ │ │ - ['cpuvertexbuffer_2eh_55', ['cpuVertexBuffer.h', ['../a00887.html', 1, '']]], │ │ │ │ │ + ['cpuvertexbuffer_2eh_55', ['cpuVertexBuffer.h', ['../a00884.html', 1, '']]], │ │ │ │ │ ['crease_56', ['crease', ['../a01333.html#a9659c3f2c73b80d9dc22763a6054079b', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Crease::Crease()'], │ │ │ │ │ ['../a01333.html#a75d5d7e54170ccf6481932916e0fa9c1', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Crease::Crease(Options const &options)'], │ │ │ │ │ ['../a01333.html', 1, 'Crease'] │ │ │ │ │ ]], │ │ │ │ │ - ['crease_2eh_57', ['crease.h', ['../a00776.html', 1, '']]], │ │ │ │ │ + ['crease_2eh_57', ['crease.h', ['../a00779.html', 1, '']]], │ │ │ │ │ ['crease_5fchaikin_58', ['CREASE_CHAIKIN', ['../a01337.html#a16ec522dc0398bf1435a912cd669ffb0a1e31a583663dd65a7b2feffeb24268b5', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Options']]], │ │ │ │ │ ['crease_5funiform_59', ['CREASE_UNIFORM', ['../a01337.html#a16ec522dc0398bf1435a912cd669ffb0a10f2956db48d2975424be2e52ebd544d', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Options']]], │ │ │ │ │ ['creasevertexindexpairs_60', ['creaseVertexIndexPairs', ['../a01105.html#a411a2a927b0270c9e4753dc219763ba5', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyDescriptor']]], │ │ │ │ │ ['creaseweights_61', ['creaseWeights', ['../a01105.html#a8cd977015d3ffffc1146c5a4e17d65e0', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyDescriptor']]], │ │ │ │ │ ['creasingmethod_62', ['CreasingMethod', ['../a01337.html#a16ec522dc0398bf1435a912cd669ffb0', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Sdc::Options']]], │ │ │ │ │ ['create_63', ['create', ['../a01249.html#ae38a4728f9debae7733ab48cfadd8312', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::GLStencilTableTBO::Create(Far::LimitStencilTable const *limitStencilTable, void *deviceContext=NULL)'], │ │ │ │ │ ['../a01249.html#a24a8210b637a5b0fca2b258de3b8b8a6', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::GLStencilTableTBO::Create(Far::StencilTable const *stencilTable, void *deviceContext=NULL)'], │ │ │ │ │ @@ -178,15 +178,15 @@ │ │ │ │ │ ['createvaryingsurface_66', ['CreateVaryingSurface', ['../a00941.html#a81638f2ff6818fd96aa7cd1ad3ed0703', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::SurfaceFactory']]], │ │ │ │ │ ['createvertexsurface_67', ['CreateVertexSurface', ['../a00941.html#a676cf019574c99fa77341ac09889192d', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::SurfaceFactory']]], │ │ │ │ │ ['cudaevaluator_68', ['CudaEvaluator', ['../a01185.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ ['cudaevaluator_2eh_69', ['cudaEvaluator.h', ['../a00788.html', 1, '']]], │ │ │ │ │ ['cudapatchtable_70', ['cudapatchtable', ['../a01189.html', 1, 'CudaPatchTable'], │ │ │ │ │ ['../a01189.html#aefa9c1a9175327a40e7cf46ed32ced2f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CudaPatchTable::CudaPatchTable()'] │ │ │ │ │ ]], │ │ │ │ │ - ['cudapatchtable_2eh_71', ['cudaPatchTable.h', ['../a00794.html', 1, '']]], │ │ │ │ │ + ['cudapatchtable_2eh_71', ['cudaPatchTable.h', ['../a00791.html', 1, '']]], │ │ │ │ │ ['cudastenciltable_72', ['cudastenciltable', ['../a01181.html#a45150c630c07bbeabd4b91145cecf087', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CudaStencilTable::CudaStencilTable()'], │ │ │ │ │ ['../a01181.html', 1, 'CudaStencilTable'], │ │ │ │ │ ['../a01181.html#af872fc469b3696a745d30d22c2b89c4c', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CudaStencilTable::CudaStencilTable()'] │ │ │ │ │ ]], │ │ │ │ │ ['cudavertexbuffer_73', ['cudavertexbuffer', ['../a01193.html#af6cb32d896f7815cac1969c857845ba8', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::CudaVertexBuffer::CudaVertexBuffer()'], │ │ │ │ │ ['../a01193.html', 1, 'CudaVertexBuffer'] │ │ │ │ │ ]], │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_4.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,12 +1,12 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ ['d3d11computeevaluator_0', ['d3d11computeevaluator', ['../a01201.html', 1, 'D3D11ComputeEvaluator'], │ │ │ │ │ ['../a01201.html#aa81511d3938d70d67a62217951cb8eb7', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::D3D11ComputeEvaluator::D3D11ComputeEvaluator()'] │ │ │ │ │ ]], │ │ │ │ │ - ['d3d11computeevaluator_2eh_1', ['d3d11ComputeEvaluator.h', ['../a00845.html', 1, '']]], │ │ │ │ │ + ['d3d11computeevaluator_2eh_1', ['d3d11ComputeEvaluator.h', ['../a00842.html', 1, '']]], │ │ │ │ │ ['d3d11legacygregorypatchtable_2', ['d3d11legacygregorypatchtable', ['../a01205.html', 1, 'D3D11LegacyGregoryPatchTable'], │ │ │ │ │ ['../a01205.html#af138b4535e4db5f013225c5924e0b243', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::D3D11LegacyGregoryPatchTable::D3D11LegacyGregoryPatchTable()'] │ │ │ │ │ ]], │ │ │ │ │ ['d3d11legacygregorypatchtable_2eh_3', ['d3d11LegacyGregoryPatchTable.h', ['../a00839.html', 1, '']]], │ │ │ │ │ ['d3d11mesh_2eh_4', ['d3d11Mesh.h', ['../a00830.html', 1, '']]], │ │ │ │ │ ['d3d11meshinterface_5', ['D3D11MeshInterface', ['../a00912.html#ae5c8e80d05d6eaee105d8eecfa9ab609', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ ['d3d11patchtable_6', ['d3d11patchtable', ['../a01209.html#ac81ed5f09e3d3a2aae5a01802b343a6d', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::D3D11PatchTable::D3D11PatchTable()'], │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_a.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,16 +1,16 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ ['length_0', ['length', ['../a01141.html#a9f59b34b1f25fe00023291b678246bcc', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::BufferDescriptor']]], │ │ │ │ │ - ['level_2eh_1', ['level.h', ['../a00755.html', 1, '']]], │ │ │ │ │ + ['level_2eh_1', ['level.h', ['../a00749.html', 1, '']]], │ │ │ │ │ ['limit_2', ['limit', ['../a01029.html#a2cf4c50a1117c44ba4d11db92b067401', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PrimvarRefinerReal::Limit(T const &src, U &dstPos, U1 &dstTan1, U2 &dstTan2) const'], │ │ │ │ │ ['../a01029.html#a0357839a7fabaa02f1d6d6a3c75e1ec2', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PrimvarRefinerReal::Limit(T const &src, U &dstPos) const'] │ │ │ │ │ ]], │ │ │ │ │ ['limitfacevarying_3', ['LimitFaceVarying', ['../a01029.html#afdee0e9e9c6edd34c96892efff808a87', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PrimvarRefinerReal']]], │ │ │ │ │ ['limits_4', ['Limits', ['../a00917.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr']]], │ │ │ │ │ - ['limits_2eh_5', ['limits.h', ['../a00698.html', 1, '']]], │ │ │ │ │ + ['limits_2eh_5', ['limits.h', ['../a00695.html', 1, '']]], │ │ │ │ │ ['limitstencil_6', ['limitstencil', ['../a01073.html', 1, 'LimitStencil'], │ │ │ │ │ ['../a01073.html#a51e1d601373aa0cd9ce70b630ce22adf', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencil::LimitStencil(int *size, Index *indices, float *weights, float *duWeights=0, float *dvWeights=0, float *duuWeights=0, float *duvWeights=0, float *dvvWeights=0)'], │ │ │ │ │ ['../a01073.html#a071ea9b75540c3d54d9bf934fc944e5a', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencil::LimitStencil(BaseStencil const &other)'] │ │ │ │ │ ]], │ │ │ │ │ ['limitstencilreal_7', ['limitstencilreal', ['../a01069.html', 1, 'LimitStencilReal< REAL >'], │ │ │ │ │ ['../a01069.html#ad6ade692f92a3bf50c813a82bd63d4c7', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilReal::LimitStencilReal()'] │ │ │ │ │ ]], │ │ │ │ │ @@ -52,9 +52,9 @@ │ │ │ │ │ ['../a00993.html#af22fd3afdc99098cc89463f530de5011', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PatchTable::LocalPointVaryingStencilPrecisionMatchesType() const'] │ │ │ │ │ ]], │ │ │ │ │ ['locationarray_23', ['locationarray', ['../a01093.html#a23ed026fe98bd57164dbb601791f51fc', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilTableFactoryReal::LocationArray::LocationArray()'], │ │ │ │ │ ['../a01093.html', 1, 'LimitStencilTableFactoryReal< REAL >::LocationArray'] │ │ │ │ │ ]], │ │ │ │ │ ['locationarrayvec_24', ['LocationArrayVec', ['../a01049.html#a940880e2d35dea72f52db5bcdc9c94b7', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilTableFactoryReal']]], │ │ │ │ │ ['loop_25', ['LOOP', ['../a00973.html#a1d1cfd8ffb84e947f82999c682b666a7a61f7f1587bd5fe978d9ff3ece8d0624c', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PatchDescriptor']]], │ │ │ │ │ - ['loopscheme_2eh_26', ['loopScheme.h', ['../a00770.html', 1, '']]] │ │ │ │ │ + ['loopscheme_2eh_26', ['loopScheme.h', ['../a00776.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_b.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -26,25 +26,25 @@ │ │ │ │ │ ['mode_20', ['mode', ['../a01045.html#a46c8a310cf4c094f8c80e1cb8dc1f911', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::StencilTableFactoryReal::Mode'], │ │ │ │ │ ['../a01049.html#a46c8a310cf4c094f8c80e1cb8dc1f911', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::LimitStencilTableFactoryReal::Mode'] │ │ │ │ │ ]], │ │ │ │ │ ['mtlcommon_2eh_21', ['mtlCommon.h', ['../a00806.html', 1, '']]], │ │ │ │ │ ['mtlcomputeevaluator_22', ['mtlcomputeevaluator', ['../a01293.html#a10015b2c4f90f3a11e60cc88dcbb9d6b', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MTLComputeEvaluator::MTLComputeEvaluator()'], │ │ │ │ │ ['../a01293.html', 1, 'MTLComputeEvaluator'] │ │ │ │ │ ]], │ │ │ │ │ - ['mtlcomputeevaluator_2eh_23', ['mtlComputeEvaluator.h', ['../a00821.html', 1, '']]], │ │ │ │ │ + ['mtlcomputeevaluator_2eh_23', ['mtlComputeEvaluator.h', ['../a00824.html', 1, '']]], │ │ │ │ │ ['mtlcontext_24', ['MTLContext', ['../a01285.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ ['mtllegacygregorypatchtable_25', ['MTLLegacyGregoryPatchTable', ['../a01297.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ - ['mtllegacygregorypatchtable_2eh_26', ['mtlLegacyGregoryPatchTable.h', ['../a00818.html', 1, '']]], │ │ │ │ │ - ['mtlmesh_2eh_27', ['mtlMesh.h', ['../a00812.html', 1, '']]], │ │ │ │ │ + ['mtllegacygregorypatchtable_2eh_26', ['mtlLegacyGregoryPatchTable.h', ['../a00821.html', 1, '']]], │ │ │ │ │ + ['mtlmesh_2eh_27', ['mtlMesh.h', ['../a00809.html', 1, '']]], │ │ │ │ │ ['mtlmeshinterface_28', ['MTLMeshInterface', ['../a00912.html#aa41e5b43fe46eeb0f97ff6ebdb1935aa', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ ['mtlpatchshadersource_29', ['MTLPatchShaderSource', ['../a01301.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ - ['mtlpatchshadersource_2eh_30', ['mtlPatchShaderSource.h', ['../a00809.html', 1, '']]], │ │ │ │ │ + ['mtlpatchshadersource_2eh_30', ['mtlPatchShaderSource.h', ['../a00812.html', 1, '']]], │ │ │ │ │ ['mtlpatchtable_31', ['mtlpatchtable', ['../a01305.html', 1, 'MTLPatchTable'], │ │ │ │ │ ['../a01305.html#a3f197c2ae3862390d72e7443a2525187', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MTLPatchTable::MTLPatchTable()'] │ │ │ │ │ ]], │ │ │ │ │ ['mtlpatchtable_2eh_32', ['mtlPatchTable.h', ['../a00815.html', 1, '']]], │ │ │ │ │ ['mtlstenciltable_33', ['mtlstenciltable', ['../a01289.html', 1, 'MTLStencilTable'], │ │ │ │ │ ['../a01289.html#a015dc72c3360b4841ee2b3feb06c106f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MTLStencilTable::MTLStencilTable(Far::LimitStencilTable const *stencilTable, MTLContext *context)'], │ │ │ │ │ ['../a01289.html#a45e329ffe9fe4e32a1b21bfc89a6763f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MTLStencilTable::MTLStencilTable(Far::StencilTable const *stencilTable, MTLContext *context)'] │ │ │ │ │ ]], │ │ │ │ │ - ['mtlvertexbuffer_2eh_34', ['mtlVertexBuffer.h', ['../a00824.html', 1, '']]] │ │ │ │ │ + ['mtlvertexbuffer_2eh_34', ['mtlVertexBuffer.h', ['../a00818.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_d.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -2,17 +2,17 @@ │ │ │ │ │ ['offset_0', ['offset', ['../a01141.html#aed7ea92f45bd273dde380a45ddced592', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::BufferDescriptor']]], │ │ │ │ │ ['ompevalstencils_1', ['ompevalstencils', ['../a00912.html#a44a05502feb5015035bc81b93cffb99c', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::OmpEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, float *dstDuu, BufferDescriptor const &dstDuuDesc, float *dstDuv, BufferDescriptor const &dstDuvDesc, float *dstDvv, BufferDescriptor const &dstDvvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, float const *duuWeights, float const *duvWeights, float const *dvvWeights, int start, int end)'], │ │ │ │ │ ['../a00912.html#a907dc53421460557871ddc35f77751f5', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::OmpEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, float *dstDu, BufferDescriptor const &dstDuDesc, float *dstDv, BufferDescriptor const &dstDvDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, float const *duWeights, float const *dvWeights, int start, int end)'], │ │ │ │ │ ['../a00912.html#a870745ff3e883b32547d4db42b3be2bd', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::OmpEvalStencils(float const *src, BufferDescriptor const &srcDesc, float *dst, BufferDescriptor const &dstDesc, int const *sizes, int const *offsets, int const *indices, float const *weights, int start, int end)'] │ │ │ │ │ ]], │ │ │ │ │ ['ompevaluator_2', ['OmpEvaluator', ['../a01313.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ ['ompevaluator_2eh_3', ['ompEvaluator.h', ['../a00881.html', 1, '']]], │ │ │ │ │ - ['ompkernel_2eh_4', ['ompKernel.h', ['../a00875.html', 1, '']]], │ │ │ │ │ - ['opencl_2eh_5', ['opencl.h', ['../a00791.html', 1, '']]], │ │ │ │ │ - ['opengl_2eh_6', ['opengl.h', ['../a00884.html', 1, '']]], │ │ │ │ │ + ['ompkernel_2eh_4', ['ompKernel.h', ['../a00872.html', 1, '']]], │ │ │ │ │ + ['opencl_2eh_5', ['opencl.h', ['../a00794.html', 1, '']]], │ │ │ │ │ + ['opengl_2eh_6', ['opengl.h', ['../a00887.html', 1, '']]], │ │ │ │ │ ['opensubdiv_7', ['OpenSubdiv', ['../a00905.html', 1, '']]], │ │ │ │ │ ['opensubdiv_3a_3aopensubdiv_5fversion_8', ['OPENSUBDIV_VERSION', ['../a00906.html', 1, 'OpenSubdiv']]], │ │ │ │ │ ['opensubdiv_3a_3aopensubdiv_5fversion_3a_3abfr_9', ['Bfr', ['../a00907.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION']]], │ │ │ │ │ ['opensubdiv_3a_3aopensubdiv_5fversion_3a_3afar_10', ['Far', ['../a00908.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION']]], │ │ │ │ │ ['opensubdiv_3a_3aopensubdiv_5fversion_3a_3aosd_11', ['Osd', ['../a00912.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION']]], │ │ │ │ │ ['opensubdiv_3a_3aopensubdiv_5fversion_3a_3asdc_12', ['Sdc', ['../a00913.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION']]], │ │ │ │ │ ['opensubdiv_3a_3aopensubdiv_5fversion_3a_3avtr_13', ['Vtr', ['../a00909.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION']]], │ │ │ │ │ @@ -47,12 +47,12 @@ │ │ │ │ │ ['../a00965.html#a28d39a844c3a37ab61d32ab7c6352f09', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Tessellation::Options::Options()'], │ │ │ │ │ ['../a00945.html#a28d39a844c3a37ab61d32ab7c6352f09', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::SurfaceFactory::Options::Options()'], │ │ │ │ │ ['../a01021.html', 1, 'PatchTableFactory::Options'], │ │ │ │ │ ['../a01085.html', 1, 'StencilTableFactoryReal< REAL >::Options'], │ │ │ │ │ ['../a01137.html', 1, 'TopologyRefinerFactory< MESH >::Options'], │ │ │ │ │ ['../a01337.html', 1, 'Options'] │ │ │ │ │ ]], │ │ │ │ │ - ['options_2eh_20', ['options.h', ['../a00779.html', 1, '']]], │ │ │ │ │ + ['options_2eh_20', ['options.h', ['../a00773.html', 1, '']]], │ │ │ │ │ ['orderverticesfromfacesfirst_21', ['orderverticesfromfacesfirst', ['../a01125.html#a3b1e47f9568213cc322ef29a84c932b6', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::UniformOptions::orderVerticesFromFacesFirst'], │ │ │ │ │ ['../a01129.html#a3b1e47f9568213cc322ef29a84c932b6', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::AdaptiveOptions::orderVerticesFromFacesFirst'] │ │ │ │ │ ]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/all_e.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,14 +1,14 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ ['parameterization_0', ['parameterization', ['../a00921.html#a64a4b29d36851a8d83be05af5b25f886', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Parameterization::Parameterization(Parameterization const &)=default'], │ │ │ │ │ ['../a00921.html#aa7e0b89d67d34c1dd7a37cdce95f9e2c', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Parameterization::Parameterization()'], │ │ │ │ │ ['../a00921.html#a301ad64c8ae0a3ba3af84377138a069f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Parameterization::Parameterization(Sdc::SchemeType scheme, int faceSize)'], │ │ │ │ │ ['../a00921.html', 1, 'Parameterization'] │ │ │ │ │ ]], │ │ │ │ │ - ['parameterization_2eh_1', ['parameterization.h', ['../a00695.html', 1, '']]], │ │ │ │ │ + ['parameterization_2eh_1', ['parameterization.h', ['../a00698.html', 1, '']]], │ │ │ │ │ ['patcharray_2', ['patcharray', ['../a01325.html', 1, 'PatchArray'], │ │ │ │ │ ['../a01325.html#ad9821423935395f540ff8d37d907600a', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::PatchArray::PatchArray(Far::PatchDescriptor regDesc_in, Far::PatchDescriptor irregDesc_in, int numPatches_in, int indexBase_in, int primitiveIdBase_in)'], │ │ │ │ │ ['../a01325.html#a9c551db8af15f4a0ddf4c2a13ce2505e', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::PatchArray::PatchArray(Far::PatchDescriptor desc_in, int numPatches_in, int indexBase_in, int primitiveIdBase_in)'] │ │ │ │ │ ]], │ │ │ │ │ ['patcharrayvector_3', ['PatchArrayVector', ['../a00912.html#a98098cd229f60d2397d84a76fe654a31', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd']]], │ │ │ │ │ ['patchbuilder_4', ['PatchBuilder', ['../a01121.html#a97612a1a955f8b65e6d7e7761ed1cef7', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner']]], │ │ │ │ │ ['patchcoord_5', ['patchcoord', ['../a01321.html#abe64006c4fe55b720f483bd7711bf216', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::PatchCoord::PatchCoord(Far::PatchTable::PatchHandle handleArg, float sArg, float tArg)'], │ │ │ │ │ @@ -45,15 +45,15 @@ │ │ │ │ │ ['../a01269.html#adf9352136d44e5999629c6b4530bf4e0', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::MeshInterface::PatchTable'] │ │ │ │ │ ]], │ │ │ │ │ ['patchtable_2eh_20', ['patchTable.h', ['../a00731.html', 1, '']]], │ │ │ │ │ ['patchtablebuilder_21', ['patchtablebuilder', ['../a00993.html#ad452cef79832abb71eef0c3d88acc1a0', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PatchTable::PatchTableBuilder'], │ │ │ │ │ ['../a01121.html#ad452cef79832abb71eef0c3d88acc1a0', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::PatchTableBuilder'] │ │ │ │ │ ]], │ │ │ │ │ ['patchtablefactory_22', ['PatchTableFactory', ['../a01017.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far']]], │ │ │ │ │ - ['patchtablefactory_2eh_23', ['patchTableFactory.h', ['../a00725.html', 1, '']]], │ │ │ │ │ + ['patchtablefactory_2eh_23', ['patchTableFactory.h', ['../a00728.html', 1, '']]], │ │ │ │ │ ['patchtagvector_24', ['PatchTagVector', ['../a01017.html#a37218ea13f75caee4c93cc4e94d26060', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PatchTableFactory']]], │ │ │ │ │ ['patchvertstable_25', ['PatchVertsTable', ['../a00993.html#a9484ab8a323750c2f639ee8709b1349b', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PatchTable']]], │ │ │ │ │ ['pointdescriptor_26', ['pointdescriptor', ['../a00937.html', 1, 'Surface< REAL >::PointDescriptor'], │ │ │ │ │ ['../a00937.html#ac60ab7fa3966237e2de95cc60defa4de', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface::PointDescriptor::PointDescriptor()'], │ │ │ │ │ ['../a00937.html#a69d66788e741236b1176159a1d609189', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface::PointDescriptor::PointDescriptor(int n)'], │ │ │ │ │ ['../a00937.html#a6e6069bdfef867e798fe863f40f4274a', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Surface::PointDescriptor::PointDescriptor(int n, int m)'] │ │ │ │ │ ]], │ │ │ │ │ @@ -69,15 +69,15 @@ │ │ │ │ │ ['preservequads_36', ['preservequads', ['../a00965.html#a98820ec764e776bd556a9b80b872b78f', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Tessellation::Options::PreserveQuads(bool on)'], │ │ │ │ │ ['../a00965.html#ae2ec197b850e8bd12878cc67a503a07a', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Bfr::Tessellation::Options::PreserveQuads() const'] │ │ │ │ │ ]], │ │ │ │ │ ['primitiveidbase_37', ['primitiveIdBase', ['../a01325.html#a5a054ce6862ecc6ea8c404fadb1c9a15', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Osd::PatchArray']]], │ │ │ │ │ ['primvarrefiner_38', ['primvarrefiner', ['../a01037.html#a643d81a2ae20ba1897433f5af5a3697a', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PrimvarRefiner::PrimvarRefiner()'], │ │ │ │ │ ['../a01037.html', 1, 'PrimvarRefiner'] │ │ │ │ │ ]], │ │ │ │ │ - ['primvarrefiner_2eh_39', ['primvarRefiner.h', ['../a00728.html', 1, '']]], │ │ │ │ │ + ['primvarrefiner_2eh_39', ['primvarRefiner.h', ['../a00719.html', 1, '']]], │ │ │ │ │ ['primvarrefinerreal_40', ['primvarrefinerreal', ['../a01121.html#a2cb48b58c1c2ecef25abb39339a95ac1', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::TopologyRefiner::PrimvarRefinerReal'], │ │ │ │ │ ['../a01029.html#a1fe1fbda93c01c326f13929d1c3c6247', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PrimvarRefinerReal::PrimvarRefinerReal()'], │ │ │ │ │ ['../a01029.html', 1, 'PrimvarRefinerReal< REAL >'] │ │ │ │ │ ]], │ │ │ │ │ ['primvarrefinerreal_3c_20float_20_3e_41', ['PrimvarRefinerReal< float >', ['../a01029.html', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far']]], │ │ │ │ │ ['print_42', ['print', ['../a00973.html#acd0f82d3c49b8a5dd436d4003c44b713', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PatchDescriptor::print()'], │ │ │ │ │ ['../a00993.html#acd0f82d3c49b8a5dd436d4003c44b713', 1, 'OpenSubdiv::OPENSUBDIV_VERSION::Far::PatchTable::print()'] │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_1.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,4 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ ['bilinearscheme_2eh_0', ['bilinearScheme.h', ['../a00785.html', 1, '']]], │ │ │ │ │ - ['bufferdescriptor_2eh_1', ['bufferDescriptor.h', ['../a00896.html', 1, '']]] │ │ │ │ │ + ['bufferdescriptor_2eh_1', ['bufferDescriptor.h', ['../a00899.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_2.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,16 +1,16 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ ['catmarkscheme_2eh_0', ['catmarkScheme.h', ['../a00782.html', 1, '']]], │ │ │ │ │ ['clevaluator_2eh_1', ['clEvaluator.h', ['../a00803.html', 1, '']]], │ │ │ │ │ ['clpatchtable_2eh_2', ['clPatchTable.h', ['../a00800.html', 1, '']]], │ │ │ │ │ ['clvertexbuffer_2eh_3', ['clVertexBuffer.h', ['../a00797.html', 1, '']]], │ │ │ │ │ ['componentinterfaces_2eh_4', ['componentInterfaces.h', ['../a00764.html', 1, '']]], │ │ │ │ │ - ['cpud3d11vertexbuffer_2eh_5', ['cpuD3D11VertexBuffer.h', ['../a00842.html', 1, '']]], │ │ │ │ │ - ['cpuevaluator_2eh_6', ['cpuEvaluator.h', ['../a00899.html', 1, '']]], │ │ │ │ │ + ['cpud3d11vertexbuffer_2eh_5', ['cpuD3D11VertexBuffer.h', ['../a00845.html', 1, '']]], │ │ │ │ │ + ['cpuevaluator_2eh_6', ['cpuEvaluator.h', ['../a00896.html', 1, '']]], │ │ │ │ │ ['cpuglvertexbuffer_2eh_7', ['cpuGLVertexBuffer.h', ['../a00866.html', 1, '']]], │ │ │ │ │ ['cpupatchtable_2eh_8', ['cpuPatchTable.h', ['../a00893.html', 1, '']]], │ │ │ │ │ - ['cpuvertexbuffer_2eh_9', ['cpuVertexBuffer.h', ['../a00887.html', 1, '']]], │ │ │ │ │ - ['crease_2eh_10', ['crease.h', ['../a00776.html', 1, '']]], │ │ │ │ │ + ['cpuvertexbuffer_2eh_9', ['cpuVertexBuffer.h', ['../a00884.html', 1, '']]], │ │ │ │ │ + ['crease_2eh_10', ['crease.h', ['../a00779.html', 1, '']]], │ │ │ │ │ ['cudaevaluator_2eh_11', ['cudaEvaluator.h', ['../a00788.html', 1, '']]], │ │ │ │ │ - ['cudapatchtable_2eh_12', ['cudaPatchTable.h', ['../a00794.html', 1, '']]], │ │ │ │ │ + ['cudapatchtable_2eh_12', ['cudaPatchTable.h', ['../a00791.html', 1, '']]], │ │ │ │ │ ['cudavertexbuffer_2eh_13', ['cudaVertexBuffer.h', ['../a00902.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_3.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,7 +1,7 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ - ['d3d11computeevaluator_2eh_0', ['d3d11ComputeEvaluator.h', ['../a00845.html', 1, '']]], │ │ │ │ │ + ['d3d11computeevaluator_2eh_0', ['d3d11ComputeEvaluator.h', ['../a00842.html', 1, '']]], │ │ │ │ │ ['d3d11legacygregorypatchtable_2eh_1', ['d3d11LegacyGregoryPatchTable.h', ['../a00839.html', 1, '']]], │ │ │ │ │ ['d3d11mesh_2eh_2', ['d3d11Mesh.h', ['../a00830.html', 1, '']]], │ │ │ │ │ ['d3d11patchtable_2eh_3', ['d3d11PatchTable.h', ['../a00836.html', 1, '']]], │ │ │ │ │ ['d3d11vertexbuffer_2eh_4', ['d3d11VertexBuffer.h', ['../a00833.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_8.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,5 +1,5 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ - ['level_2eh_0', ['level.h', ['../a00755.html', 1, '']]], │ │ │ │ │ - ['limits_2eh_1', ['limits.h', ['../a00698.html', 1, '']]], │ │ │ │ │ - ['loopscheme_2eh_2', ['loopScheme.h', ['../a00770.html', 1, '']]] │ │ │ │ │ + ['level_2eh_0', ['level.h', ['../a00749.html', 1, '']]], │ │ │ │ │ + ['limits_2eh_1', ['limits.h', ['../a00695.html', 1, '']]], │ │ │ │ │ + ['loopscheme_2eh_2', ['loopScheme.h', ['../a00776.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_9.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,10 +1,10 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ ['mesh_2eh_0', ['mesh.h', ['../a00890.html', 1, '']]], │ │ │ │ │ ['mtlcommon_2eh_1', ['mtlCommon.h', ['../a00806.html', 1, '']]], │ │ │ │ │ - ['mtlcomputeevaluator_2eh_2', ['mtlComputeEvaluator.h', ['../a00821.html', 1, '']]], │ │ │ │ │ - ['mtllegacygregorypatchtable_2eh_3', ['mtlLegacyGregoryPatchTable.h', ['../a00818.html', 1, '']]], │ │ │ │ │ - ['mtlmesh_2eh_4', ['mtlMesh.h', ['../a00812.html', 1, '']]], │ │ │ │ │ - ['mtlpatchshadersource_2eh_5', ['mtlPatchShaderSource.h', ['../a00809.html', 1, '']]], │ │ │ │ │ + ['mtlcomputeevaluator_2eh_2', ['mtlComputeEvaluator.h', ['../a00824.html', 1, '']]], │ │ │ │ │ + ['mtllegacygregorypatchtable_2eh_3', ['mtlLegacyGregoryPatchTable.h', ['../a00821.html', 1, '']]], │ │ │ │ │ + ['mtlmesh_2eh_4', ['mtlMesh.h', ['../a00809.html', 1, '']]], │ │ │ │ │ + ['mtlpatchshadersource_2eh_5', ['mtlPatchShaderSource.h', ['../a00812.html', 1, '']]], │ │ │ │ │ ['mtlpatchtable_2eh_6', ['mtlPatchTable.h', ['../a00815.html', 1, '']]], │ │ │ │ │ - ['mtlvertexbuffer_2eh_7', ['mtlVertexBuffer.h', ['../a00824.html', 1, '']]] │ │ │ │ │ + ['mtlvertexbuffer_2eh_7', ['mtlVertexBuffer.h', ['../a00818.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_a.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,7 +1,7 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ ['ompevaluator_2eh_0', ['ompEvaluator.h', ['../a00881.html', 1, '']]], │ │ │ │ │ - ['ompkernel_2eh_1', ['ompKernel.h', ['../a00875.html', 1, '']]], │ │ │ │ │ - ['opencl_2eh_2', ['opencl.h', ['../a00791.html', 1, '']]], │ │ │ │ │ - ['opengl_2eh_3', ['opengl.h', ['../a00884.html', 1, '']]], │ │ │ │ │ - ['options_2eh_4', ['options.h', ['../a00779.html', 1, '']]] │ │ │ │ │ + ['ompkernel_2eh_1', ['ompKernel.h', ['../a00872.html', 1, '']]], │ │ │ │ │ + ['opencl_2eh_2', ['opencl.h', ['../a00794.html', 1, '']]], │ │ │ │ │ + ['opengl_2eh_3', ['opengl.h', ['../a00887.html', 1, '']]], │ │ │ │ │ + ['options_2eh_4', ['options.h', ['../a00773.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_b.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,10 +1,10 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ - ['parameterization_2eh_0', ['parameterization.h', ['../a00695.html', 1, '']]], │ │ │ │ │ + ['parameterization_2eh_0', ['parameterization.h', ['../a00698.html', 1, '']]], │ │ │ │ │ ['patchdescriptor_2eh_1', ['patchDescriptor.h', ['../a00740.html', 1, '']]], │ │ │ │ │ ['patchmap_2eh_2', ['patchMap.h', ['../a00734.html', 1, '']]], │ │ │ │ │ ['patchparam_2eh_3', ['patchParam.h', ['../a00737.html', 1, '']]], │ │ │ │ │ ['patchtable_2eh_4', ['patchTable.h', ['../a00731.html', 1, '']]], │ │ │ │ │ - ['patchtablefactory_2eh_5', ['patchTableFactory.h', ['../a00725.html', 1, '']]], │ │ │ │ │ - ['primvarrefiner_2eh_6', ['primvarRefiner.h', ['../a00728.html', 1, '']]], │ │ │ │ │ + ['patchtablefactory_2eh_5', ['patchTableFactory.h', ['../a00728.html', 1, '']]], │ │ │ │ │ + ['primvarrefiner_2eh_6', ['primvarRefiner.h', ['../a00719.html', 1, '']]], │ │ │ │ │ ['ptexindices_2eh_7', ['ptexIndices.h', ['../a00722.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_c.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,4 +1,4 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ - ['refinement_2eh_0', ['refinement.h', ['../a00752.html', 1, '']]], │ │ │ │ │ - ['refinersurfacefactory_2eh_1', ['refinerSurfaceFactory.h', ['../a00689.html', 1, '']]] │ │ │ │ │ + ['refinement_2eh_0', ['refinement.h', ['../a00755.html', 1, '']]], │ │ │ │ │ + ['refinersurfacefactory_2eh_1', ['refinerSurfaceFactory.h', ['../a00692.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_d.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,11 +1,11 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ - ['scheme_2eh_0', ['scheme.h', ['../a00773.html', 1, '']]], │ │ │ │ │ - ['sparseselector_2eh_1', ['sparseSelector.h', ['../a00749.html', 1, '']]], │ │ │ │ │ + ['scheme_2eh_0', ['scheme.h', ['../a00770.html', 1, '']]], │ │ │ │ │ + ['sparseselector_2eh_1', ['sparseSelector.h', ['../a00752.html', 1, '']]], │ │ │ │ │ ['stackbuffer_2eh_2', ['stackBuffer.h', ['../a00746.html', 1, '']]], │ │ │ │ │ - ['stenciltable_2eh_3', ['stencilTable.h', ['../a00716.html', 1, '']]], │ │ │ │ │ - ['stenciltablefactory_2eh_4', ['stencilTableFactory.h', ['../a00719.html', 1, '']]], │ │ │ │ │ - ['surface_2eh_5', ['surface.h', ['../a00692.html', 1, '']]], │ │ │ │ │ + ['stenciltable_2eh_3', ['stencilTable.h', ['../a00725.html', 1, '']]], │ │ │ │ │ + ['stenciltablefactory_2eh_4', ['stencilTableFactory.h', ['../a00716.html', 1, '']]], │ │ │ │ │ + ['surface_2eh_5', ['surface.h', ['../a00689.html', 1, '']]], │ │ │ │ │ ['surfacefactory_2eh_6', ['surfaceFactory.h', ['../a00686.html', 1, '']]], │ │ │ │ │ - ['surfacefactorycache_2eh_7', ['surfaceFactoryCache.h', ['../a00683.html', 1, '']]], │ │ │ │ │ - ['surfacefactorymeshadapter_2eh_8', ['surfaceFactoryMeshAdapter.h', ['../a00680.html', 1, '']]] │ │ │ │ │ + ['surfacefactorycache_2eh_7', ['surfaceFactoryCache.h', ['../a00680.html', 1, '']]], │ │ │ │ │ + ['surfacefactorymeshadapter_2eh_8', ['surfaceFactoryMeshAdapter.h', ['../a00683.html', 1, '']]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/doxy_html/search/files_e.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,14 +1,14 @@ │ │ │ │ │ var searchData = [ │ │ │ │ │ - ['tbbevaluator_2eh_0', ['tbbEvaluator.h', ['../a00878.html', 1, '']]], │ │ │ │ │ - ['tbbkernel_2eh_1', ['tbbKernel.h', ['../a00872.html', 1, '']]], │ │ │ │ │ + ['tbbevaluator_2eh_0', ['tbbEvaluator.h', ['../a00875.html', 1, '']]], │ │ │ │ │ + ['tbbkernel_2eh_1', ['tbbKernel.h', ['../a00878.html', 1, '']]], │ │ │ │ │ ['tessellation_2eh_2', ['tessellation.h', ['../a00677.html', 1, '']]], │ │ │ │ │ ['topologydescriptor_2eh_3', ['topologyDescriptor.h', ['../a00713.html', 1, '']]], │ │ │ │ │ - ['topologylevel_2eh_4', ['topologyLevel.h', ['../a00707.html', 1, '']]], │ │ │ │ │ - ['topologyrefiner_2eh_5', ['topologyRefiner.h', ['../a00710.html', 1, '']]], │ │ │ │ │ + ['topologylevel_2eh_4', ['topologyLevel.h', ['../a00710.html', 1, '']]], │ │ │ │ │ + ['topologyrefiner_2eh_5', ['topologyRefiner.h', ['../a00707.html', 1, '']]], │ │ │ │ │ ['topologyrefinerfactory_2eh_6', ['topologyRefinerFactory.h', ['../a00704.html', 1, '']]], │ │ │ │ │ ['types_2eh_7', ['types.h', ['../a01486.html', 1, '(Global Namespace)'], │ │ │ │ │ ['../a01489.html', 1, '(Global Namespace)'], │ │ │ │ │ ['../a01492.html', 1, '(Global Namespace)'], │ │ │ │ │ ['../a01495.html', 1, '(Global Namespace)'] │ │ │ │ │ ]] │ │ │ │ │ ]; │ │ │ ├── ./usr/share/doc/opensubdiv/tipuesearch/tipuesearch_content.js │ │ │ │ ├── js-beautify {} │ │ │ │ │ @@ -1,88 +1,83 @@ │ │ │ │ │ var tipuesearch = { │ │ │ │ │ "pages": [{ │ │ │ │ │ - "title": "osd_tutorial_0.cpp", │ │ │ │ │ - "text": "osd_tutorial_0.cpp osd_tutorial_0.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsosdtutorial_0osd_tutorial_0.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial demonstrates the manipulation of Osd Evaluator and BufferDescriptor. include opensubdivfartopologyDescriptor.h include opensubdivfarstencilTableFactory.h include opensubdivosdcpuEvaluator.h include opensubdivosdcpuVertexBuffer.h include cstdio include cstring ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 24 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv static Far TopologyRefiner const createTopologyRefiner int maxlevel ------------------------------------------------------------------------------ int main int , char int maxlevel 2 , nCoarseVerts 0 , nRefinedVerts 0 Setup phase Far StencilTable const stencilTable NULL Setup FarStencilTable Far TopologyRefiner const refiner createTopologyRefiner maxlevel Setup a factory to create FarStencilTable for more details see Far tutorials Far StencilTableFactory Options options options . generateOffsets true options . generateIntermediateLevels false stencilTable Far StencilTableFactory Create refiner , options nCoarseVerts refiner - GetLevel 0 . GetNumVertices nRefinedVerts stencilTable - GetNumStencils We are done with Far cleanup table delete refiner Setup a buffer for vertex primvar data Osd CpuVertexBuffer vbuffer Osd CpuVertexBuffer Create 3 , nCoarseVerts nRefinedVerts Execution phase every frame Pack the control vertex data at the start of the vertex buffer and update every time control data changes vbuffer - UpdateData g_verts , 0 , nCoarseVerts Osd BufferDescriptor srcDesc 0 , 3 , 3 Osd BufferDescriptor dstDesc nCoarseVerts 3 , 3 , 3 Launch the computation Osd CpuEvaluator EvalStencils vbuffer , srcDesc , vbuffer , dstDesc , stencilTable Visualization with Maya print a MEL script that generates particles at the location of the refined vertices printf particle float const refinedVerts vbuffer - BindCpuBuffer 3 nCoarseVerts for int i 0 i nRefinedVerts i float const vert refinedVerts 3 i printf -p f f f n , vert 0 , vert 1 , vert 2 printf -c 1 n delete stencilTable delete vbuffer ------------------------------------------------------------------------------ static Far TopologyRefiner const createTopologyRefiner int maxlevel Populate a topology descriptor with our raw data typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options Uniformly refine the topology up to maxlevel refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel return refiner ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "osd_tutorial_0.html" │ │ │ │ │ - }, { │ │ │ │ │ - "title": "bfr_tutorial_2_2.cpp", │ │ │ │ │ - "text": "bfr_tutorial_2_2.cpp bfr_tutorial_2_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_2_2bfr_tutorial_2_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial builds on others using the SurfaceFactory, Surface and Tessellation classes by using more of the functionality of the Tessellation class to construct a tessellation of the mesh that is topologically watertight, i.e. resulting points evaluated along shared edges or vertices are shared and not duplicated. Since Tessellation provides points around its boundary first, the evaluated points for shared vertices and edges are identified when constructed and reused when shared later. The boundary of the tessellation of a face is therefore a collection of shared points and methods of Tessellation help to remap the faces generated to the shared set of points. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio include cassert Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv using Far Index using Far IndexArray using Far ConstIndexArray Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args Simple local structs supporting shared points for vertices and edges namespace struct SharedVertex SharedVertex pointIndex -1 bool IsSet const return pointIndex 0 void Set int index pointIndex index int pointIndex struct SharedEdge SharedEdge pointIndex -1 , numPoints 0 bool IsSet const return pointIndex 0 void Set int index , int n pointIndex index , numPoints n int pointIndex int numPoints end namespace The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. This tessellation function differs from earlier tutorials in that it computes and reuses shared points at vertices and edges of the mesh. There are several ways to compute these shared points, and which is best depends on context. Dealing with shared data poses complications for threading in general, so computing all points for the vertices and edges up front may be preferred -- despite the fact that faces will be visited more than once first when generating potentially shared vertex or edge points, and later when generating any interior points. The loops for vertices and edges can be threaded and the indexing of the shared points is simpler. For the single-threaded case here, the faces are each processed in order and any shared points will be computed and used as needed. So each face is visited once and so each Surface initialized once but the bookkeeping to deal with indices of shared points becomes more complicated. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface faceSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Declare vectors to identify shared tessellation points at vertices and edges and their indices around the boundary of a face Far TopologyLevel const baseLevel meshTopology . GetLevel 0 std vector SharedVertex sharedVerts baseLevel . GetNumVertices std vector SharedEdge sharedEdges baseLevel . GetNumEdges std vector int tessBoundaryIndices Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numMeshPointsEvaluated 0 int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surface for this face -- if valid skipping holes and boundary faces in some rare cases if meshSurfaceFactory . InitVertexSurface faceIndex , faceSurface continue Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern faceSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Resize patch point and output arrays int pointSize 3 facePatchPoints . resize faceSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate the patch point array faceSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize Evaluate the sample points of the Tessellation First traverse the boundary of the face to determine whether to evaluate or share points on vertices and edges of the face. Both pre-existing and new boundary points are identified by index in an array for later use. The interior points are all trivially computed after the boundary is dealt with. Identify the boundary and interior coords and initialize the index array for the potentially shared boundary points int numBoundaryCoords tessPattern . GetNumBoundaryCoords int numInteriorCoords numOutCoords - numBoundaryCoords float const tessBoundaryCoords outCoords 0 float const tessInteriorCoords outCoords numBoundaryCoords 2 ConstIndexArray fVerts baseLevel . GetFaceVertices faceIndex ConstIndexArray fEdges baseLevel . GetFaceEdges faceIndex tessBoundaryIndices . resize numBoundaryCoords Walk around the face, inspecting each vertex and outgoing edge, and populating the index array of boundary points float patchPointData facePatchPoints . data int boundaryIndex 0 int numFacePointsEvaluated 0 for int i 0 i fVerts . size i Index vertIndex fVerts i Index edgeIndex fEdges i int edgeRate options . tessUniformRate Evaluateassign or retrieve the shared point for the vertex SharedVertex sharedVertex sharedVerts vertIndex if sharedVertex . IsSet Identify indices of the new shared point in both the mesh and face and increment their inventory int indexInMesh numMeshPointsEvaluated int indexInFace numFacePointsEvaluated sharedVertex . Set indexInMesh Evaluate new shared point and assign index to boundary float const uv tessBoundaryCoords boundaryIndex 2 int pIndex indexInFace pointSize faceSurface . Evaluate uv , patchPointData , pointSize , outPos pIndex , outDu pIndex , outDv pIndex tessBoundaryIndices boundaryIndex indexInMesh else Assign shared vertex point index to boundary tessBoundaryIndices boundaryIndex sharedVertex . pointIndex Evaluateassign or retrieve all shared points for the edge To keep this simple, assume the edge is manifold. So the second face sharing the edge has that edge in the opposite direction in its boundary relative to the first face -- making it necessary to reverse the order of shared points for the boundary of the second face. To support a non-manifold edge, all subsequent faces that share the assigned shared edge must determine if their orientation of that edge is reversed relative to the first face for which the shared edge points were evaluated. So a little more book-keeping andor inspection is required. if edgeRate 1 int pointsPerEdge edgeRate - 1 SharedEdge sharedEdge sharedEdges edgeIndex if sharedEdge . IsSet Identify indices of the new shared points in both the mesh and face and increment their inventory int nextInMesh numMeshPointsEvaluated int nextInFace numFacePointsEvaluated numFacePointsEvaluated pointsPerEdge numMeshPointsEvaluated pointsPerEdge sharedEdge . Set nextInMesh , pointsPerEdge Evaluate shared points and assign indices to boundary float const uv tessBoundaryCoords boundaryIndex 2 for int j 0 j pointsPerEdge j , uv 2 int pIndex nextInFace pointSize faceSurface . Evaluate uv , patchPointData , pointSize , outPos pIndex , outDu pIndex , outDv pIndex tessBoundaryIndices boundaryIndex nextInMesh else See note above on simplification for manifold edges assert baseLevel . IsEdgeNonManifold edgeIndex Assign shared points to boundary in reverse order int nextInMesh sharedEdge . pointIndex pointsPerEdge - 1 for int j 0 j pointsPerEdge j tessBoundaryIndices boundaryIndex nextInMesh -- Evaluate any interior points unique to this face -- appending them to those shared points computed above for the boundary if numInteriorCoords float const uv tessInteriorCoords int iLast numFacePointsEvaluated numInteriorCoords for int i numFacePointsEvaluated i iLast i , uv 2 int pIndex i pointSize faceSurface . Evaluate uv , patchPointData , pointSize , outPos pIndex , outDu pIndex , outDv pIndex numFacePointsEvaluated numInteriorCoords numMeshPointsEvaluated numInteriorCoords Remember to trimresize the arrays storing evaluation results for new points to reflect the size actually populated. outPos . resize numFacePointsEvaluated pointSize outDu . resize numFacePointsEvaluated pointSize outDv . resize numFacePointsEvaluated pointSize Identify the faces of the Tessellation Note that the coordinate indices used by the facets are local to the face i.e. they range from 0..N-1, where N is the number of coordinates in the pattern and so need to be offset when writing to Obj format. For more advanced use, the coordinates associated with the boundary and interior of the pattern are distinguishable so that those on the boundary can be easily remapped to refer to shared edge or corner points, while those in the interior can be separately offset or similarly remapped. So transform the indices of the facets here as needed using the indices of shared boundary points assembled above and a suitable offset for the new interior points added int tessInteriorOffset numMeshPointsEvaluated - numOutCoords int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , tessBoundaryIndices . data , tessInteriorOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outFacets , tessFacetSize , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "bfr_tutorial_3_2.cpp", │ │ │ │ │ + "text": "bfr_tutorial_3_2.cpp bfr_tutorial_3_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_3_2bfr_tutorial_3_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial is a variation of tutorials showing simple uniform tessellation. Rather than constructing and evaluating a Surface at a time, this tutorial shows how Surfaces can be created and saved for repeated use. A simple SurfaceCache class is created that creates and stores the Surface for each face, along with the patch points associated with it. The main tessellation function remains essentially the same, but here it access the Surfaces from the SurfaceCache rather than computing them locally. Note that while this example illustrated the retention of all Surfaces for a mesh, this behavior is not recommended. It does not scale well for large meshes and undermines the memory savings that transient use of Surfaces is designed to achieve. Rather than storing Surfaces for all faces, maintaining a priority queue for a fixed number may be a reasonable compromise. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include memory include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args This simple class creates and dispenses Surfaces for all faces of a mesh. It consists primarily of an array of simple structs entries for each face and a single array of patch points for all Surfaces created. There are many ways to create such a cache depending on requirements. This is a simple example, but the interface presents some options that are worth considering. A SurfaceCache is constructed here given the following - a reference to the SurfaceFactory - the cache could just as easily take a reference to the mesh and construct the SurfaceFactory internally - the position data for the mesh - this is needed to compute patch points for the Surfaces - if caching UVs or any other primvar, other data needs to be provided -- along with the interpolation type for that data vertex, face-varying, etc. - option to cache patch points - the cache could store the Surfaces only or also include their patch points - storing patch points takes more memory but will eliminate any preparation time for evaluation of the Surface - option to cache all surfaces - the benefits to caching simple linear or regular surfaces are minimal -- and may even be detrimental - so only caching non-linear irregular surfaces is an option worth considering The SurfaceCache implementation here provides the options noted above. But for simplicity, the actual usage of the SurfaceCache does not deal with the permutations of additional work that is necessary when the Surfaces or their patch points are not cached. class SurfaceCache public typedef Bfr Surface float Surface typedef Bfr RefinerSurfaceFactory SurfaceFactory public SurfaceCache SurfaceFactory const surfaceFactory , std vector float const meshPoints , bool cachePatchPoints true , bool cacheAllSurfaces true SurfaceCache delete SurfaceCache default Public methods to retrieved cached Surfaces and their pre-computed patch points bool FaceHasLimitSurface int face return _entries face . hasLimit Surface const GetSurface int face return _entries face . surface . get float const GetPatchPoints int face return getPatchPoints face private Simple struct to keep track of Surface and more for each face struct FaceEntry FaceEntry surface , hasLimit false , pointOffset -1 std unique_ptr Surface const surface bool hasLimit int pointOffset Non-const version to be used internally to aide assignment float getPatchPoints int face return _entries face . surface _points . empty _points . data _entries face . pointOffset 3 0 private std vector FaceEntry _entries std vector float _points SurfaceCache SurfaceCache SurfaceFactory const surfaceFactory , std vector float const meshPoints , bool cachePatchPoints , bool cacheAllSurfaces int numFaces surfaceFactory . GetNumFaces _entries . resize numFaces int numPointsInCache 0 for int face 0 face numFaces face Surface s surfaceFactory . CreateVertexSurface float face if s FaceEntry entry _entries face entry . hasLimit true if cacheAllSurfaces s - IsRegular s - IsLinear entry . surface . reset s entry . pointOffset numPointsInCache numPointsInCache s - GetNumPatchPoints else delete s if cachePatchPoints _points . resize numPointsInCache 3 for int face 0 face numFaces face float patchPoints getPatchPoints face if patchPoints GetSurface face - PreparePatchPoints meshPoints . data , 3 , patchPoints , 3 The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions Initialize a SurfaceCache to construct Surfaces for all faces. From this point forward the SurfaceFactory is no longer used to access Surfaces. Note also that usage below is specific to the options used to initialize the SurfaceCache bool cachePatchPoints true bool cacheAllSurfaces true SurfaceCache surfaceCache meshSurfaceFactory , meshVertexPositions , cachePatchPoints , cacheAllSurfaces As with previous tutorials, output data associated with the face can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. std vector float outCoords std vector float outPos , outDu , outDv std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Retrieve the Surface for this face when present if surfaceCache . FaceHasLimitSurface faceIndex continue Surface const faceSurface surfaceCache . GetSurface faceIndex Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern faceSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Retrieve the patch points for the Surface, then use them to evaluate output points for all identified coordinates float const facePatchPoints surfaceCache . GetPatchPoints faceIndex int pointSize 3 outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize for int i 0 , j 0 i numOutCoords i , j pointSize faceSurface . Evaluate outCoords i 2 , facePatchPoints , pointSize , outPos j , outDu j , outDv j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outFacets , tessFacetSize , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "bfr_tutorial_2_2.html" │ │ │ │ │ + "loc": "bfr_tutorial_3_2.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "bfr_tutorial_3_1.cpp", │ │ │ │ │ "text": "bfr_tutorial_3_1.cpp bfr_tutorial_3_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_3_1bfr_tutorial_3_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial illustrates the definition of a custom subclass of BfrSurfaceFactory -- providing a class with the SurfaceFactory interface adapted to a connected mesh representation. The bulk of this code is therefore identical to a previous tutorial 1.3 which illustrates simple use of a BfrSurface factory. The only difference here lies in the explicit local definition of the subclass of BfrSurfaceFactory for FarTopologyRefiner -- named CustomSurfaceFactory in this case. include .customSurfaceFactory.h include opensubdivfartopologyRefiner.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag bool uv2xyzFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false , uv2xyzFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else if strcmp argv i , -uv2xyz uv2xyzFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , std vector float const meshFaceVaryingUVs , Args const options Use simpler local type names for the Surface and its factory typedef CustomSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing When dealing with face-varying data, an identifier is necessary when constructing Surfaces in order to distinguish the different face-varying data channels. To avoid repeatedly specifying that identifier when only one is present or of interest, it can be specified via the Options. bool meshHasUVs meshTopology . GetNumFVarChannels 0 SurfaceFactory Options surfaceOptions if meshHasUVs surfaceOptions . SetDefaultFVarID 0 SurfaceFactory surfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface posSurface Surface uvSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector float outUV std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces surfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surfaces for position and UVs of this face. There are two ways to do this -- both illustrated here Creating Surfaces for the different data interpolation types independently is clear and convenient, but considerable work may be duplicated in the construction process in the case of non-linear face-varying Surfaces. So unless it is known that face-varying interpolation is linear, use of InitSurfaces is generally preferred. Remember also that the face-varying identifier is omitted from the initialization methods here as it was previously assigned to the SurfaceFactoryOptions. In the absence of an assignment of the default FVarID to the Options, a failure to specify the FVarID here will result in failure. The cases below are expanded for illustration purposes, and validity of the resulting Surface is tested here, rather than the return value of initialization methods. bool createSurfacesTogether true if meshHasUVs surfaceFactory . InitVertexSurface faceIndex , posSurface else if createSurfacesTogether surfaceFactory . InitSurfaces faceIndex , posSurface , uvSurface else if surfaceFactory . InitVertexSurface faceIndex , posSurface surfaceFactory . InitFaceVaryingSurface faceIndex , uvSurface if posSurface . IsValid continue Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern posSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Evaluate vertex positions Resize patch point and output arrays int pointSize 3 facePatchPoints . resize posSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate patch point and output arrays posSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize for int i 0 , j 0 i numOutCoords i , j pointSize posSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outPos j , outDu j , outDv j Evaluate face-varying UVs when present if meshHasUVs Resize patch point and output arrays - note reuse of the same patch point array as position int pointSize 2 facePatchPoints . resize uvSurface . GetNumPatchPoints pointSize outUV . resize numOutCoords pointSize Populate patch point and output arrays uvSurface . PreparePatchPoints meshFaceVaryingUVs . data , pointSize , facePatchPoints . data , pointSize for int i 0 , j 0 i numOutCoords i , j pointSize uvSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outUV j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex if meshHasUVs options . uv2xyzFlag objWriter . WriteVertexPositions outUV , 2 objWriter . WriteFaces outFacets , tessFacetSize , false , false else objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv if meshHasUVs objWriter . WriteVertexUVs outUV objWriter . WriteFaces outFacets , tessFacetSize , true , meshHasUVs Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , meshFVarUVs , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "bfr_tutorial_3_1.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "bfr_tutorial_3_2.cpp", │ │ │ │ │ - "text": "bfr_tutorial_3_2.cpp bfr_tutorial_3_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_3_2bfr_tutorial_3_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial is a variation of tutorials showing simple uniform tessellation. Rather than constructing and evaluating a Surface at a time, this tutorial shows how Surfaces can be created and saved for repeated use. A simple SurfaceCache class is created that creates and stores the Surface for each face, along with the patch points associated with it. The main tessellation function remains essentially the same, but here it access the Surfaces from the SurfaceCache rather than computing them locally. Note that while this example illustrated the retention of all Surfaces for a mesh, this behavior is not recommended. It does not scale well for large meshes and undermines the memory savings that transient use of Surfaces is designed to achieve. Rather than storing Surfaces for all faces, maintaining a priority queue for a fixed number may be a reasonable compromise. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include memory include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args This simple class creates and dispenses Surfaces for all faces of a mesh. It consists primarily of an array of simple structs entries for each face and a single array of patch points for all Surfaces created. There are many ways to create such a cache depending on requirements. This is a simple example, but the interface presents some options that are worth considering. A SurfaceCache is constructed here given the following - a reference to the SurfaceFactory - the cache could just as easily take a reference to the mesh and construct the SurfaceFactory internally - the position data for the mesh - this is needed to compute patch points for the Surfaces - if caching UVs or any other primvar, other data needs to be provided -- along with the interpolation type for that data vertex, face-varying, etc. - option to cache patch points - the cache could store the Surfaces only or also include their patch points - storing patch points takes more memory but will eliminate any preparation time for evaluation of the Surface - option to cache all surfaces - the benefits to caching simple linear or regular surfaces are minimal -- and may even be detrimental - so only caching non-linear irregular surfaces is an option worth considering The SurfaceCache implementation here provides the options noted above. But for simplicity, the actual usage of the SurfaceCache does not deal with the permutations of additional work that is necessary when the Surfaces or their patch points are not cached. class SurfaceCache public typedef Bfr Surface float Surface typedef Bfr RefinerSurfaceFactory SurfaceFactory public SurfaceCache SurfaceFactory const surfaceFactory , std vector float const meshPoints , bool cachePatchPoints true , bool cacheAllSurfaces true SurfaceCache delete SurfaceCache default Public methods to retrieved cached Surfaces and their pre-computed patch points bool FaceHasLimitSurface int face return _entries face . hasLimit Surface const GetSurface int face return _entries face . surface . get float const GetPatchPoints int face return getPatchPoints face private Simple struct to keep track of Surface and more for each face struct FaceEntry FaceEntry surface , hasLimit false , pointOffset -1 std unique_ptr Surface const surface bool hasLimit int pointOffset Non-const version to be used internally to aide assignment float getPatchPoints int face return _entries face . surface _points . empty _points . data _entries face . pointOffset 3 0 private std vector FaceEntry _entries std vector float _points SurfaceCache SurfaceCache SurfaceFactory const surfaceFactory , std vector float const meshPoints , bool cachePatchPoints , bool cacheAllSurfaces int numFaces surfaceFactory . GetNumFaces _entries . resize numFaces int numPointsInCache 0 for int face 0 face numFaces face Surface s surfaceFactory . CreateVertexSurface float face if s FaceEntry entry _entries face entry . hasLimit true if cacheAllSurfaces s - IsRegular s - IsLinear entry . surface . reset s entry . pointOffset numPointsInCache numPointsInCache s - GetNumPatchPoints else delete s if cachePatchPoints _points . resize numPointsInCache 3 for int face 0 face numFaces face float patchPoints getPatchPoints face if patchPoints GetSurface face - PreparePatchPoints meshPoints . data , 3 , patchPoints , 3 The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions Initialize a SurfaceCache to construct Surfaces for all faces. From this point forward the SurfaceFactory is no longer used to access Surfaces. Note also that usage below is specific to the options used to initialize the SurfaceCache bool cachePatchPoints true bool cacheAllSurfaces true SurfaceCache surfaceCache meshSurfaceFactory , meshVertexPositions , cachePatchPoints , cacheAllSurfaces As with previous tutorials, output data associated with the face can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. std vector float outCoords std vector float outPos , outDu , outDv std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Retrieve the Surface for this face when present if surfaceCache . FaceHasLimitSurface faceIndex continue Surface const faceSurface surfaceCache . GetSurface faceIndex Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern faceSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Retrieve the patch points for the Surface, then use them to evaluate output points for all identified coordinates float const facePatchPoints surfaceCache . GetPatchPoints faceIndex int pointSize 3 outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize for int i 0 , j 0 i numOutCoords i , j pointSize faceSurface . Evaluate outCoords i 2 , facePatchPoints , pointSize , outPos j , outDu j , outDv j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outFacets , tessFacetSize , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "osd_tutorial_0.cpp", │ │ │ │ │ + "text": "osd_tutorial_0.cpp osd_tutorial_0.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsosdtutorial_0osd_tutorial_0.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial demonstrates the manipulation of Osd Evaluator and BufferDescriptor. include opensubdivfartopologyDescriptor.h include opensubdivfarstencilTableFactory.h include opensubdivosdcpuEvaluator.h include opensubdivosdcpuVertexBuffer.h include cstdio include cstring ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 24 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv static Far TopologyRefiner const createTopologyRefiner int maxlevel ------------------------------------------------------------------------------ int main int , char int maxlevel 2 , nCoarseVerts 0 , nRefinedVerts 0 Setup phase Far StencilTable const stencilTable NULL Setup FarStencilTable Far TopologyRefiner const refiner createTopologyRefiner maxlevel Setup a factory to create FarStencilTable for more details see Far tutorials Far StencilTableFactory Options options options . generateOffsets true options . generateIntermediateLevels false stencilTable Far StencilTableFactory Create refiner , options nCoarseVerts refiner - GetLevel 0 . GetNumVertices nRefinedVerts stencilTable - GetNumStencils We are done with Far cleanup table delete refiner Setup a buffer for vertex primvar data Osd CpuVertexBuffer vbuffer Osd CpuVertexBuffer Create 3 , nCoarseVerts nRefinedVerts Execution phase every frame Pack the control vertex data at the start of the vertex buffer and update every time control data changes vbuffer - UpdateData g_verts , 0 , nCoarseVerts Osd BufferDescriptor srcDesc 0 , 3 , 3 Osd BufferDescriptor dstDesc nCoarseVerts 3 , 3 , 3 Launch the computation Osd CpuEvaluator EvalStencils vbuffer , srcDesc , vbuffer , dstDesc , stencilTable Visualization with Maya print a MEL script that generates particles at the location of the refined vertices printf particle float const refinedVerts vbuffer - BindCpuBuffer 3 nCoarseVerts for int i 0 i nRefinedVerts i float const vert refinedVerts 3 i printf -p f f f n , vert 0 , vert 1 , vert 2 printf -c 1 n delete stencilTable delete vbuffer ------------------------------------------------------------------------------ static Far TopologyRefiner const createTopologyRefiner int maxlevel Populate a topology descriptor with our raw data typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options Uniformly refine the topology up to maxlevel refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel return refiner ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "bfr_tutorial_3_2.html" │ │ │ │ │ + "loc": "osd_tutorial_0.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "bfr_tutorial_1_4.cpp", │ │ │ │ │ - "text": "bfr_tutorial_1_4.cpp bfr_tutorial_1_4.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_1_4bfr_tutorial_1_4.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial builds on the previous tutorial that makes use of the SurfaceFactory, Surface and Tessellation classes for evaluating and tessellating the limit surface of faces of a mesh by illustrating how the presence of additional data in the mesh arrays is handled. As in the previous tutorial, vertex positions and face-varying UVs are provided with the mesh to be evaluated. But here an additional color is interleaved with the position in the vertex data of the mesh and a third component is added to face-varying UV data making it u,v,w. To evaluate the position and 2D UVs while avoiding the color and unused third UV coordinate, the SurfacePointDescriptor class is used to describe the size and stride of the desired data to be evaluated in the arrays of mesh data. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag bool uv2xyzFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false , uv2xyzFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else if strcmp argv i , -uv2xyz uv2xyzFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVtxData , int vtxDataSize , std vector float const meshFVarData , int fvarDataSize , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface typedef Surface PointDescriptor SurfacePoint Identify the source positions and UVs within more general data arrays for the mesh. If position andor UV are not at the start of the vtx andor fvar data, simply offset the head of the array here accordingly bool meshHasUVs meshTopology . GetNumFVarChannels 0 float const meshPosData meshVtxData . data SurfacePoint meshPosPoint 3 , vtxDataSize float const meshUVData meshHasUVs meshFVarData . data 0 SurfacePoint meshUVPoint 2 , fvarDataSize Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing When dealing with face-varying data, an identifier is necessary when constructing Surfaces in order to distinguish the different face-varying data channels. To avoid repeatedly specifying that identifier when only one is present or of interest, it can be specified via the Options. SurfaceFactory Options surfaceOptions if meshHasUVs surfaceOptions . SetDefaultFVarID 0 SurfaceFactory surfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface posSurface Surface uvSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector float outUV std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces surfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surfaces for position and UVs of this face. There are two ways to do this -- both illustrated here Creating Surfaces for the different data interpolation types independently is clear and convenient, but considerable work may be duplicated in the construction process in the case of non-linear face-varying Surfaces. So unless it is known that face-varying interpolation is linear, use of InitSurfaces is generally preferred. Remember also that the face-varying identifier is omitted from the initialization methods here as it was previously assigned to the SurfaceFactoryOptions. In the absence of an assignment of the default FVarID to the Options, a failure to specify the FVarID here will result in failure. The cases below are expanded for illustration purposes, and validity of the resulting Surface is tested here, rather than the return value of initialization methods. bool createSurfacesTogether true if meshHasUVs surfaceFactory . InitVertexSurface faceIndex , posSurface else if createSurfacesTogether surfaceFactory . InitSurfaces faceIndex , posSurface , uvSurface else if surfaceFactory . InitVertexSurface faceIndex , posSurface surfaceFactory . InitFaceVaryingSurface faceIndex , uvSurface if posSurface . IsValid continue Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern posSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Evaluate vertex positions Resize patch point and output arrays int pointSize meshPosPoint . size facePatchPoints . resize posSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate patch point and output arrays float patchPosData facePatchPoints . data SurfacePoint patchPosPoint pointSize posSurface . PreparePatchPoints meshPosData , meshPosPoint , patchPosData , patchPosPoint for int i 0 , j 0 i numOutCoords i , j pointSize posSurface . Evaluate outCoords i 2 , patchPosData , patchPosPoint , outPos j , outDu j , outDv j Evaluate face-varying UVs when present if meshHasUVs Resize patch point and output arrays - note reuse of the same patch point array as position int pointSize meshUVPoint . size facePatchPoints . resize uvSurface . GetNumPatchPoints pointSize outUV . resize numOutCoords pointSize Populate patch point and output arrays float patchUVData facePatchPoints . data SurfacePoint patchUVPoint pointSize uvSurface . PreparePatchPoints meshUVData , meshUVPoint , patchUVData , patchUVPoint for int i 0 , j 0 i numOutCoords i , j pointSize uvSurface . Evaluate outCoords i 2 , patchUVData , patchUVPoint , outUV j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex if meshHasUVs options . uv2xyzFlag objWriter . WriteVertexPositions outUV , 2 objWriter . WriteFaces outFacets , tessFacetSize , false , false else objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv if meshHasUVs objWriter . WriteVertexUVs outUV objWriter . WriteFaces outFacets , tessFacetSize , true , meshHasUVs Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE Expand the loaded position and UV arrays to include additional data initialized with -1 for distinction, e.g. add a 4-tuple for RGBA color to the vertex data and add a third field w to the face-varying data int numPos int meshVtxPositions . size 3 int vtxSize 7 std vector float vtxData numPos vtxSize , -1.0f for int i 0 i numPos i vtxData i vtxSize meshVtxPositions i 3 vtxData i vtxSize 1 meshVtxPositions i 3 1 vtxData i vtxSize 2 meshVtxPositions i 3 2 int numUVs int meshFVarUVs . size 2 int fvarSize 3 std vector float fvarData numUVs fvarSize , -1.0f for int i 0 i numUVs i fvarData i fvarSize meshFVarUVs i 2 fvarData i fvarSize 1 meshFVarUVs i 2 1 Pass the expanded data arrays along with their respective strides tessellateToObj meshTopology , vtxData , vtxSize , fvarData , fvarSize , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "bfr_tutorial_2_2.cpp", │ │ │ │ │ + "text": "bfr_tutorial_2_2.cpp bfr_tutorial_2_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_2_2bfr_tutorial_2_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial builds on others using the SurfaceFactory, Surface and Tessellation classes by using more of the functionality of the Tessellation class to construct a tessellation of the mesh that is topologically watertight, i.e. resulting points evaluated along shared edges or vertices are shared and not duplicated. Since Tessellation provides points around its boundary first, the evaluated points for shared vertices and edges are identified when constructed and reused when shared later. The boundary of the tessellation of a face is therefore a collection of shared points and methods of Tessellation help to remap the faces generated to the shared set of points. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio include cassert Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv using Far Index using Far IndexArray using Far ConstIndexArray Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args Simple local structs supporting shared points for vertices and edges namespace struct SharedVertex SharedVertex pointIndex -1 bool IsSet const return pointIndex 0 void Set int index pointIndex index int pointIndex struct SharedEdge SharedEdge pointIndex -1 , numPoints 0 bool IsSet const return pointIndex 0 void Set int index , int n pointIndex index , numPoints n int pointIndex int numPoints end namespace The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. This tessellation function differs from earlier tutorials in that it computes and reuses shared points at vertices and edges of the mesh. There are several ways to compute these shared points, and which is best depends on context. Dealing with shared data poses complications for threading in general, so computing all points for the vertices and edges up front may be preferred -- despite the fact that faces will be visited more than once first when generating potentially shared vertex or edge points, and later when generating any interior points. The loops for vertices and edges can be threaded and the indexing of the shared points is simpler. For the single-threaded case here, the faces are each processed in order and any shared points will be computed and used as needed. So each face is visited once and so each Surface initialized once but the bookkeeping to deal with indices of shared points becomes more complicated. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface faceSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Declare vectors to identify shared tessellation points at vertices and edges and their indices around the boundary of a face Far TopologyLevel const baseLevel meshTopology . GetLevel 0 std vector SharedVertex sharedVerts baseLevel . GetNumVertices std vector SharedEdge sharedEdges baseLevel . GetNumEdges std vector int tessBoundaryIndices Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numMeshPointsEvaluated 0 int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surface for this face -- if valid skipping holes and boundary faces in some rare cases if meshSurfaceFactory . InitVertexSurface faceIndex , faceSurface continue Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern faceSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Resize patch point and output arrays int pointSize 3 facePatchPoints . resize faceSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate the patch point array faceSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize Evaluate the sample points of the Tessellation First traverse the boundary of the face to determine whether to evaluate or share points on vertices and edges of the face. Both pre-existing and new boundary points are identified by index in an array for later use. The interior points are all trivially computed after the boundary is dealt with. Identify the boundary and interior coords and initialize the index array for the potentially shared boundary points int numBoundaryCoords tessPattern . GetNumBoundaryCoords int numInteriorCoords numOutCoords - numBoundaryCoords float const tessBoundaryCoords outCoords 0 float const tessInteriorCoords outCoords numBoundaryCoords 2 ConstIndexArray fVerts baseLevel . GetFaceVertices faceIndex ConstIndexArray fEdges baseLevel . GetFaceEdges faceIndex tessBoundaryIndices . resize numBoundaryCoords Walk around the face, inspecting each vertex and outgoing edge, and populating the index array of boundary points float patchPointData facePatchPoints . data int boundaryIndex 0 int numFacePointsEvaluated 0 for int i 0 i fVerts . size i Index vertIndex fVerts i Index edgeIndex fEdges i int edgeRate options . tessUniformRate Evaluateassign or retrieve the shared point for the vertex SharedVertex sharedVertex sharedVerts vertIndex if sharedVertex . IsSet Identify indices of the new shared point in both the mesh and face and increment their inventory int indexInMesh numMeshPointsEvaluated int indexInFace numFacePointsEvaluated sharedVertex . Set indexInMesh Evaluate new shared point and assign index to boundary float const uv tessBoundaryCoords boundaryIndex 2 int pIndex indexInFace pointSize faceSurface . Evaluate uv , patchPointData , pointSize , outPos pIndex , outDu pIndex , outDv pIndex tessBoundaryIndices boundaryIndex indexInMesh else Assign shared vertex point index to boundary tessBoundaryIndices boundaryIndex sharedVertex . pointIndex Evaluateassign or retrieve all shared points for the edge To keep this simple, assume the edge is manifold. So the second face sharing the edge has that edge in the opposite direction in its boundary relative to the first face -- making it necessary to reverse the order of shared points for the boundary of the second face. To support a non-manifold edge, all subsequent faces that share the assigned shared edge must determine if their orientation of that edge is reversed relative to the first face for which the shared edge points were evaluated. So a little more book-keeping andor inspection is required. if edgeRate 1 int pointsPerEdge edgeRate - 1 SharedEdge sharedEdge sharedEdges edgeIndex if sharedEdge . IsSet Identify indices of the new shared points in both the mesh and face and increment their inventory int nextInMesh numMeshPointsEvaluated int nextInFace numFacePointsEvaluated numFacePointsEvaluated pointsPerEdge numMeshPointsEvaluated pointsPerEdge sharedEdge . Set nextInMesh , pointsPerEdge Evaluate shared points and assign indices to boundary float const uv tessBoundaryCoords boundaryIndex 2 for int j 0 j pointsPerEdge j , uv 2 int pIndex nextInFace pointSize faceSurface . Evaluate uv , patchPointData , pointSize , outPos pIndex , outDu pIndex , outDv pIndex tessBoundaryIndices boundaryIndex nextInMesh else See note above on simplification for manifold edges assert baseLevel . IsEdgeNonManifold edgeIndex Assign shared points to boundary in reverse order int nextInMesh sharedEdge . pointIndex pointsPerEdge - 1 for int j 0 j pointsPerEdge j tessBoundaryIndices boundaryIndex nextInMesh -- Evaluate any interior points unique to this face -- appending them to those shared points computed above for the boundary if numInteriorCoords float const uv tessInteriorCoords int iLast numFacePointsEvaluated numInteriorCoords for int i numFacePointsEvaluated i iLast i , uv 2 int pIndex i pointSize faceSurface . Evaluate uv , patchPointData , pointSize , outPos pIndex , outDu pIndex , outDv pIndex numFacePointsEvaluated numInteriorCoords numMeshPointsEvaluated numInteriorCoords Remember to trimresize the arrays storing evaluation results for new points to reflect the size actually populated. outPos . resize numFacePointsEvaluated pointSize outDu . resize numFacePointsEvaluated pointSize outDv . resize numFacePointsEvaluated pointSize Identify the faces of the Tessellation Note that the coordinate indices used by the facets are local to the face i.e. they range from 0..N-1, where N is the number of coordinates in the pattern and so need to be offset when writing to Obj format. For more advanced use, the coordinates associated with the boundary and interior of the pattern are distinguishable so that those on the boundary can be easily remapped to refer to shared edge or corner points, while those in the interior can be separately offset or similarly remapped. So transform the indices of the facets here as needed using the indices of shared boundary points assembled above and a suitable offset for the new interior points added int tessInteriorOffset numMeshPointsEvaluated - numOutCoords int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , tessBoundaryIndices . data , tessInteriorOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outFacets , tessFacetSize , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "bfr_tutorial_1_4.html" │ │ │ │ │ + "loc": "bfr_tutorial_2_2.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "bfr_tutorial_2_1.cpp", │ │ │ │ │ "text": "bfr_tutorial_2_1.cpp bfr_tutorial_2_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_2_1bfr_tutorial_2_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial builds on the previous tutorial that makes use of the SurfaceFactory, Surface and Tessellation classes by illustrating the use of non-uniform tessellation parameters with Tessellation. Tessellation rates for the edges of a face are determined by a length associated with each edge. That length may be computed using either the control hull or the limit surface. The length of a tessellation interval is required and will be inferred if not explicitly specified as a command line option. The tessellation rate for an edge is computed as its length divided by the length of the tessellation interval. A maximum tessellation rate is imposed to prevent accidental unbounded tessellation, but can easily be raised as needed. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio include cmath include algorithm Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType float tessInterval int tessRateMax bool useHullFlag bool tessQuadsFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessInterval 0.0f , tessRateMax 10 , useHullFlag false , tessQuadsFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -length if i argc tessInterval float atof argv i else if strcmp argv i , -max if i argc tessRateMax atoi argv i else if strcmp argv i , -hull useHullFlag true else if strcmp argv i , -quads tessQuadsFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args Local trivial functions for simple edge length calculations and the determination of associated tessellation rates inline float EdgeLength float const v0 , float const v1 float dv 3 dv 0 std abs v0 0 - v1 0 dv 1 std abs v0 1 - v1 1 dv 2 std abs v0 2 - v1 2 return std sqrt dv 0 dv 0 dv 1 dv 1 dv 2 dv 2 float FindLongestEdge Far TopologyRefiner const mesh , std vector float const vertPos , int pointSize float maxLength 0.0f int numEdges mesh . GetLevel 0 . GetNumEdges for int i 0 i numEdges i Far ConstIndexArray edgeVerts mesh . GetLevel 0 . GetEdgeVertices i float edgeLength EdgeLength vertPos edgeVerts 0 pointSize , vertPos edgeVerts 1 pointSize maxLength std max maxLength , edgeLength return maxLength void GetEdgeTessRates std vector float const vertPos , int pointSize , Args const options , int edgeRates int numEdges int vertPos . size pointSize for int i 0 i numEdges i int j i 1 numEdges float edgeLength EdgeLength vertPos i pointSize , vertPos j pointSize edgeRates i 1 int edgeLength options . tessInterval edgeRates i std min edgeRates i , options . tessRateMax The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface faceSurface std vector float facePatchPoints std vector int faceTessRates std vector float outCoords std vector float outPos , outDu , outDv std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surface for this face -- if valid skipping holes and boundary faces in some rare cases if meshSurfaceFactory . InitVertexSurface faceIndex , faceSurface continue Prepare the Surface patch points first as it may be evaluated to determine suitable edge-rates for Tessellation int pointSize 3 facePatchPoints . resize faceSurface . GetNumPatchPoints pointSize faceSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize For each of the N edges of the face, a tessellation rate is determined to initialize a non-uniform Tessellation pattern. Many metrics are possible -- some based on the geometry itself size, curvature, others dependent on viewpoint screen space size, center of view, etc. and many more. Simple techniques are chosen here for illustration and can easily be replaced. Here two methods are shown using lengths between the corners of the face -- the first using the vertex positions of the face and the second using points evaluated at the corners of its limit surface. Use of the control hull is more efficient avoiding the evaluation but may prove less effective in some cases though both estimates have their limitations. int N faceSurface . GetFaceSize Use the output array temporarily to hold the N positions outPos . resize N pointSize if options . useHullFlag Far ConstIndexArray verts meshTopology . GetLevel 0 . GetFaceVertices faceIndex for int i 0 , j 0 i N i , j pointSize float const vPos meshVertexPositions verts i pointSize outPos j vPos 0 outPos j 1 vPos 1 outPos j 2 vPos 2 else Bfr Parameterization faceParam faceSurface . GetParameterization for int i 0 , j 0 i N i , j pointSize float uv 2 faceParam . GetVertexCoord i , uv faceSurface . Evaluate uv , facePatchPoints . data , pointSize , outPos j faceTessRates . resize N GetEdgeTessRates outPos , pointSize , options , faceTessRates . data Declare a non-uniform Tessellation using the rates for each edge and identify coordinates of the points to evaluate Additional interior rates can be optionally provided 2 for quads, 1 for others but will be inferred in their absence. Bfr Tessellation tessPattern faceSurface . GetParameterization , N , faceTessRates . data , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Resize the output arrays and evaluate outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize for int i 0 , j 0 i numOutCoords i , j pointSize faceSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outPos j , outDu j , outDv j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outFacets , tessFacetSize , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE If no interval length was specified, set one by finding the longest edge of the mesh and dividing it by the maximum tessellation rate if args . tessInterval 0.0f args . tessInterval FindLongestEdge meshTopology , meshVtxPositions , 3 float args . tessRateMax tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "bfr_tutorial_2_1.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "bfr_tutorial_1_5.cpp", │ │ │ │ │ "text": "bfr_tutorial_1_5.cpp bfr_tutorial_1_5.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_1_5bfr_tutorial_1_5.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial is an alternative to an earlier tutorial that showed uniform tessellation. This version differs by evaluating the points of the tessellation using limit stencils instead of the standard Surface evaluation methods. Limit stencils factor the evaluation into a set of coefficients for each control point affecting the Surface. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface faceSurface std vector float faceControlPoints std vector float limitStencils std vector float outCoords std vector float outPos , outDu , outDv std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surface for this face -- if valid skipping holes and boundary faces in some rare cases if meshSurfaceFactory . InitVertexSurface faceIndex , faceSurface continue Resize stencils and control point arrays based on the number of control points for the Surface int numControlPoints faceSurface . GetNumControlPoints limitStencils . resize 3 numControlPoints float pStencil limitStencils . data float duStencil limitStencils . data numControlPoints float dvStencil limitStencils . data numControlPoints 2 Limit stencils can be applied using the control points in a local array or directy from the mesh. Both are shown here, so if using the local array, resize and populate it bool gatherControlPoints true if gatherControlPoints faceControlPoints . resize numControlPoints 3 faceSurface . GatherControlPoints meshVertexPositions . data , 3 , faceControlPoints . data , 3 Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern faceSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Evaluate and apply stencils to compute points of the tessellation outPos . resize numOutCoords 3 outDu . resize numOutCoords 3 outDv . resize numOutCoords 3 for int i 0 i numOutCoords i float const uv outCoords . data i 2 faceSurface . EvaluateStencil uv , pStencil , duStencil , dvStencil float p outPos . data i 3 float du outDu . data i 3 float dv outDv . data i 3 if gatherControlPoints float const controlPoints faceControlPoints . data faceSurface . ApplyStencil pStencil , controlPoints , 3 , p faceSurface . ApplyStencil duStencil , controlPoints , 3 , du faceSurface . ApplyStencil dvStencil , controlPoints , 3 , dv else float const meshPoints meshVertexPositions . data faceSurface . ApplyStencilFromMesh pStencil , meshPoints , 3 , p faceSurface . ApplyStencilFromMesh duStencil , meshPoints , 3 , du faceSurface . ApplyStencilFromMesh dvStencil , meshPoints , 3 , dv Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outFacets , tessFacetSize , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "bfr_tutorial_1_5.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "bfr_tutorial_1_2.cpp", │ │ │ │ │ - "text": "bfr_tutorial_1_2.cpp bfr_tutorial_1_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_1_2bfr_tutorial_1_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial builds on the previous tutorial that makes use of the SurfaceFactory and Surface for evaluating the limit surface of faces by using the Tessellation class to determine the points to evaluate and the faces that connect them. The Tessellation class replaces the explicit determination of points and faces for the triangle fan of the previous example. Given a uniform tessellation rate via a command line option, Tessellation returns the set of coordinates to evaluate, and separately returns the faces that connect them. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface faceSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surface for this face -- if valid skipping holes and boundary faces in some rare cases if meshSurfaceFactory . InitVertexSurface faceIndex , faceSurface continue Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern faceSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Resize patch point and output arrays int pointSize 3 facePatchPoints . resize faceSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate patch point and output arrays faceSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize for int i 0 , j 0 i numOutCoords i , j pointSize faceSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outPos j , outDu j , outDv j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outFacets , tessFacetSize , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "bfr_tutorial_1_4.cpp", │ │ │ │ │ + "text": "bfr_tutorial_1_4.cpp bfr_tutorial_1_4.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_1_4bfr_tutorial_1_4.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial builds on the previous tutorial that makes use of the SurfaceFactory, Surface and Tessellation classes for evaluating and tessellating the limit surface of faces of a mesh by illustrating how the presence of additional data in the mesh arrays is handled. As in the previous tutorial, vertex positions and face-varying UVs are provided with the mesh to be evaluated. But here an additional color is interleaved with the position in the vertex data of the mesh and a third component is added to face-varying UV data making it u,v,w. To evaluate the position and 2D UVs while avoiding the color and unused third UV coordinate, the SurfacePointDescriptor class is used to describe the size and stride of the desired data to be evaluated in the arrays of mesh data. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag bool uv2xyzFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false , uv2xyzFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else if strcmp argv i , -uv2xyz uv2xyzFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVtxData , int vtxDataSize , std vector float const meshFVarData , int fvarDataSize , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface typedef Surface PointDescriptor SurfacePoint Identify the source positions and UVs within more general data arrays for the mesh. If position andor UV are not at the start of the vtx andor fvar data, simply offset the head of the array here accordingly bool meshHasUVs meshTopology . GetNumFVarChannels 0 float const meshPosData meshVtxData . data SurfacePoint meshPosPoint 3 , vtxDataSize float const meshUVData meshHasUVs meshFVarData . data 0 SurfacePoint meshUVPoint 2 , fvarDataSize Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing When dealing with face-varying data, an identifier is necessary when constructing Surfaces in order to distinguish the different face-varying data channels. To avoid repeatedly specifying that identifier when only one is present or of interest, it can be specified via the Options. SurfaceFactory Options surfaceOptions if meshHasUVs surfaceOptions . SetDefaultFVarID 0 SurfaceFactory surfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface posSurface Surface uvSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector float outUV std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces surfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surfaces for position and UVs of this face. There are two ways to do this -- both illustrated here Creating Surfaces for the different data interpolation types independently is clear and convenient, but considerable work may be duplicated in the construction process in the case of non-linear face-varying Surfaces. So unless it is known that face-varying interpolation is linear, use of InitSurfaces is generally preferred. Remember also that the face-varying identifier is omitted from the initialization methods here as it was previously assigned to the SurfaceFactoryOptions. In the absence of an assignment of the default FVarID to the Options, a failure to specify the FVarID here will result in failure. The cases below are expanded for illustration purposes, and validity of the resulting Surface is tested here, rather than the return value of initialization methods. bool createSurfacesTogether true if meshHasUVs surfaceFactory . InitVertexSurface faceIndex , posSurface else if createSurfacesTogether surfaceFactory . InitSurfaces faceIndex , posSurface , uvSurface else if surfaceFactory . InitVertexSurface faceIndex , posSurface surfaceFactory . InitFaceVaryingSurface faceIndex , uvSurface if posSurface . IsValid continue Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern posSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Evaluate vertex positions Resize patch point and output arrays int pointSize meshPosPoint . size facePatchPoints . resize posSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate patch point and output arrays float patchPosData facePatchPoints . data SurfacePoint patchPosPoint pointSize posSurface . PreparePatchPoints meshPosData , meshPosPoint , patchPosData , patchPosPoint for int i 0 , j 0 i numOutCoords i , j pointSize posSurface . Evaluate outCoords i 2 , patchPosData , patchPosPoint , outPos j , outDu j , outDv j Evaluate face-varying UVs when present if meshHasUVs Resize patch point and output arrays - note reuse of the same patch point array as position int pointSize meshUVPoint . size facePatchPoints . resize uvSurface . GetNumPatchPoints pointSize outUV . resize numOutCoords pointSize Populate patch point and output arrays float patchUVData facePatchPoints . data SurfacePoint patchUVPoint pointSize uvSurface . PreparePatchPoints meshUVData , meshUVPoint , patchUVData , patchUVPoint for int i 0 , j 0 i numOutCoords i , j pointSize uvSurface . Evaluate outCoords i 2 , patchUVData , patchUVPoint , outUV j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex if meshHasUVs options . uv2xyzFlag objWriter . WriteVertexPositions outUV , 2 objWriter . WriteFaces outFacets , tessFacetSize , false , false else objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv if meshHasUVs objWriter . WriteVertexUVs outUV objWriter . WriteFaces outFacets , tessFacetSize , true , meshHasUVs Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE Expand the loaded position and UV arrays to include additional data initialized with -1 for distinction, e.g. add a 4-tuple for RGBA color to the vertex data and add a third field w to the face-varying data int numPos int meshVtxPositions . size 3 int vtxSize 7 std vector float vtxData numPos vtxSize , -1.0f for int i 0 i numPos i vtxData i vtxSize meshVtxPositions i 3 vtxData i vtxSize 1 meshVtxPositions i 3 1 vtxData i vtxSize 2 meshVtxPositions i 3 2 int numUVs int meshFVarUVs . size 2 int fvarSize 3 std vector float fvarData numUVs fvarSize , -1.0f for int i 0 i numUVs i fvarData i fvarSize meshFVarUVs i 2 fvarData i fvarSize 1 meshFVarUVs i 2 1 Pass the expanded data arrays along with their respective strides tessellateToObj meshTopology , vtxData , vtxSize , fvarData , fvarSize , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "bfr_tutorial_1_2.html" │ │ │ │ │ + "loc": "bfr_tutorial_1_4.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "bfr_tutorial_1_3.cpp", │ │ │ │ │ "text": "bfr_tutorial_1_3.cpp bfr_tutorial_1_3.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_1_3bfr_tutorial_1_3.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial builds on the previous tutorial that makes use of the SurfaceFactory, Surface and Tessellation classes for evaluating and tessellating the limit surface of faces of a mesh by adding support for the evaluation of face-varying UVs. If UVs exist in the given mesh, they will be evaluated and included with the vertex positions and normals previously illustrated as part of the tessellation written to the Obj file. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag bool uv2xyzFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false , uv2xyzFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else if strcmp argv i , -uv2xyz uv2xyzFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , std vector float const meshFaceVaryingUVs , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing When dealing with face-varying data, an identifier is necessary when constructing Surfaces in order to distinguish the different face-varying data channels. To avoid repeatedly specifying that identifier when only one is present or of interest, it can be specified via the Options. bool meshHasUVs meshTopology . GetNumFVarChannels 0 SurfaceFactory Options surfaceOptions if meshHasUVs surfaceOptions . SetDefaultFVarID 0 SurfaceFactory surfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface posSurface Surface uvSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector float outUV std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces surfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surfaces for position and UVs of this face. There are two ways to do this -- both illustrated here Creating Surfaces for the different data interpolation types independently is clear and convenient, but considerable work may be duplicated in the construction process in the case of non-linear face-varying Surfaces. So unless it is known that face-varying interpolation is linear, use of InitSurfaces is generally preferred. Remember also that the face-varying identifier is omitted from the initialization methods here as it was previously assigned to the SurfaceFactoryOptions. In the absence of an assignment of the default FVarID to the Options, a failure to specify the FVarID here will result in failure. The cases below are expanded for illustration purposes, and validity of the resulting Surface is tested here, rather than the return value of initialization methods. bool createSurfacesTogether true if meshHasUVs surfaceFactory . InitVertexSurface faceIndex , posSurface else if createSurfacesTogether surfaceFactory . InitSurfaces faceIndex , posSurface , uvSurface else if surfaceFactory . InitVertexSurface faceIndex , posSurface surfaceFactory . InitFaceVaryingSurface faceIndex , uvSurface if posSurface . IsValid continue Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern posSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Evaluate vertex positions Resize patch point and output arrays int pointSize 3 facePatchPoints . resize posSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate patch point and output arrays posSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize for int i 0 , j 0 i numOutCoords i , j pointSize posSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outPos j , outDu j , outDv j Evaluate face-varying UVs when present if meshHasUVs Resize patch point and output arrays - note reuse of the same patch point array as position int pointSize 2 facePatchPoints . resize uvSurface . GetNumPatchPoints pointSize outUV . resize numOutCoords pointSize Populate patch point and output arrays uvSurface . PreparePatchPoints meshFaceVaryingUVs . data , pointSize , facePatchPoints . data , pointSize for int i 0 , j 0 i numOutCoords i , j pointSize uvSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outUV j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex if meshHasUVs options . uv2xyzFlag objWriter . WriteVertexPositions outUV , 2 objWriter . WriteFaces outFacets , tessFacetSize , false , false else objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv if meshHasUVs objWriter . WriteVertexUVs outUV objWriter . WriteFaces outFacets , tessFacetSize , true , meshHasUVs Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , meshFVarUVs , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "bfr_tutorial_1_3.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "bfr_tutorial_1_1.cpp", │ │ │ │ │ - "text": "bfr_tutorial_1_1.cpp bfr_tutorial_1_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_1_1bfr_tutorial_1_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial illustrates the use of the SurfaceFactory, Surface and Parameterization classes for creating and evaluating the limit surface associated with each base face of a mesh. Following the creation of a connected mesh for a shape using a FarTopologyRefiner, as illustrated in Far tutorials, an instance of a SurfaceFactory is declared to process its faces. Each face of the mesh is evaluated and tessellated independently with a simple triangle fan, with results written out in Obj format for inspection. These classes make it simple to evaluate and tessellate all faces quads, tris or others while supporting the full set of subdivision options. While a triangle fan may be a trivial tessellation and so not very useful later examples using the Tessellation class provide more useful results with the same simplicity. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface faceSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector int outTriangles Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surface for this face -- if valid skipping holes and boundary faces in some rare cases if meshSurfaceFactory . InitVertexSurface faceIndex , faceSurface continue Get the Parameterization of the Surface and use it to identify coordinates for evaluation -- in this case, at the vertices and center of the face to create a fan of triangles Bfr Parameterization faceParam faceSurface . GetParameterization int faceSize faceParam . GetFaceSize int numOutCoords faceSize 1 outCoords . resize numOutCoords 2 for int i 0 i faceSize i faceParam . GetVertexCoord i , outCoords i 2 faceParam . GetCenterCoord outCoords faceSize 2 Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Resize patch point and output arrays int pointSize 3 facePatchPoints . resize faceSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate patch point and output arrays faceSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize for int i 0 , j 0 i numOutCoords i , j pointSize faceSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outPos j , outDu j , outDv j Identify the faces of the tessellation, i.e. the triangle fan connecting points at the vertices to the center last point Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. int objVertexIndexOffset objWriter . GetNumVertices outTriangles . resize faceSize 3 int outTriangle outTriangles . data for int i 0 i faceSize i , outTriangle 3 outTriangle 0 objVertexIndexOffset i outTriangle 1 objVertexIndexOffset i 1 faceSize outTriangle 2 objVertexIndexOffset faceSize Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outTriangles , 3 , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "bfr_tutorial_1_1.html" │ │ │ │ │ - }, { │ │ │ │ │ "title": "far_tutorial_5_2.cpp", │ │ │ │ │ "text": "far_tutorial_5_2.cpp far_tutorial_5_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_5_2far_tutorial_5_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to manage the limit surface of a potentially large mesh by creating groups of patches for selected faces of the mesh. Familiarity with construction and evaluation of a PatchTable is assumed see tutorial_5_1. When the patches for a mesh do not need to be retained for further use, e.g. when simply computing points for a tessellation, the time and space required to construct a single large PatchTable can be considerable. By constructing, evaluating and discarding smaller PatchTables for subsets of the mesh, the high transient memory cost can be avoided when computed serially. When computed in parallel, there may be little memory savings, but the construction time can then be distributed. This tutorial creates simple geometry currently a lattice of cubes that can be expanded in complexity with a simple multiplier. The collection of faces are then divided into a specified number of groups from which patches will be constructed and evaluated. A simple tessellation a triangle fan around the midpoint of each face is then written in Obj format to the standard output. include ......regressioncommonarg_utils.h include ......regressioncommonfar_utils.h include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include opensubdivfarpatchTableFactory.h include opensubdivfarpatchMap.h include opensubdivfarptexIndices.h include cassert include cstdio include cstring include fstream include sstream using namespace OpenSubdiv using Far Index Global utilities in this namespace are not relevant to the tutorial. They simply serve to construct some default geometry to be processed in the form of a TopologyRefiner and vector of vertex positions. namespace Simple structs for x,y,z position and a 3-tuple for the set of vertices of a triangle struct Pos Pos Pos float x , float y , float z p 0 x , p 1 y , p 2 z Pos operator Pos const op const return Pos p 0 op . p 0 , p 1 op . p 1 , p 2 op . p 2 Clear and AddWithWeight required for interpolation void Clear void 0 p 0 p 1 p 2 0.0f void AddWithWeight Pos const src , float weight p 0 weight src . p 0 p 1 weight src . p 1 p 2 weight src . p 2 float p 3 typedef std vector Pos PosVector struct Tri Tri Tri int a , int b , int c v 0 a , v 1 b , v 2 c int v 3 typedef std vector Tri TriVector Functions to populate the topology and geometry arrays with simple shapes that we can multiply to increase complexity void appendDefaultPrimitive Pos const origin , std vector int vertsPerFace , std vector Index faceVerts , std vector Pos positionsPerVert Local topology and position of a cube centered at origin static float const cubePositions 8 3 -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f static int const cubeFaceVerts 6 4 0 , 3 , 2 , 1 , 4 , 5 , 6 , 7 , 0 , 4 , 7 , 3 , 1 , 2 , 6 , 5 , 0 , 1 , 5 , 4 , 3 , 7 , 6 , 2 Identify the next vertex before appending vertex positions int baseVertex int positionsPerVert . size for int i 0 i 8 i float const p cubePositions i positionsPerVert . push_back origin Pos p 0 , p 1 , p 2 Append number of verts-per-face and face-vertices for each face for int i 0 i 6 i vertsPerFace . push_back 4 for int j 0 j 4 j faceVerts . push_back baseVertex cubeFaceVerts i j void createDefaultGeometry int multiplier , std vector int vertsPerFace , std vector Index faceVerts , std vector Pos positionsPerVert Default primitive is currently a cube int const vertsPerPrimitive 8 int const facesPerPrimitive 6 int const faceVertsPerPrimitive 24 int nPrimitives multiplier multiplier multiplier positionsPerVert . reserve nPrimitives vertsPerPrimitive vertsPerFace . reserve nPrimitives facesPerPrimitive faceVerts . reserve nPrimitives faceVertsPerPrimitive for int x 0 x multiplier x for int y 0 y multiplier y for int z 0 z multiplier z appendDefaultPrimitive Pos float x 2.0f , float y 2.0f , float z 2.0f , vertsPerFace , faceVerts , positionsPerVert Create a TopologyRefiner from default geometry created above Far TopologyRefiner createTopologyRefinerDefault int multiplier , PosVector posVector std vector int topVertsPerFace std vector Index topFaceVerts createDefaultGeometry multiplier , topVertsPerFace , topFaceVerts , posVector typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_AND_CORNER Descriptor desc desc . numVertices int posVector . size desc . numFaces int topVertsPerFace . size desc . numVertsPerFace topVertsPerFace 0 desc . vertIndicesPerFace topFaceVerts 0 Instantiate a FarTopologyRefiner from the descriptor. Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options if refiner 0 exit EXIT_FAILURE bool dumpDefaultGeometryToObj false if dumpDefaultGeometryToObj int nVerts int posVector . size for int i 0 i nVerts i float const p posVector i . p printf v f f f n , p 0 , p 1 , p 2 int const fVerts topFaceVerts 0 int nFaces int topVertsPerFace . size for int i 0 i nFaces i printf f for int j 0 j topVertsPerFace i j printf d , 1 fVerts printf n exit EXIT_SUCCESS return refiner Create a TopologyRefiner from a specified Obj file geometry created internally Far TopologyRefiner createTopologyRefinerFromObj std string const objFileName , Sdc SchemeType schemeType , PosVector posVector const char filename objFileName . c_str const Shape shape 0 std ifstream ifs filename if ifs std stringstream ss ss ifs . rdbuf ifs . close std string shapeString ss . str shape Shape parseObj shapeString . c_str , ConvertSdcTypeToShapeScheme schemeType , false if shape 0 fprintf stderr , Error Cannot create Shape from .obj file s n , filename return 0 else fprintf stderr , Error Cannot open .obj file s n , filename return 0 Sdc SchemeType sdcType GetSdcType shape Sdc Options sdcOptions GetSdcOptions shape Far TopologyRefiner refiner Far TopologyRefinerFactory Shape Create shape , Far TopologyRefinerFactory Shape Options sdcType , sdcOptions if refiner 0 fprintf stderr , Error Unable to construct TopologyRefiner from .obj file s n , filename return 0 int numVertices refiner - GetNumVerticesTotal posVector . resize numVertices std memcpy posVector 0 . p 0 , shape - verts 0 , numVertices 3 sizeof float delete shape return refiner end namespace The PatchGroup bundles objects used to create and evaluate a sparse set of patches. Its construction creates a PatchTable and all other objects necessary to evaluate patches associated with the specified subset of faces provided. A simple method to tessellate a specified face is provided. Note that, since the data buffers for the base level and refined levels are separate we want to avoid copying primvar data for the base level of a potentially large mesh, that patch evaluation needs to account for the separation when combining control points. struct PatchGroup PatchGroup Far PatchTableFactory Options patchOptions , Far TopologyRefiner const baseRefinerArg , Far PtexIndices const basePtexIndicesArg , std vector Pos const basePositionsArg , std vector Index const baseFacesArg PatchGroup void TessellateBaseFace int face , PosVector tessPoints , TriVector tessTris const Const reference members Far TopologyRefiner const baseRefiner Far PtexIndices const basePtexIndices std vector Pos const basePositions std vector Index const baseFaces Members constructed to evaluate patches Far PatchTable patchTable Far PatchMap patchMap int patchFaceSize std vector Pos localPositions PatchGroup PatchGroup Far PatchTableFactory Options patchOptions , Far TopologyRefiner const baseRefinerArg , Far PtexIndices const basePtexIndicesArg , std vector Pos const basePositionsArg , std vector Index const baseFacesArg baseRefiner baseRefinerArg , basePtexIndices basePtexIndicesArg , basePositions basePositionsArg , baseFaces baseFacesArg Create a local refiner sharing the base level, apply adaptive refinement to the given subset of base faces, and construct a patch table and its associated map for the same set of faces Far ConstIndexArray groupFaces baseFaces 0 , int baseFaces . size Far TopologyRefiner localRefiner Far TopologyRefinerFactory Far TopologyDescriptor Create baseRefiner localRefiner - RefineAdaptive patchOptions . GetRefineAdaptiveOptions , groupFaces patchTable Far PatchTableFactory Create localRefiner , patchOptions , groupFaces patchMap new Far PatchMap patchTable patchFaceSize Sdc SchemeTypeTraits GetRegularFaceSize baseRefiner . GetSchemeType Compute the number of refined and local points needed to evaluate the patches, allocate and interpolate. This varies from tutorial_5_1 in that the primvar buffer for the base vertices is separate from the refined vertices and local patch points which must also be accounted for when evaluating the patches. int nBaseVertices localRefiner - GetLevel 0 . GetNumVertices int nRefinedVertices localRefiner - GetNumVerticesTotal - nBaseVertices int nLocalPoints patchTable - GetNumLocalPoints localPositions . resize nRefinedVertices nLocalPoints if nRefinedVertices Far PrimvarRefiner primvarRefiner localRefiner Pos const src basePositions 0 Pos dst localPositions 0 for int level 1 level localRefiner - GetNumLevels level primvarRefiner . Interpolate level , src , dst src dst dst localRefiner - GetLevel level . GetNumVertices if nLocalPoints patchTable - GetLocalPointStencilTable - UpdateValues basePositions 0 , nBaseVertices , localPositions 0 , localPositions nRefinedVertices delete localRefiner PatchGroup PatchGroup delete patchTable delete patchMap void PatchGroup TessellateBaseFace int face , PosVector tessPoints , TriVector tessTris const Tesselate the face with points at the midpoint of the face and at each corner, and triangles connecting the midpoint to each edge. Irregular faces require an aribrary number of corners points, but all are at the origin of the child face of the irregular base face float const quadPoints 5 2 0.5f , 0.5f , 0.0f , 0.0f , 1.0f , 0.0f , 1.0f , 1.0f , 0.0f , 1.0f float const triPoints 4 2 0.5f , 0.5f , 0.0f , 0.0f , 1.0f , 0.0f , 0.0f , 1.0f float const irregPoints 4 2 1.0f , 1.0f , 0.0f , 0.0f Determine the topology of the given base face and the resulting tessellation points and faces to generate int baseFace baseFaces face int faceSize baseRefiner . GetLevel 0 . GetFaceVertices baseFace . size bool faceIsIrregular faceSize patchFaceSize int nTessPoints faceSize 1 int nTessFaces faceSize tessPoints . resize nTessPoints tessTris . resize nTessFaces Compute the mid and corner points -- remember that for an irregular face, we must reference the individual ptex faces for each corner int ptexFace basePtexIndices . GetFaceId baseFace int numBaseVerts int basePositions . size for int i 0 i nTessPoints i Choose the s,t coordinate from the fixed tessellation float const st faceIsIrregular irregPoints i 0 faceSize 4 quadPoints i triPoints i Locate the patch corresponding to the face ptex idx and s,t and evaluate int patchFace ptexFace if faceIsIrregular i 0 patchFace i - 1 Far PatchTable PatchHandle const handle patchMap - FindPatch patchFace , st 0 , st 1 assert handle float pWeights 20 patchTable - EvaluateBasis handle , st 0 , st 1 , pWeights Identify the patch cvs and combine with the evaluated weights -- remember to distinguish cvs in the base level Far ConstIndexArray cvIndices patchTable - GetPatchVertices handle Pos pos tessPoints i pos . Clear for int cv 0 cv cvIndices . size cv int cvIndex cvIndices cv if cvIndex numBaseVerts pos . AddWithWeight basePositions cvIndex , pWeights cv else pos . AddWithWeight localPositions cvIndex - numBaseVerts , pWeights cv Assign triangles connecting the midpoint of the base face to the points computed at the ends of each of its edges for int i 0 i nTessFaces i tessTris i Tri 0 , 1 i , 1 i 1 faceSize Command line arguments parsed to provide run-time options class Args public std string inputObjFile Sdc SchemeType schemeType int geoMultiplier int maxPatchDepth int numPatchGroups bool noTessFlag bool noOutputFlag public Args int argc , char argv inputObjFile , schemeType Sdc SCHEME_CATMARK , geoMultiplier 10 , maxPatchDepth 3 , numPatchGroups 10 , noTessFlag false , noOutputFlag false Parse and assign standard arguments and Obj files ArgOptions args args . Parse argc , argv maxPatchDepth args . GetLevel schemeType ConvertShapeSchemeToSdcType args . GetDefaultScheme const std vector const char objFiles args . GetObjFiles if objFiles . empty for size_t i 1 i objFiles . size i fprintf stderr , Warning .obj file s ignored n , objFiles i inputObjFile std string objFiles 0 Parse remaining arguments specific to this example const std vector const char rargs args . GetRemainingArgs for size_t i 0 i rargs . size i if strcmp rargs i , -groups if i rargs . size numPatchGroups atoi rargs i else if strcmp rargs i , -mult if i rargs . size geoMultiplier atoi rargs i else if strcmp rargs i , -notess noTessFlag true else if strcmp rargs i , -nooutput noOutputFlag true else fprintf stderr , Warning Argument s ignored n , rargs i private Args Load command line arguments and geometry, then divide the mesh into groups of faces from which to create and tessellate patches int main int argc , char argv Args args argc , argv Create or load the base geometry command line arguments allow a .obj file to be specified. In addition to the TopologyRefiner and set of positions for the base vertices, a set of PtexIndices is also required to evaluate patches, so build it here once for use elsewhere std vector Pos basePositions Far TopologyRefiner baseRefinerPtr args . inputObjFile . empty createTopologyRefinerDefault args . geoMultiplier , basePositions createTopologyRefinerFromObj args . inputObjFile , args . schemeType , basePositions assert baseRefinerPtr Far TopologyRefiner baseRefiner baseRefinerPtr Far PtexIndices basePtexIndices baseRefiner Determine the sizes of the patch groups specified -- there will be two sizes that differ by one to account for unequal division int numBaseFaces baseRefiner . GetNumFacesTotal int numPatchGroups args . numPatchGroups if numPatchGroups numBaseFaces numPatchGroups numBaseFaces else if numPatchGroups 1 numPatchGroups 1 int lesserGroupSize numBaseFaces numPatchGroups int numLargerGroups numBaseFaces - numPatchGroups lesserGroupSize Define the options used to construct the patches for each group. Unless suppressed, a tessellation in Obj format will also be printed to standard output, so keep track of the vertex indices. Far PatchTableFactory Options patchOptions args . maxPatchDepth patchOptions . generateVaryingTables false patchOptions . shareEndCapPatchPoints false patchOptions . endCapType Far PatchTableFactory Options ENDCAP_GREGORY_BASIS int objVertCount 0 PosVector tessPoints TriVector tessFaces for int i 0 i numPatchGroups i Initialize a vector with a group of base faces from which to create and evaluate patches Index minFace i lesserGroupSize std min i , numLargerGroups Index maxFace minFace lesserGroupSize i numLargerGroups std vector Far Index baseFaces maxFace - minFace for int face minFace face maxFace face baseFaces face - minFace face Declare a PatchGroup and tessellate its base faces -- generating vertices and faces in Obj format to standard output PatchGroup patchGroup patchOptions , baseRefiner , basePtexIndices , basePositions , baseFaces if args . noTessFlag continue if args . noOutputFlag printf g patchGroup_d n , i for int j 0 j int baseFaces . size j patchGroup . TessellateBaseFace j , tessPoints , tessFaces if args . noOutputFlag int nVerts int tessPoints . size for int k 0 k nVerts k float const p tessPoints k . p printf v f f f n , p 0 , p 1 , p 2 int nTris int tessFaces . size int vBase 1 objVertCount for int k 0 k nTris k int const v tessFaces k . v printf f d d d n , vBase v 0 , vBase v 1 , vBase v 2 objVertCount nVerts delete baseRefinerPtr return EXIT_SUCCESS Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "far_tutorial_5_2.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "far_tutorial_5_1.cpp", │ │ │ │ │ - "text": "far_tutorial_5_1.cpp far_tutorial_5_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_5_1far_tutorial_5_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to interpolate surface limits at arbitrary parametric locations using feature adaptive FarPatchTables. The evaluation of the limit surface at arbitrary locations requires the adaptive isolation of topological features. This process converts the input polygonal control cage into a collection of bi-cubic patches. We can then evaluate the patches at random parametric locations and obtain analytical positions and tangents on the limit surface. The results are dumped into a MEL script that draws streak particle systems that show the tangent and bi-tangent at the random samples locations. include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include opensubdivfarpatchTableFactory.h include opensubdivfarpatchMap.h include opensubdivfarptexIndices.h include cassert include cstdio include cstring include cfloat using namespace OpenSubdiv typedef double Real pyramid geometry from catmark_pyramid_crease0.h static int const g_nverts 5 static Real const g_verts 24 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 2.0f , 0.0f , 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 0.0f , static int const g_vertsperface 5 3 , 3 , 3 , 3 , 4 static int const g_nfaces 5 static int const g_faceverts 16 0 , 1 , 2 , 0 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 4 , 3 , 2 , 1 static int const g_ncreases 4 static int const g_creaseverts 8 4 , 3 , 3 , 2 , 2 , 1 , 1 , 4 static float const g_creaseweights 4 3.0f , 3.0f , 3.0f , 3.0f Creates a FarTopologyRefiner from the pyramid shape above static Far TopologyRefiner createTopologyRefiner ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex void Clear void 0 point 0 point 1 point 2 0.0f void AddWithWeight Vertex const src , Real weight point 0 weight src . point 0 point 1 weight src . point 1 point 2 weight src . point 2 Real point 3 ------------------------------------------------------------------------------ Limit frame container implementation -- this interface is not strictly required but follows a similar pattern to Vertex. struct LimitFrame void Clear void 0 point 0 point 1 point 2 0.0f deriv1 0 deriv1 1 deriv1 2 0.0f deriv2 0 deriv2 1 deriv2 2 0.0f void AddWithWeight Vertex const src , Real weight , Real d1Weight , Real d2Weight point 0 weight src . point 0 point 1 weight src . point 1 point 2 weight src . point 2 deriv1 0 d1Weight src . point 0 deriv1 1 d1Weight src . point 1 deriv1 2 d1Weight src . point 2 deriv2 0 d2Weight src . point 0 deriv2 1 d2Weight src . point 1 deriv2 2 d2Weight src . point 2 Real point 3 , deriv1 3 , deriv2 3 ------------------------------------------------------------------------------ int main int , char Generate a FarTopologyRefiner see tutorial_1_1 for details. Far TopologyRefiner refiner createTopologyRefiner Patches are constructed from adaptively refined faces, but the processes of constructing the PatchTable and of applying adaptive refinement have historically been separate. Adaptive refinement is applied purely to satisfy the needs of the desired PatchTable, so options associated with adaptive refinement should be derived from those specified for the PatchTable. This is not a strict requirement, but it will avoid problems arising from specifyingcoordinating the two independently especially when dealing with face-varying patches. Initialize options for the PatchTable Choose patches adaptively refined to level 3 since the sharpest crease in the shape is 3.0f in g_creaseweights, and include the inf-sharp crease option just to illustrate the need to syncronize options. int maxPatchLevel 3 Far PatchTableFactory Options patchOptions maxPatchLevel patchOptions . SetPatchPrecision Real patchOptions . useInfSharpPatch true patchOptions . generateVaryingTables false patchOptions . endCapType Far PatchTableFactory Options ENDCAP_GREGORY_BASIS Initialize corresonding options for adaptive refinement Far TopologyRefiner AdaptiveOptions adaptiveOptions maxPatchLevel bool assignAdaptiveOptionsExplicitly false if assignAdaptiveOptionsExplicitly adaptiveOptions . useInfSharpPatch true else Be sure patch options were intialized with the desired max level adaptiveOptions patchOptions . GetRefineAdaptiveOptions assert adaptiveOptions . useInfSharpPatch patchOptions . useInfSharpPatch Apply adaptive refinement and construct the associated PatchTable to evaluate the limit surface refiner - RefineAdaptive adaptiveOptions Far PatchTable const patchTable Far PatchTableFactory Create refiner , patchOptions Compute the total number of points we need to evaluate the PatchTable. Approximations at irregular or extraordinary features require the use of additional points associated with the patches that are referred to as local points i.e. local to the PatchTable. int nRefinerVertices refiner - GetNumVerticesTotal int nLocalPoints patchTable - GetNumLocalPoints Create a buffer to hold the position of the refined verts and local points, then copy the coarse positions at the beginning. std vector Vertex verts nRefinerVertices nLocalPoints std memcpy verts 0 , g_verts , g_nverts 3 sizeof Real Adaptive refinement may result in fewer levels than the max specified. int nRefinedLevels refiner - GetNumLevels Interpolate vertex primvar data they are the control vertices of the limit patches see tutorial_1_1 for details Far PrimvarRefinerReal Real primvarRefiner refiner Vertex src verts 0 for int level 1 level nRefinedLevels level Vertex dst src refiner - GetLevel level -1 . GetNumVertices primvarRefiner . Interpolate level , src , dst src dst Evaluate local points from interpolated vertex primvars. if nLocalPoints patchTable - GetLocalPointStencilTable Real - UpdateValues verts 0 , verts nRefinerVertices Create a FarPatchMap to help locating patches in the table Far PatchMap patchmap patchTable Create a FarPtexIndices to help find indices of ptex faces. Far PtexIndices ptexIndices refiner Generate random samples on each ptex face int nsamplesPerFace 200 , nfaces ptexIndices . GetNumFaces std vector LimitFrame samples nsamplesPerFace nfaces srand static_cast int 2147483647 Real pWeights 20 , dsWeights 20 , dtWeights 20 for int face 0 , count 0 face nfaces face for int sample 0 sample nsamplesPerFace sample , count Real s Real rand Real RAND_MAX , t Real rand Real RAND_MAX Locate the patch corresponding to the face ptex idx and s,t Far PatchTable PatchHandle const handle patchmap . FindPatch face , s , t assert handle Evaluate the patch weights, identify the CVs and compute the limit frame patchTable - EvaluateBasis handle , s , t , pWeights , dsWeights , dtWeights Far ConstIndexArray cvs patchTable - GetPatchVertices handle LimitFrame dst samples count dst . Clear for int cv 0 cv cvs . size cv dst . AddWithWeight verts cvs cv , pWeights cv , dsWeights cv , dtWeights cv Visualization with Maya print a MEL script that generates particles at the location of the limit vertices int nsamples int samples . size printf file -f -new n Output particle positions for the tangent printf particle -n deriv1 for int sample 0 sample nsamples sample Real const pos samples sample . point printf -p f f f n , pos 0 , pos 1 , pos 2 printf n Set per-particle direction using the limit tangent display as Streak printf setAttr deriv1.particleRenderType 6 n printf setAttr deriv1.velocity -type vectorArray d , nsamples for int sample 0 sample nsamples sample Real const tan1 samples sample . deriv1 printf f f f n , tan1 0 , tan1 1 , tan1 2 printf n Output particle positions for the bi-tangent printf particle -n deriv2 for int sample 0 sample nsamples sample Real const pos samples sample . point printf -p f f f n , pos 0 , pos 1 , pos 2 printf n printf setAttr deriv2.particleRenderType 6 n printf setAttr deriv2.velocity -type vectorArray d , nsamples for int sample 0 sample nsamples sample Real const tan2 samples sample . deriv2 printf f f f n , tan2 0 , tan2 1 , tan2 2 printf n Exercise to the reader cross tangent bi-tangent for limit surface normal... Force Maya DAG update to see the result in the viewport printf currentTime -edit currentTime -q n printf select deriv1Shape deriv2Shape n delete refiner delete patchTable return EXIT_SUCCESS ------------------------------------------------------------------------------ static Far TopologyRefiner createTopologyRefiner typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_faceverts desc . numCreases g_ncreases desc . creaseVertexIndexPairs g_creaseverts desc . creaseWeights g_creaseweights Instantiate a FarTopologyRefiner from the descriptor. Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options return refiner Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "far_tutorial_5_1.html" │ │ │ │ │ - }, { │ │ │ │ │ "title": "far_tutorial_5_3.cpp", │ │ │ │ │ "text": "far_tutorial_5_3.cpp far_tutorial_5_3.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_5_3far_tutorial_5_3.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to use a FarLimitStenciTable to repeatedly and efficiently evaluate a set of points and optionally derivatives on the limit surface. A LimitStencilTable derives from StencilTable but is specialized to factor the evaluation of limit positions and derivatives into stencils. This allows a set of limit properties to be efficiently recomputed in response to changes to the vertices of the base mesh. Constructing the different kinds of StencilTables can have a high cost, so whether that cost is worth it will depend on your usage e.g. if points are only computed once, using stencil tables is typically not worth the added cost. Any points on the limit surface can be identified for evaluation. In this example we create a crude tessellation similar to tutorial_5_2. The midpoint of each face and points near the corners of the face are evaluated and a triangle fan connects them. include ......regressioncommonarg_utils.h include ......regressioncommonfar_utils.h include opensubdivfartopologyDescriptor.h include opensubdivfarpatchTableFactory.h include opensubdivfarstencilTableFactory.h include opensubdivfarptexIndices.h include cassert include cstdio include cstring include fstream include sstream using namespace OpenSubdiv using Far Index Global utilities in this namespace are not relevant to the tutorial. They simply serve to construct some default geometry to be processed in the form of a TopologyRefiner and vector of vertex positions. namespace Simple structs for x,y,z position and a 3-tuple for the set of vertices of a triangle struct Pos Pos Pos float x , float y , float z p 0 x , p 1 y , p 2 z Pos operator Pos const op const return Pos p 0 op . p 0 , p 1 op . p 1 , p 2 op . p 2 Clear and AddWithWeight required for interpolation void Clear void 0 p 0 p 1 p 2 0.0f void AddWithWeight Pos const src , float weight p 0 weight src . p 0 p 1 weight src . p 1 p 2 weight src . p 2 float p 3 typedef std vector Pos PosVector struct Tri Tri Tri int a , int b , int c v 0 a , v 1 b , v 2 c int v 3 typedef std vector Tri TriVector Functions to populate the topology and geometry arrays a simple shape whose positions may be transformed void createCube std vector int vertsPerFace , std vector Index faceVertsPerFace , std vector Pos positionsPerVert Local topology and position of a cube centered at origin static float const cubePositions 8 3 -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f static int const cubeFaceVerts 6 4 0 , 3 , 2 , 1 , 4 , 5 , 6 , 7 , 0 , 4 , 7 , 3 , 1 , 2 , 6 , 5 , 0 , 1 , 5 , 4 , 3 , 7 , 6 , 2 Initialize verts-per-face and face-vertices for each face vertsPerFace . resize 6 faceVertsPerFace . resize 24 for int i 0 i 6 i vertsPerFace i 4 for int j 0 j 4 j faceVertsPerFace i 4 j cubeFaceVerts i j Initialize vertex positions positionsPerVert . resize 8 for int i 0 i 8 i float const p cubePositions i positionsPerVert i Pos p 0 , p 1 , p 2 Create a TopologyRefiner from default geometry created above Far TopologyRefiner createTopologyRefinerDefault PosVector posVector std vector int topVertsPerFace std vector Index topFaceVerts createCube topVertsPerFace , topFaceVerts , posVector typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_AND_CORNER Descriptor desc desc . numVertices int posVector . size desc . numFaces int topVertsPerFace . size desc . numVertsPerFace topVertsPerFace 0 desc . vertIndicesPerFace topFaceVerts 0 Instantiate a FarTopologyRefiner from the descriptor. Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options assert refiner return refiner Create a TopologyRefiner from a specified Obj file geometry created internally Far TopologyRefiner createTopologyRefinerFromObj std string const objFileName , Sdc SchemeType schemeType , PosVector posVector const char filename objFileName . c_str const Shape shape 0 std ifstream ifs filename if ifs std stringstream ss ss ifs . rdbuf ifs . close std string shapeString ss . str shape Shape parseObj shapeString . c_str , ConvertSdcTypeToShapeScheme schemeType , false if shape 0 fprintf stderr , Error Cannot create Shape from .obj file s n , filename return 0 else fprintf stderr , Error Cannot open .obj file s n , filename return 0 Sdc SchemeType sdcType GetSdcType shape Sdc Options sdcOptions GetSdcOptions shape Far TopologyRefiner refiner Far TopologyRefinerFactory Shape Create shape , Far TopologyRefinerFactory Shape Options sdcType , sdcOptions if refiner 0 fprintf stderr , Error Unable to construct TopologyRefiner from .obj file s n , filename return 0 int numVertices refiner - GetNumVerticesTotal posVector . resize numVertices std memcpy posVector 0 . p 0 , shape - verts 0 , numVertices 3 sizeof float delete shape return refiner Simple function to export an Obj file for the limit points -- which provides a simple tessllation similar to tutorial_5_2. int writeToObj Far TopologyLevel const baseLevel , std vector Pos const vertexPositions , int nextObjVertexIndex for size_t i 0 i vertexPositions . size i float const p vertexPositions i . p printf v f f f n , p 0 , p 1 , p 2 Connect the sequences of limit points center followed by corners into triangle fans for each base face for int i 0 i baseLevel . GetNumFaces i int faceSize baseLevel . GetFaceVertices i . size int vCenter nextObjVertexIndex 1 int vCorner vCenter 1 for int k 0 k faceSize k printf f d d d n , vCenter , vCorner k , vCorner k 1 faceSize nextObjVertexIndex faceSize 1 return nextObjVertexIndex end namespace Command line arguments parsed to provide run-time options class Args public std string inputObjFile Sdc SchemeType schemeType int maxPatchDepth int numPoses Pos poseOffset bool deriv1Flag bool noPatchesFlag bool noOutputFlag public Args int argc , char argv inputObjFile , schemeType Sdc SCHEME_CATMARK , maxPatchDepth 3 , numPoses 0 , poseOffset 1.0f , 0.0f , 0.0f , deriv1Flag false , noPatchesFlag false , noOutputFlag false Parse and assign standard arguments and Obj files ArgOptions args args . Parse argc , argv maxPatchDepth args . GetLevel schemeType ConvertShapeSchemeToSdcType args . GetDefaultScheme const std vector const char objFiles args . GetObjFiles if objFiles . empty for size_t i 1 i objFiles . size i fprintf stderr , Warning .obj file s ignored n , objFiles i inputObjFile std string objFiles 0 Parse remaining arguments specific to this example const std vector const char rargs args . GetRemainingArgs for size_t i 0 i rargs . size i if strcmp rargs i , -d1 deriv1Flag true else if strcmp rargs i , -nopatches noPatchesFlag true else if strcmp rargs i , -poses if i rargs . size numPoses atoi rargs i else if strcmp rargs i , -offset if i rargs . size poseOffset . p 0 float atof rargs i if i rargs . size poseOffset . p 1 float atof rargs i if i rargs . size poseOffset . p 2 float atof rargs i else if strcmp rargs i , -nooutput noOutputFlag true else fprintf stderr , Warning Argument s ignored n , rargs i private Args Assemble the set of locations for the limit points. The resulting vector of LocationArrays can contain arbitrary locations on the limit surface -- with multiple locations for the same patch grouped into a single array. In this case, for each base face, coordinates for the center and its corners are specified -- from which we will construct a triangle fan providing a crude tessellation similar to tutorial_5_2. typedef Far LimitStencilTableFactory LocationArray LocationArray int assembleLimitPointLocations Far TopologyRefiner const refiner , std vector LocationArray locations Coordinates for the center of the face and its corners slightly inset. Unlike most of the public interface for patches, the LocationArray refers to parameteric coordinates as s,t, so that convention will be followed here. Note that the s,t coordinates in a LocationArray are referred to by reference. The memory holding these s,t values must persist while the LimitStencilTable is constructed -- the arrays here are declared as static for that purpose. static float const quadSCoords 5 0.5f , 0.05f , 0.95f , 0.95f , 0.05f static float const quadTCoords 5 0.5f , 0.05f , 0.05f , 0.95f , 0.95f static float const triSCoords 4 0.33f , 0.05f , 0.95f , 0.05f static float const triTCoords 4 0.33f , 0.05f , 0.00f , 0.95f static float const irregSCoords 2 1.0f , 0.05f static float const irregTCoords 2 1.0f , 0.05f Since these are references to patches to be evaluated, we require use of the Ptex indices to identify the top-most parameterized patch, which is essential to dealing with non-quad faces in the case of Catmark. Far TopologyLevel const baseLevel refiner . GetLevel 0 Far PtexIndices basePtexIndices refiner int regFaceSize Sdc SchemeTypeTraits GetRegularFaceSize refiner . GetSchemeType For each base face, simply refer to the s,t arrays for regular quad and triangular patches with a single LocationArray. Otherwise, for irregular faces, the corners of the face come from different patches and so must be referenced in separate LocationArrays. locations . clear int numLimitPoints 0 for int i 0 i baseLevel . GetNumFaces i int baseFaceSize baseLevel . GetFaceVertices i . size int basePtexId basePtexIndices . GetFaceId i bool faceIsRegular baseFaceSize regFaceSize if faceIsRegular All coordinates are on the same top-level patch LocationArray loc loc . ptexIdx basePtexId loc . numLocations baseFaceSize 1 if baseFaceSize 4 loc . s quadSCoords loc . t quadTCoords else loc . s triSCoords loc . t triTCoords locations . push_back loc else Center coordinate is on the first sub-patch while those on near the corners are on each successive sub-patch LocationArray loc loc . numLocations 1 for int j 0 j baseFaceSize j bool isPerimeter j 0 loc . ptexIdx basePtexId isPerimeter j -1 0 loc . s irregSCoords isPerimeter loc . t irregTCoords isPerimeter locations . push_back loc numLimitPoints baseFaceSize 1 return numLimitPoints Load command line arguments and geometry, build the LimitStencilTable for a set of points on the limit surface and compute those points for several orientations of the mesh int main int argc , char argv Args args argc , argv Create or load the base geometry command line arguments allow a .obj file to be specified, providing a TopologyRefiner and a set of base vertex positions to work with std vector Pos basePositions Far TopologyRefiner refinerPtr args . inputObjFile . empty createTopologyRefinerDefault basePositions createTopologyRefinerFromObj args . inputObjFile , args . schemeType , basePositions assert refinerPtr Far TopologyRefiner refiner refinerPtr Far TopologyLevel const baseLevel refiner . GetLevel 0 Use of LimitStencilTable requires either explicit or implicit use of a PatchTable. A PatchTable is not required to construct a LimitStencilTable -- one will be constructed internally for use and discarded -- but explicit construction is recommended to control the many legacy options for PatchTable, rather than relying on internal defaults. Adaptive refinement is required in both cases to indicate the accuracy of the patches. Note that if a TopologyRefiner and PatchTable are not used for any other purpose than computing the limit points, that specifying the subset of faces containing those limit points in the adaptive refinement and PatchTable construction can avoid unnecessary overhead. Far PatchTable patchTablePtr 0 if args . noPatchesFlag refiner . RefineAdaptive Far TopologyRefiner AdaptiveOptions args . maxPatchDepth else Far PatchTableFactory Options patchOptions args . maxPatchDepth patchOptions . useInfSharpPatch true patchOptions . generateLegacySharpCornerPatches false patchOptions . generateVaryingTables false patchOptions . generateFVarTables false patchOptions . endCapType Far PatchTableFactory Options ENDCAP_GREGORY_BASIS refiner . RefineAdaptive patchOptions . GetRefineAdaptiveOptions patchTablePtr Far PatchTableFactory Create refiner , patchOptions assert patchTablePtr Assemble the set of locations for the limit points. For each base face, coordinates for the center and its corners are specified -- from which we will construct a triangle fan providing a crude tessellation similar to tutorial_5_2. std vector LocationArray locations int numLimitPoints assembleLimitPointLocations refiner , locations Construct a LimitStencilTable from the refiner, patch table optional and the collection of limit point locations. Stencils can optionally be created for computing dervatives -- the default is to compute 1st derivative stencils, so be sure to disable that if not necessary Far LimitStencilTableFactory Options limitOptions limitOptions . generate1stDerivatives args . deriv1Flag Far LimitStencilTable const limitStencilTablePtr Far LimitStencilTableFactory Create refiner , locations , 0 , optional StencilTable for the refined points patchTablePtr , optional PatchTable limitOptions assert limitStencilTablePtr Far LimitStencilTable const limitStencilTable limitStencilTablePtr Apply the constructed LimitStencilTable to compute limit positions from the base level vertex positions. This is trivial if computing all positions in one invokation. The UpdateValues method and those for derivatives are overloaded to optionally accept a subrange of indices to distribute the computation std vector Pos limitPositions numLimitPoints limitStencilTable . UpdateValues basePositions , limitPositions Call with the optional subrange limitStencilTable . UpdateValues basePositions , limitPositions , 0 , numLimitPoints 2 limitStencilTable . UpdateValues basePositions , limitPositions , numLimitPoints 2 1 , numLimitPoints Write vertices and faces in Obj format for the original limit points int objVertCount 0 if args . noOutputFlag printf g base_mesh n objVertCount writeToObj baseLevel , limitPositions , objVertCount Recompute the limit points and output faces for different poses of the original mesh -- in this case simply translated. Also optionally compute 1st derivatives though they are not used here std vector Pos posePositions basePositions std vector Pos limitDu args . deriv1Flag numLimitPoints 0 std vector Pos limitDv args . deriv1Flag numLimitPoints 0 for int i 0 i args . numPoses i Trivially transform the base vertex positions and re-compute for size_t j 0 j basePositions . size j posePositions j posePositions j args . poseOffset limitStencilTable . UpdateValues posePositions , limitPositions if args . deriv1Flag limitStencilTable . UpdateDerivs posePositions , limitDu , limitDv if args . noOutputFlag printf n g pose_d n , i objVertCount writeToObj baseLevel , limitPositions , objVertCount delete refinerPtr delete patchTablePtr delete limitStencilTablePtr return EXIT_SUCCESS Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "far_tutorial_5_3.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "far_tutorial_4_2.cpp", │ │ │ │ │ - "text": "far_tutorial_4_2.cpp far_tutorial_4_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_4_2far_tutorial_4_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to create and manipulate both vertex and varying FarStencilTable to interpolate 2 primvar data buffers vertex positions and vertex colors. include opensubdivfartopologyDescriptor.h include opensubdivfarstencilTable.h include opensubdivfarstencilTableFactory.h include cstdio include cstring ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _data 0 src . _data 0 _data 1 src . _data 1 _data 2 src . _data 2 void Clear void 0 _data 0 _data 1 _data 2 0.0f void AddWithWeight Vertex const src , float weight _data 0 weight src . _data 0 _data 1 weight src . _data 1 _data 2 weight src . _data 2 Public interface ------------------------------------ float const GetData const return _data private float _data 3 ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 24 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f Per-vertex RGB color data static float g_colors 24 1.0f , 0.0f , 0.5f , 0.0f , 1.0f , 0.0f , 0.0f , 0.0f , 1.0f , 1.0f , 1.0f , 1.0f , 1.0f , 1.0f , 0.0f , 0.0f , 1.0f , 1.0f , 1.0f , 0.0f , 1.0f , 0.0f , 0.0f , 0.0f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv static Far TopologyRefiner createTopologyRefiner ------------------------------------------------------------------------------ int main int , char Generate a FarTopologyRefiner see tutorial_1_1 for details. Far TopologyRefiner refiner createTopologyRefiner Uniformly refine the topology up to maxlevel. int maxlevel 4 refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel int nverts refiner - GetLevel maxlevel . GetNumVertices Use the FarStencilTable factory to create discrete stencil table Far StencilTableFactory Options options options . generateIntermediateLevels false only the highest refinement level. options . generateOffsets true Vertex primvar data Create stencils table for vertex interpolation options . interpolationMode Far StencilTableFactory INTERPOLATE_VERTEX Far StencilTable const vertexStencils Far StencilTableFactory Create refiner , options assert nverts vertexStencils - GetNumStencils Allocate vertex primvar buffer 1 stencil for each vertex std vector Vertex vertexBuffer vertexStencils - GetNumStencils Use the cube vertex positions as vertex primvar data Vertex vertexCVs reinterpret_cast Vertex g_verts Varying primvar data Create stencils table for varying interpolation options . interpolationMode Far StencilTableFactory INTERPOLATE_VARYING Far StencilTable const varyingStencils Far StencilTableFactory Create refiner , options assert nverts varyingStencils - GetNumStencils Allocate varying primvar buffer 1 stencil for each vertex std vector Vertex varyingBuffer varyingStencils - GetNumStencils Use per-vertex array of RGB colors as varying primvar data Vertex varyingCVs reinterpret_cast Vertex g_colors delete refiner Apply stencils in frame loop This section would be applied every frame after control vertices have been moved. Apply stencils on the control vertex data to update the primvar data of the refined vertices. vertexStencils - UpdateValues vertexCVs , vertexBuffer 0 varyingStencils - UpdateValues varyingCVs , varyingBuffer 0 Visualization with Maya print a MEL script that generates particles at the location of the refined vertices printf particle for int vert 0 vert int nverts vert float const pos vertexBuffer vert . GetData printf -p f f f n , pos 0 , pos 1 , pos 2 printf -c 1 n Set particle point size 20 -- very large printf addAttr -is true -ln pointSize -at long -dv 20 particleShape1 n Add per-particle color attribute rgbPP printf addAttr -ln rgbPP -dt vectorArray particleShape1 n Set per-particle color values from our varying primvar data printf setAttr particleShape1.rgbPP -type vectorArray d , nverts for int vert 0 vert nverts vert float const color varyingBuffer vert . GetData printf f f f n , color 0 , color 1 , color 2 printf n delete vertexStencils delete varyingStencils return EXIT_SUCCESS ------------------------------------------------------------------------------ static Far TopologyRefiner createTopologyRefiner Populate a topology descriptor with our raw data. typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor. Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options return refiner ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "bfr_tutorial_1_2.cpp", │ │ │ │ │ + "text": "bfr_tutorial_1_2.cpp bfr_tutorial_1_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_1_2bfr_tutorial_1_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial builds on the previous tutorial that makes use of the SurfaceFactory and Surface for evaluating the limit surface of faces by using the Tessellation class to determine the points to evaluate and the faces that connect them. The Tessellation class replaces the explicit determination of points and faces for the triangle fan of the previous example. Given a uniform tessellation rate via a command line option, Tessellation returns the set of coordinates to evaluate, and separately returns the faces that connect them. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include opensubdivbfrtessellation.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType int tessUniformRate bool tessQuadsFlag public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK , tessUniformRate 5 , tessQuadsFlag false for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else if strcmp argv i , -res if i argc tessUniformRate atoi argv i else if strcmp argv i , -quads tessQuadsFlag true else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface faceSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector int outFacets Assign Tessellation Options applied for all faces. Tessellations allow the creating of either 3- or 4-sided faces -- both of which are supported here via a command line option int const tessFacetSize 3 options . tessQuadsFlag Bfr Tessellation Options tessOptions tessOptions . SetFacetSize tessFacetSize tessOptions . PreserveQuads options . tessQuadsFlag Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surface for this face -- if valid skipping holes and boundary faces in some rare cases if meshSurfaceFactory . InitVertexSurface faceIndex , faceSurface continue Declare a simple uniform Tessellation for the Parameterization of this face and identify coordinates of the points to evaluate Bfr Tessellation tessPattern faceSurface . GetParameterization , options . tessUniformRate , tessOptions int numOutCoords tessPattern . GetNumCoords outCoords . resize numOutCoords 2 tessPattern . GetCoords outCoords . data Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Resize patch point and output arrays int pointSize 3 facePatchPoints . resize faceSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate patch point and output arrays faceSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize for int i 0 , j 0 i numOutCoords i , j pointSize faceSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outPos j , outDu j , outDv j Identify the faces of the Tessellation Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. One of several Tessellation methods to transform the facet indices simply translates all indices by the desired offset. int objVertexIndexOffset objWriter . GetNumVertices int numFacets tessPattern . GetNumFacets outFacets . resize numFacets tessFacetSize tessPattern . GetFacets outFacets . data tessPattern . TransformFacetCoordIndices outFacets . data , objVertexIndexOffset Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outFacets , tessFacetSize , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "far_tutorial_4_2.html" │ │ │ │ │ + "loc": "bfr_tutorial_1_2.html" │ │ │ │ │ + }, { │ │ │ │ │ + "title": "far_tutorial_5_1.cpp", │ │ │ │ │ + "text": "far_tutorial_5_1.cpp far_tutorial_5_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_5_1far_tutorial_5_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to interpolate surface limits at arbitrary parametric locations using feature adaptive FarPatchTables. The evaluation of the limit surface at arbitrary locations requires the adaptive isolation of topological features. This process converts the input polygonal control cage into a collection of bi-cubic patches. We can then evaluate the patches at random parametric locations and obtain analytical positions and tangents on the limit surface. The results are dumped into a MEL script that draws streak particle systems that show the tangent and bi-tangent at the random samples locations. include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include opensubdivfarpatchTableFactory.h include opensubdivfarpatchMap.h include opensubdivfarptexIndices.h include cassert include cstdio include cstring include cfloat using namespace OpenSubdiv typedef double Real pyramid geometry from catmark_pyramid_crease0.h static int const g_nverts 5 static Real const g_verts 24 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 2.0f , 0.0f , 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 0.0f , static int const g_vertsperface 5 3 , 3 , 3 , 3 , 4 static int const g_nfaces 5 static int const g_faceverts 16 0 , 1 , 2 , 0 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 4 , 3 , 2 , 1 static int const g_ncreases 4 static int const g_creaseverts 8 4 , 3 , 3 , 2 , 2 , 1 , 1 , 4 static float const g_creaseweights 4 3.0f , 3.0f , 3.0f , 3.0f Creates a FarTopologyRefiner from the pyramid shape above static Far TopologyRefiner createTopologyRefiner ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex void Clear void 0 point 0 point 1 point 2 0.0f void AddWithWeight Vertex const src , Real weight point 0 weight src . point 0 point 1 weight src . point 1 point 2 weight src . point 2 Real point 3 ------------------------------------------------------------------------------ Limit frame container implementation -- this interface is not strictly required but follows a similar pattern to Vertex. struct LimitFrame void Clear void 0 point 0 point 1 point 2 0.0f deriv1 0 deriv1 1 deriv1 2 0.0f deriv2 0 deriv2 1 deriv2 2 0.0f void AddWithWeight Vertex const src , Real weight , Real d1Weight , Real d2Weight point 0 weight src . point 0 point 1 weight src . point 1 point 2 weight src . point 2 deriv1 0 d1Weight src . point 0 deriv1 1 d1Weight src . point 1 deriv1 2 d1Weight src . point 2 deriv2 0 d2Weight src . point 0 deriv2 1 d2Weight src . point 1 deriv2 2 d2Weight src . point 2 Real point 3 , deriv1 3 , deriv2 3 ------------------------------------------------------------------------------ int main int , char Generate a FarTopologyRefiner see tutorial_1_1 for details. Far TopologyRefiner refiner createTopologyRefiner Patches are constructed from adaptively refined faces, but the processes of constructing the PatchTable and of applying adaptive refinement have historically been separate. Adaptive refinement is applied purely to satisfy the needs of the desired PatchTable, so options associated with adaptive refinement should be derived from those specified for the PatchTable. This is not a strict requirement, but it will avoid problems arising from specifyingcoordinating the two independently especially when dealing with face-varying patches. Initialize options for the PatchTable Choose patches adaptively refined to level 3 since the sharpest crease in the shape is 3.0f in g_creaseweights, and include the inf-sharp crease option just to illustrate the need to syncronize options. int maxPatchLevel 3 Far PatchTableFactory Options patchOptions maxPatchLevel patchOptions . SetPatchPrecision Real patchOptions . useInfSharpPatch true patchOptions . generateVaryingTables false patchOptions . endCapType Far PatchTableFactory Options ENDCAP_GREGORY_BASIS Initialize corresonding options for adaptive refinement Far TopologyRefiner AdaptiveOptions adaptiveOptions maxPatchLevel bool assignAdaptiveOptionsExplicitly false if assignAdaptiveOptionsExplicitly adaptiveOptions . useInfSharpPatch true else Be sure patch options were intialized with the desired max level adaptiveOptions patchOptions . GetRefineAdaptiveOptions assert adaptiveOptions . useInfSharpPatch patchOptions . useInfSharpPatch Apply adaptive refinement and construct the associated PatchTable to evaluate the limit surface refiner - RefineAdaptive adaptiveOptions Far PatchTable const patchTable Far PatchTableFactory Create refiner , patchOptions Compute the total number of points we need to evaluate the PatchTable. Approximations at irregular or extraordinary features require the use of additional points associated with the patches that are referred to as local points i.e. local to the PatchTable. int nRefinerVertices refiner - GetNumVerticesTotal int nLocalPoints patchTable - GetNumLocalPoints Create a buffer to hold the position of the refined verts and local points, then copy the coarse positions at the beginning. std vector Vertex verts nRefinerVertices nLocalPoints std memcpy verts 0 , g_verts , g_nverts 3 sizeof Real Adaptive refinement may result in fewer levels than the max specified. int nRefinedLevels refiner - GetNumLevels Interpolate vertex primvar data they are the control vertices of the limit patches see tutorial_1_1 for details Far PrimvarRefinerReal Real primvarRefiner refiner Vertex src verts 0 for int level 1 level nRefinedLevels level Vertex dst src refiner - GetLevel level -1 . GetNumVertices primvarRefiner . Interpolate level , src , dst src dst Evaluate local points from interpolated vertex primvars. if nLocalPoints patchTable - GetLocalPointStencilTable Real - UpdateValues verts 0 , verts nRefinerVertices Create a FarPatchMap to help locating patches in the table Far PatchMap patchmap patchTable Create a FarPtexIndices to help find indices of ptex faces. Far PtexIndices ptexIndices refiner Generate random samples on each ptex face int nsamplesPerFace 200 , nfaces ptexIndices . GetNumFaces std vector LimitFrame samples nsamplesPerFace nfaces srand static_cast int 2147483647 Real pWeights 20 , dsWeights 20 , dtWeights 20 for int face 0 , count 0 face nfaces face for int sample 0 sample nsamplesPerFace sample , count Real s Real rand Real RAND_MAX , t Real rand Real RAND_MAX Locate the patch corresponding to the face ptex idx and s,t Far PatchTable PatchHandle const handle patchmap . FindPatch face , s , t assert handle Evaluate the patch weights, identify the CVs and compute the limit frame patchTable - EvaluateBasis handle , s , t , pWeights , dsWeights , dtWeights Far ConstIndexArray cvs patchTable - GetPatchVertices handle LimitFrame dst samples count dst . Clear for int cv 0 cv cvs . size cv dst . AddWithWeight verts cvs cv , pWeights cv , dsWeights cv , dtWeights cv Visualization with Maya print a MEL script that generates particles at the location of the limit vertices int nsamples int samples . size printf file -f -new n Output particle positions for the tangent printf particle -n deriv1 for int sample 0 sample nsamples sample Real const pos samples sample . point printf -p f f f n , pos 0 , pos 1 , pos 2 printf n Set per-particle direction using the limit tangent display as Streak printf setAttr deriv1.particleRenderType 6 n printf setAttr deriv1.velocity -type vectorArray d , nsamples for int sample 0 sample nsamples sample Real const tan1 samples sample . deriv1 printf f f f n , tan1 0 , tan1 1 , tan1 2 printf n Output particle positions for the bi-tangent printf particle -n deriv2 for int sample 0 sample nsamples sample Real const pos samples sample . point printf -p f f f n , pos 0 , pos 1 , pos 2 printf n printf setAttr deriv2.particleRenderType 6 n printf setAttr deriv2.velocity -type vectorArray d , nsamples for int sample 0 sample nsamples sample Real const tan2 samples sample . deriv2 printf f f f n , tan2 0 , tan2 1 , tan2 2 printf n Exercise to the reader cross tangent bi-tangent for limit surface normal... Force Maya DAG update to see the result in the viewport printf currentTime -edit currentTime -q n printf select deriv1Shape deriv2Shape n delete refiner delete patchTable return EXIT_SUCCESS ------------------------------------------------------------------------------ static Far TopologyRefiner createTopologyRefiner typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_faceverts desc . numCreases g_ncreases desc . creaseVertexIndexPairs g_creaseverts desc . creaseWeights g_creaseweights Instantiate a FarTopologyRefiner from the descriptor. Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options return refiner Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "far_tutorial_5_1.html" │ │ │ │ │ + }, { │ │ │ │ │ + "title": "bfr_tutorial_1_1.cpp", │ │ │ │ │ + "text": "bfr_tutorial_1_1.cpp bfr_tutorial_1_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsbfrtutorial_1_1bfr_tutorial_1_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial illustrates the use of the SurfaceFactory, Surface and Parameterization classes for creating and evaluating the limit surface associated with each base face of a mesh. Following the creation of a connected mesh for a shape using a FarTopologyRefiner, as illustrated in Far tutorials, an instance of a SurfaceFactory is declared to process its faces. Each face of the mesh is evaluated and tessellated independently with a simple triangle fan, with results written out in Obj format for inspection. These classes make it simple to evaluate and tessellate all faces quads, tris or others while supporting the full set of subdivision options. While a triangle fan may be a trivial tessellation and so not very useful later examples using the Tessellation class provide more useful results with the same simplicity. include opensubdivfartopologyRefiner.h include opensubdivbfrrefinerSurfaceFactory.h include opensubdivbfrsurface.h include vector include string include cstring include cstdio Local headers with support for this tutorial in namespace tutorial include .meshLoader.h include .objWriter.h using namespace OpenSubdiv Simple command line arguments to provide input and run-time options class Args public std string inputObjFile std string outputObjFile Sdc SchemeType schemeType public Args int argc , char argv inputObjFile , outputObjFile , schemeType Sdc SCHEME_CATMARK for int i 1 i argc i if strstr argv i , .obj if inputObjFile . empty inputObjFile std string argv i else fprintf stderr , Warning Extra Obj file s ignored n , argv i else if strcmp argv i , -o if i argc outputObjFile std string argv i else if strcmp argv i , -bilinear schemeType Sdc SCHEME_BILINEAR else if strcmp argv i , -catmark schemeType Sdc SCHEME_CATMARK else if strcmp argv i , -loop schemeType Sdc SCHEME_LOOP else fprintf stderr , Warning Unrecognized argument s ignored n , argv i private Args The main tessellation function given a mesh and vertex positions, tessellate each face -- writing results in Obj format. void tessellateToObj Far TopologyRefiner const meshTopology , std vector float const meshVertexPositions , Args const options Use simpler local type names for the Surface and its factory typedef Bfr RefinerSurfaceFactory SurfaceFactory typedef Bfr Surface float Surface Initialize the SurfaceFactory for the given base mesh very low cost in terms of both time and space and tessellate each face independently i.e. no shared vertices Note that the SurfaceFactory is not thread-safe by default due to use of an internal cache. Creating a separate instance of the SurfaceFactory for each thread is one way to safely parallelize this loop. Another preferred is to assign a thread-safe cache to the single instance. First declare any evaluation options when initializing though none are used in this simple case SurfaceFactory Options surfaceOptions SurfaceFactory meshSurfaceFactory meshTopology , surfaceOptions The Surface to be constructed and evaluated for each face -- as well as the intermediate and output data associated with it -- can be declared in the scope local to each face. But since dynamic memory is involved with these variables, it is preferred to declare them outside that loop to preserve and reuse that dynamic memory. Surface faceSurface std vector float facePatchPoints std vector float outCoords std vector float outPos , outDu , outDv std vector int outTriangles Process each face, writing the output of each in Obj format tutorial ObjWriter objWriter options . outputObjFile int numFaces meshSurfaceFactory . GetNumFaces for int faceIndex 0 faceIndex numFaces faceIndex Initialize the Surface for this face -- if valid skipping holes and boundary faces in some rare cases if meshSurfaceFactory . InitVertexSurface faceIndex , faceSurface continue Get the Parameterization of the Surface and use it to identify coordinates for evaluation -- in this case, at the vertices and center of the face to create a fan of triangles Bfr Parameterization faceParam faceSurface . GetParameterization int faceSize faceParam . GetFaceSize int numOutCoords faceSize 1 outCoords . resize numOutCoords 2 for int i 0 i faceSize i faceParam . GetVertexCoord i , outCoords i 2 faceParam . GetCenterCoord outCoords faceSize 2 Prepare the patch points for the Surface, then use them to evaluate output points for all identified coordinates Resize patch point and output arrays int pointSize 3 facePatchPoints . resize faceSurface . GetNumPatchPoints pointSize outPos . resize numOutCoords pointSize outDu . resize numOutCoords pointSize outDv . resize numOutCoords pointSize Populate patch point and output arrays faceSurface . PreparePatchPoints meshVertexPositions . data , pointSize , facePatchPoints . data , pointSize for int i 0 , j 0 i numOutCoords i , j pointSize faceSurface . Evaluate outCoords i 2 , facePatchPoints . data , pointSize , outPos j , outDu j , outDv j Identify the faces of the tessellation, i.e. the triangle fan connecting points at the vertices to the center last point Note the need to offset vertex indices for the output faces -- using the number of vertices generated prior to this face. int objVertexIndexOffset objWriter . GetNumVertices outTriangles . resize faceSize 3 int outTriangle outTriangles . data for int i 0 i faceSize i , outTriangle 3 outTriangle 0 objVertexIndexOffset i outTriangle 1 objVertexIndexOffset i 1 faceSize outTriangle 2 objVertexIndexOffset faceSize Write the evaluated points and faces connecting them as Obj objWriter . WriteGroupName baseFace_ , faceIndex objWriter . WriteVertexPositions outPos objWriter . WriteVertexNormals outDu , outDv objWriter . WriteFaces outTriangles , 3 , true , false Load command line arguments, specified or default geometry and process int main int argc , char argv Args args argc , argv Far TopologyRefiner meshTopology 0 std vector float meshVtxPositions std vector float meshFVarUVs meshTopology tutorial createTopologyRefiner args . inputObjFile , args . schemeType , meshVtxPositions , meshFVarUVs if meshTopology 0 return EXIT_FAILURE tessellateToObj meshTopology , meshVtxPositions , args delete meshTopology return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "bfr_tutorial_1_1.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "far_tutorial_4_3.cpp", │ │ │ │ │ "text": "far_tutorial_4_3.cpp far_tutorial_4_3.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_4_3far_tutorial_4_3.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to create and manipulate table of cascading stencils. We initialize a FarTopologyRefiner with a cube and apply uniform refinement. We then use a FarStencilTableFactory to generate a stencil table. We set the factory Options to not factorize intermediate levels, thus giving a table of cascading stencils. We then apply the stencils to the vertex position primvar data, and insert a hierarchical edit at level 1. This edit is smoothed by the application of the subsequent stencil cascades. The results are dumped into an OBJ file that shows the intermediate levels of refinement of the original cube. include opensubdivfartopologyDescriptor.h include opensubdivfarstencilTable.h include opensubdivfarstencilTableFactory.h include cstdio include cstring ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 _position 0 _position 1 _position 2 0.0f void AddWithWeight Vertex const src , float weight _position 0 weight src . _position 0 _position 1 weight src . _position 1 _position 2 weight src . _position 2 Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z float const GetPosition const return _position float GetPosition return _position private float _position 3 ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 24 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv static Far TopologyRefiner createTopologyRefiner ------------------------------------------------------------------------------ int main int , char Generate a FarTopologyRefiner see tutorial_1_1 for details. Far TopologyRefiner refiner createTopologyRefiner Uniformly refine the topology up to maxlevel. int maxlevel 4 refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Use the FarStencilTable factory to create cascading stencil table note we want stencils for each refinement level cascade mode is achieved by setting factorizeIntermediateLevels to false Far StencilTableFactory Options options options . generateIntermediateLevels true options . factorizeIntermediateLevels false options . generateOffsets true Far StencilTable const stencilTable Far StencilTableFactory Create refiner , options std vector Vertex vertexBuffer refiner - GetNumVerticesTotal - g_nverts Vertex destVerts vertexBuffer 0 int start 0 , end 0 stencil batches for each level of subdivision for int level 0 level maxlevel level int nverts refiner - GetLevel level 1 . GetNumVertices Vertex const srcVerts reinterpret_cast Vertex g_verts if level 0 srcVerts vertexBuffer start start end end nverts stencilTable - UpdateValues srcVerts , destVerts , start , end apply 2 hierarchical edits on level 1 vertices if level 1 float pos destVerts start 5 . GetPosition pos 1 0.5f pos destVerts start 20 . GetPosition pos 0 0.25f Output OBJ of the highest level refined ----------- Vertex verts vertexBuffer 0 Print vertex positions for int level 1 , firstvert 0 level maxlevel level Far TopologyLevel const refLevel refiner - GetLevel level printf g level_d n , level int nverts refLevel . GetNumVertices for int vert 0 vert nverts vert float const pos verts vert . GetPosition printf v f f f n , pos 0 , pos 1 , pos 2 verts nverts Print faces for int face 0 face refLevel . GetNumFaces face Far ConstIndexArray fverts refLevel . GetFaceVertices face all refined Catmark faces should be quads assert fverts . size 4 printf f for int vert 0 vert fverts . size vert printf d , fverts vert firstvert 1 OBJ uses 1-based arrays... printf n firstvert nverts delete refiner delete stencilTable return EXIT_SUCCESS ------------------------------------------------------------------------------ static Far TopologyRefiner createTopologyRefiner Populate a topology descriptor with our raw data. typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor. return Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "far_tutorial_4_3.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "far_tutorial_3_1.cpp", │ │ │ │ │ - "text": "far_tutorial_3_1.cpp far_tutorial_3_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_3_1far_tutorial_3_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to interface a high-level topology representation with Far for better efficiency. In tutorial 0, we showed how to instantiate topology from a simple face-vertex list. Here we will show how to take advantage of more complex data structures. Many client applications that manipulate geometry use advanced data structures such as half-edge, quad-edge or winged-edge in order to represent complex topological relationships beyond the usual face-vertex lists. We can take advantage of this information. Far provides an advanced interface that allows such a client application to communicate advanced component relationships directly and avoid having Far rebuilding them redundantly. include opensubdivfartopologyRefinerFactory.h include opensubdivfarprimvarRefiner.h include cstdio ------------------------------------------------------------------------------ using namespace OpenSubdiv ------------------------------------------------------------------------------ For this tutorial, we provide the complete topological representation of a simple pyramid. In our case, we store it as a simple sequence of integers, with the understanding that client-code would provide a fully implemented data-structure such as quad-edges or winged-edges. Pyramid geometry from catmark_pyramid.h - extended for this tutorial static int g_nverts 5 , g_nedges 8 , g_nfaces 5 vertex positions static float g_verts 5 3 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 2.0f , 0.0f , 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 0.0f number of vertices in each face static int g_facenverts 5 3 , 3 , 3 , 3 , 4 index of face vertices static int g_faceverts 16 0 , 1 , 2 , 0 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 4 , 3 , 2 , 1 index of edge vertices 2 per edge static int g_edgeverts 16 0 , 1 , 1 , 2 , 2 , 0 , 2 , 3 , 3 , 0 , 3 , 4 , 4 , 0 , 4 , 1 index of face edges static int g_faceedges 16 0 , 1 , 2 , 2 , 3 , 4 , 4 , 5 , 6 , 6 , 7 , 0 , 5 , 3 , 1 , 7 number of faces adjacent to each edge static int g_edgenfaces 8 2 , 2 , 2 , 2 , 2 , 2 , 2 , 2 index of faces incident to a given edge static int g_edgefaces 16 0 , 3 , 0 , 4 , 0 , 1 , 1 , 4 , 1 , 2 , 2 , 4 , 2 , 3 , 3 , 4 number of faces incident to each vertex static int g_vertexnfaces 5 4 , 3 , 3 , 3 , 3 index of faces incident to each vertex static int g_vertexfaces 25 0 , 1 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 1 , 4 , 2 , 2 , 4 , 3 number of edges incident to each vertex static int g_vertexnedges 5 4 , 3 , 3 , 3 , 3 index of edges incident to each vertex static int g_vertexedges 25 0 , 2 , 4 , 6 , 1 , 0 , 7 , 2 , 1 , 3 , 4 , 3 , 5 , 6 , 5 , 7 Edge crease sharpness static float g_edgeCreases 8 0.0f , 2.5f , 0.0f , 2.5f , 0.0f , 2.5f , 0.0f , 2.5f ------------------------------------------------------------------------------ Because existing client-code may not provide an exact match for the topological queries required by Fars interface, we can provide a converter class. This can be particularly useful for instance if the client data-structure requires additional relationships to be mapped. For instance, half-edge representations do not store unique edge indices and it can be difficult to traverse edges or faces adjacent to a given vertex. Using an intermediate wrapper class allows us to leverage existing relationships information from a mesh, and generate the missing components temporarily. For a practical example, you can look at the file hbr_to_vtr.h in the same tutorial directory. This example implements a OsdHbrConverter class as a way of interfacing PRmans half-edge representation to Far. struct Converter public Sdc SchemeType GetType const return Sdc SCHEME_CATMARK Sdc Options GetOptions const Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY return options int GetNumFaces const return g_nfaces int GetNumEdges const return g_nedges int GetNumVertices const return g_nverts Face relationships int GetNumFaceVerts int face const return g_facenverts face int const GetFaceVerts int face const return g_faceverts getCompOffset g_facenverts , face int const GetFaceEdges int face const return g_faceedges getCompOffset g_facenverts , face Edge relationships int const GetEdgeVertices int edge const return g_edgeverts edge 2 int GetNumEdgeFaces int edge const return g_edgenfaces edge int const GetEdgeFaces int edge const return g_edgefaces getCompOffset g_edgenfaces , edge Vertex relationships int GetNumVertexEdges int vert const return g_vertexnedges vert int const GetVertexEdges int vert const return g_vertexedges getCompOffset g_vertexnedges , vert int GetNumVertexFaces int vert const return g_vertexnfaces vert int const GetVertexFaces int vert const return g_vertexfaces getCompOffset g_vertexnfaces , vert private int getCompOffset int const comps , int comp const int ofs 0 for int i 0 i comp i ofs comps i return ofs ------------------------------------------------------------------------------ namespace OpenSubdiv namespace OPENSUBDIV_VERSION namespace Far template bool TopologyRefinerFactory Converter resizeComponentTopology TopologyRefiner refiner , Converter const conv Faces and face-verts int nfaces conv . GetNumFaces setNumBaseFaces refiner , nfaces for int face 0 face nfaces face int nv conv . GetNumFaceVerts face setNumBaseFaceVertices refiner , face , nv Edges and edge-faces int nedges conv . GetNumEdges setNumBaseEdges refiner , nedges for int edge 0 edge nedges edge int nf conv . GetNumEdgeFaces edge setNumBaseEdgeFaces refiner , edge , nf Vertices and vert-faces and vert-edges int nverts conv . GetNumVertices setNumBaseVertices refiner , nverts for int vert 0 vert nverts vert int ne conv . GetNumVertexEdges vert , nf conv . GetNumVertexFaces vert setNumBaseVertexEdges refiner , vert , ne setNumBaseVertexFaces refiner , vert , nf return true template bool TopologyRefinerFactory Converter assignComponentTopology TopologyRefiner refiner , Converter const conv using Far IndexArray Face relations int nfaces conv . GetNumFaces for int face 0 face nfaces face IndexArray dstFaceVerts getBaseFaceVertices refiner , face IndexArray dstFaceEdges getBaseFaceEdges refiner , face int const faceverts conv . GetFaceVerts face int const faceedges conv . GetFaceEdges face for int vert 0 vert conv . GetNumFaceVerts face vert dstFaceVerts vert faceverts vert dstFaceEdges vert faceedges vert Edge relations Note if your representation is unable to provide edge relationships ex half-edges, you can comment out this section and Far will automatically generate the missing information. int nedges conv . GetNumEdges for int edge 0 edge nedges edge Edge-vertices IndexArray dstEdgeVerts getBaseEdgeVertices refiner , edge dstEdgeVerts 0 conv . GetEdgeVertices edge 0 dstEdgeVerts 1 conv . GetEdgeVertices edge 1 Edge-faces IndexArray dstEdgeFaces getBaseEdgeFaces refiner , edge for int face 0 face conv . GetNumEdgeFaces face face dstEdgeFaces face conv . GetEdgeFaces edge face Vertex relations int nverts conv . GetNumVertices for int vert 0 vert nverts vert Vert-Faces IndexArray vertFaces getBaseVertexFaces refiner , vert LocalIndexArray vertInFaceIndices getBaseVertexFaceLocalIndicesrefiner, vert for int face 0 face conv . GetNumVertexFaces vert face vertFaces face conv . GetVertexFaces vert face Vert-Edges IndexArray vertEdges getBaseVertexEdges refiner , vert LocalIndexArray vertInEdgeIndices getBaseVertexEdgeLocalIndicesrefiner, vert for int edge 0 edge conv . GetNumVertexEdges vert edge vertEdges edge conv . GetVertexEdges vert edge populateBaseLocalIndices refiner return true template bool TopologyRefinerFactory Converter assignComponentTags TopologyRefiner refiner , Converter const conv arbitrarily sharpen the 4 bottom edges of the pyramid to 2.5f for int edge 0 edge conv . GetNumEdges edge setBaseEdgeSharpness refiner , edge , g_edgeCreases edge return true ifdef _MSC_VER template void TopologyRefinerFactory Converter reportInvalidTopology TopologyError errCode , char const msg , Converter const mesh Optional topology validation error reporting This method is called whenever the factory encounters topology validation errors. By default, nothing is reported Warning msg template bool TopologyRefinerFactory Converter assignFaceVaryingTopology TopologyRefiner refiner , Converter const conv Because of the way MSVC specializes templated functions, we had to remove the default stubs in FarTopologyRefinerFactory. In this example, no face-varying data is being added, but we still need to implement a template specialization or MSVC linker fails. return true endif namespace Far namespace OPENSUBDIV_VERSION namespace OpenSubdiv ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 _position 0 _position 1 _position 2 0.0f void AddWithWeight Vertex const src , float weight _position 0 weight src . _position 0 _position 1 weight src . _position 1 _position 2 weight src . _position 2 Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 ------------------------------------------------------------------------------ int main int , char Converter conv Far TopologyRefiner refiner Far TopologyRefinerFactory Converter Create conv , Far TopologyRefinerFactory Converter Options conv . GetType , conv . GetOptions int maxlevel 5 Uniformly refine the topology up to maxlevel refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Allocate a buffer for vertex primvar data. The buffer length is set to be the sum of all children vertices up to the highest level of refinement. std vector Vertex vbuffer refiner - GetNumVerticesTotal Vertex verts vbuffer 0 Initialize coarse mesh positions int nCoarseVerts g_nverts for int i 0 i nCoarseVerts i verts i . SetPosition g_verts i 0 , g_verts i 1 , g_verts i 2 Interpolate vertex primvar data Far PrimvarRefiner primvarRefiner refiner Vertex src verts for int level 1 level maxlevel level Vertex dst src refiner - GetLevel level -1 . GetNumVertices primvarRefiner . Interpolate level , src , dst src dst Output OBJ of the highest level refined ----------- Far TopologyLevel const refLastLevel refiner - GetLevel maxlevel int nverts refLastLevel . GetNumVertices int nfaces refLastLevel . GetNumFaces Print vertex positions int firstOfLastVerts refiner - GetNumVerticesTotal - nverts for int vert 0 vert nverts vert float const pos verts firstOfLastVerts vert . GetPosition printf v f f f n , pos 0 , pos 1 , pos 2 Print faces for int face 0 face nfaces face Far ConstIndexArray fverts refLastLevel . GetFaceVertices face all refined Catmark faces should be quads assert fverts . size 4 printf f for int vert 0 vert fverts . size vert printf d , fverts vert 1 OBJ uses 1-based arrays... printf n delete refiner return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "far_tutorial_4_2.cpp", │ │ │ │ │ + "text": "far_tutorial_4_2.cpp far_tutorial_4_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_4_2far_tutorial_4_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to create and manipulate both vertex and varying FarStencilTable to interpolate 2 primvar data buffers vertex positions and vertex colors. include opensubdivfartopologyDescriptor.h include opensubdivfarstencilTable.h include opensubdivfarstencilTableFactory.h include cstdio include cstring ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _data 0 src . _data 0 _data 1 src . _data 1 _data 2 src . _data 2 void Clear void 0 _data 0 _data 1 _data 2 0.0f void AddWithWeight Vertex const src , float weight _data 0 weight src . _data 0 _data 1 weight src . _data 1 _data 2 weight src . _data 2 Public interface ------------------------------------ float const GetData const return _data private float _data 3 ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 24 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f Per-vertex RGB color data static float g_colors 24 1.0f , 0.0f , 0.5f , 0.0f , 1.0f , 0.0f , 0.0f , 0.0f , 1.0f , 1.0f , 1.0f , 1.0f , 1.0f , 1.0f , 0.0f , 0.0f , 1.0f , 1.0f , 1.0f , 0.0f , 1.0f , 0.0f , 0.0f , 0.0f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv static Far TopologyRefiner createTopologyRefiner ------------------------------------------------------------------------------ int main int , char Generate a FarTopologyRefiner see tutorial_1_1 for details. Far TopologyRefiner refiner createTopologyRefiner Uniformly refine the topology up to maxlevel. int maxlevel 4 refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel int nverts refiner - GetLevel maxlevel . GetNumVertices Use the FarStencilTable factory to create discrete stencil table Far StencilTableFactory Options options options . generateIntermediateLevels false only the highest refinement level. options . generateOffsets true Vertex primvar data Create stencils table for vertex interpolation options . interpolationMode Far StencilTableFactory INTERPOLATE_VERTEX Far StencilTable const vertexStencils Far StencilTableFactory Create refiner , options assert nverts vertexStencils - GetNumStencils Allocate vertex primvar buffer 1 stencil for each vertex std vector Vertex vertexBuffer vertexStencils - GetNumStencils Use the cube vertex positions as vertex primvar data Vertex vertexCVs reinterpret_cast Vertex g_verts Varying primvar data Create stencils table for varying interpolation options . interpolationMode Far StencilTableFactory INTERPOLATE_VARYING Far StencilTable const varyingStencils Far StencilTableFactory Create refiner , options assert nverts varyingStencils - GetNumStencils Allocate varying primvar buffer 1 stencil for each vertex std vector Vertex varyingBuffer varyingStencils - GetNumStencils Use per-vertex array of RGB colors as varying primvar data Vertex varyingCVs reinterpret_cast Vertex g_colors delete refiner Apply stencils in frame loop This section would be applied every frame after control vertices have been moved. Apply stencils on the control vertex data to update the primvar data of the refined vertices. vertexStencils - UpdateValues vertexCVs , vertexBuffer 0 varyingStencils - UpdateValues varyingCVs , varyingBuffer 0 Visualization with Maya print a MEL script that generates particles at the location of the refined vertices printf particle for int vert 0 vert int nverts vert float const pos vertexBuffer vert . GetData printf -p f f f n , pos 0 , pos 1 , pos 2 printf -c 1 n Set particle point size 20 -- very large printf addAttr -is true -ln pointSize -at long -dv 20 particleShape1 n Add per-particle color attribute rgbPP printf addAttr -ln rgbPP -dt vectorArray particleShape1 n Set per-particle color values from our varying primvar data printf setAttr particleShape1.rgbPP -type vectorArray d , nverts for int vert 0 vert nverts vert float const color varyingBuffer vert . GetData printf f f f n , color 0 , color 1 , color 2 printf n delete vertexStencils delete varyingStencils return EXIT_SUCCESS ------------------------------------------------------------------------------ static Far TopologyRefiner createTopologyRefiner Populate a topology descriptor with our raw data. typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor. Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options return refiner ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "far_tutorial_3_1.html" │ │ │ │ │ + "loc": "far_tutorial_4_2.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "far_tutorial_4_1.cpp", │ │ │ │ │ "text": "far_tutorial_4_1.cpp far_tutorial_4_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_4_1far_tutorial_4_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to create and manipulate FarStencilTable. We use the factorized stencils to interpolate vertex primvar data buffers. include opensubdivfartopologyDescriptor.h include opensubdivfarstencilTable.h include opensubdivfarstencilTableFactory.h include cstdio include cstring ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 _position 0 _position 1 _position 2 0.0f void AddWithWeight Vertex const src , float weight _position 0 weight src . _position 0 _position 1 weight src . _position 1 _position 2 weight src . _position 2 Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z float const GetPosition const return _position private float _position 3 ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 24 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv static Far TopologyRefiner createTopologyRefiner ------------------------------------------------------------------------------ int main int , char Generate a FarTopologyRefiner see tutorial_1_1 for details. Far TopologyRefiner refiner createTopologyRefiner Uniformly refine the topology up to maxlevel. int maxlevel 3 refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Use the FarStencilTable factory to create discrete stencil table note we only want stencils for the highest refinement level. Far StencilTableFactory Options options options . generateIntermediateLevels false options . generateOffsets true Far StencilTable const stencilTable Far StencilTableFactory Create refiner , options Allocate vertex primvar buffer 1 stencil for each vertex int nstencils stencilTable - GetNumStencils std vector Vertex vertexBuffer nstencils Quick dirty re-cast of the primvar data from our cube this is where you would drive shape deformations every frame Vertex controlValues reinterpret_cast Vertex g_verts This section would be applied every frame after control vertices have been moved. Apply stencils on the control vertex data to update the primvar data of the refined vertices. stencilTable - UpdateValues controlValues , vertexBuffer 0 Visualization with Maya print a MEL script that generates particles at the location of the refined vertices printf particle for int i 0 i int vertexBuffer . size i float const pos vertexBuffer i . GetPosition printf -p f f f n , pos 0 , pos 1 , pos 2 printf -c 1 n delete refiner delete stencilTable return EXIT_SUCCESS ------------------------------------------------------------------------------ static Far TopologyRefiner createTopologyRefiner Populate a topology descriptor with our raw data. typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor. return Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "far_tutorial_4_1.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "far_tutorial_2_3.cpp", │ │ │ │ │ @@ -91,174 +86,179 @@ │ │ │ │ │ "loc": "far_tutorial_2_3.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "far_tutorial_2_2.cpp", │ │ │ │ │ "text": "far_tutorial_2_2.cpp far_tutorial_2_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_2_2far_tutorial_2_2.cpp ------------------------------------------------------------------------------ Tutorial description Building on tutorial 0, this example shows how to instantiate a simple mesh, refine it uniformly and then interpolate both vertex and face-varying primvar data. The resulting interpolated data is output as an obj file, with the face-varying data recorded in the uv texture layout. include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include cstdio ------------------------------------------------------------------------------ Face-varying implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 _position 0 _position 1 _position 2 0.0f void AddWithWeight Vertex const src , float weight _position 0 weight src . _position 0 _position 1 weight src . _position 1 _position 2 weight src . _position 2 Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 ------------------------------------------------------------------------------ Face-varying container implementation. We are using a uv texture layout as a face-varying primitive variable attribute. Because face-varying data is specified per-face-per-vertex, we cannot use the same container that we use for vertex or varying data. We specify a new container, which only carries u,v coordinates. Similarly to our Vertex container, we add a minimalistic interpolation interface with a Clear and AddWithWeight methods. struct FVarVertexUV Minimal required interface ---------------------- void Clear u v 0.0f void AddWithWeight FVarVertexUV const src , float weight u weight src . u v weight src . v Basic uv layout channel float u , v struct FVarVertexColor Minimal required interface ---------------------- void Clear r g b a 0.0f void AddWithWeight FVarVertexColor const src , float weight r weight src . r g weight src . g b weight src . b a weight src . a Basic color layout channel float r , g , b , a ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h vertex primitive variable data topology static float g_verts 8 3 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 face-varying primitive variable data topology for UVs static float g_uvs 14 2 0.375 , 0.00 , 0.625 , 0.00 , 0.375 , 0.25 , 0.625 , 0.25 , 0.375 , 0.50 , 0.625 , 0.50 , 0.375 , 0.75 , 0.625 , 0.75 , 0.375 , 1.00 , 0.625 , 1.00 , 0.875 , 0.00 , 0.875 , 0.25 , 0.125 , 0.00 , 0.125 , 0.25 static int g_nuvs 14 static int g_uvIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 9 , 8 , 1 , 10 , 11 , 3 , 12 , 0 , 2 , 13 face-varying primitive variable data topology for color static float g_colors 24 4 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 0.0 , 0.0 , 1.0 , 1.0 , 0.0 , 0.0 , 1.0 , 1.0 , 0.0 , 0.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 , 1.0 static int g_ncolors 24 static int g_colorIndices 24 0 , 3 , 9 , 6 , 7 , 10 , 15 , 12 , 13 , 16 , 21 , 18 , 19 , 22 , 4 , 1 , 5 , 23 , 17 , 11 , 20 , 2 , 8 , 14 using namespace OpenSubdiv ------------------------------------------------------------------------------ int main int , char int maxlevel 3 typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY options . SetFVarLinearInterpolation Sdc Options FVAR_LINEAR_NONE Populate a topology descriptor with our raw data Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices int channelUV 0 int channelColor 1 Create a face-varying channel descriptor Descriptor FVarChannel channels 2 channels channelUV . numValues g_nuvs channels channelUV . valueIndices g_uvIndices channels channelColor . numValues g_ncolors channels channelColor . valueIndices g_colorIndices Add the channel topology to the main descriptor desc . numFVarChannels 2 desc . fvarChannels channels Instantiate a FarTopologyRefiner from the descriptor Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options Uniformly refine the topology up to maxlevel note fullTopologyInLastLevel must be true to work with face-varying data Far TopologyRefiner UniformOptions refineOptions maxlevel refineOptions . fullTopologyInLastLevel true refiner - RefineUniform refineOptions Allocate and initialize the vertex primvar data see tutorial 2 for more details. std vector Vertex vbuffer refiner - GetNumVerticesTotal Vertex verts vbuffer 0 for int i 0 i g_nverts i verts i . SetPosition g_verts i 0 , g_verts i 1 , g_verts i 2 Allocate and initialize the first channel of face-varying primvar data UVs std vector FVarVertexUV fvBufferUV refiner - GetNumFVarValuesTotal channelUV FVarVertexUV fvVertsUV fvBufferUV 0 for int i 0 i g_nuvs i fvVertsUV i . u g_uvs i 0 fvVertsUV i . v g_uvs i 1 Allocate interpolate the face-varying primvar data colors std vector FVarVertexColor fvBufferColor refiner - GetNumFVarValuesTotal channelColor FVarVertexColor fvVertsColor fvBufferColor 0 for int i 0 i g_ncolors i fvVertsColor i . r g_colors i 0 fvVertsColor i . g g_colors i 1 fvVertsColor i . b g_colors i 2 fvVertsColor i . a g_colors i 3 Interpolate both vertex and face-varying primvar data Far PrimvarRefiner primvarRefiner refiner Vertex srcVert verts FVarVertexUV srcFVarUV fvVertsUV FVarVertexColor srcFVarColor fvVertsColor for int level 1 level maxlevel level Vertex dstVert srcVert refiner - GetLevel level -1 . GetNumVertices FVarVertexUV dstFVarUV srcFVarUV refiner - GetLevel level -1 . GetNumFVarValues channelUV FVarVertexColor dstFVarColor srcFVarColor refiner - GetLevel level -1 . GetNumFVarValues channelColor primvarRefiner . Interpolate level , srcVert , dstVert primvarRefiner . InterpolateFaceVarying level , srcFVarUV , dstFVarUV , channelUV primvarRefiner . InterpolateFaceVarying level , srcFVarColor , dstFVarColor , channelColor srcVert dstVert srcFVarUV dstFVarUV srcFVarColor dstFVarColor Output OBJ of the highest level refined ----------- Far TopologyLevel const refLastLevel refiner - GetLevel maxlevel int nverts refLastLevel . GetNumVertices int nuvs refLastLevel . GetNumFVarValues channelUV int ncolors refLastLevel . GetNumFVarValues channelColor int nfaces refLastLevel . GetNumFaces Print vertex positions int firstOfLastVerts refiner - GetNumVerticesTotal - nverts for int vert 0 vert nverts vert float const pos verts firstOfLastVerts vert . GetPosition printf v f f f n , pos 0 , pos 1 , pos 2 Print uvs int firstOfLastUvs refiner - GetNumFVarValuesTotal channelUV - nuvs for int fvvert 0 fvvert nuvs fvvert FVarVertexUV const uv fvVertsUV firstOfLastUvs fvvert printf vt f f n , uv . u , uv . v Print colors int firstOfLastColors refiner - GetNumFVarValuesTotal channelColor - ncolors for int fvvert 0 fvvert ncolors fvvert FVarVertexColor const c fvVertsColor firstOfLastColors fvvert printf c f f f f n , c . r , c . g , c . b , c . a Print faces for int face 0 face nfaces face Far ConstIndexArray fverts refLastLevel . GetFaceVertices face Far ConstIndexArray fuvs refLastLevel . GetFaceFVarValues face , channelUV all refined Catmark faces should be quads assert fverts . size 4 fuvs . size 4 printf f for int vert 0 vert fverts . size vert OBJ uses 1-based arrays... printf dd , fverts vert 1 , fuvs vert 1 printf n delete refiner return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "far_tutorial_2_2.html" │ │ │ │ │ }, { │ │ │ │ │ + "title": "far_tutorial_3_1.cpp", │ │ │ │ │ + "text": "far_tutorial_3_1.cpp far_tutorial_3_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_3_1far_tutorial_3_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to interface a high-level topology representation with Far for better efficiency. In tutorial 0, we showed how to instantiate topology from a simple face-vertex list. Here we will show how to take advantage of more complex data structures. Many client applications that manipulate geometry use advanced data structures such as half-edge, quad-edge or winged-edge in order to represent complex topological relationships beyond the usual face-vertex lists. We can take advantage of this information. Far provides an advanced interface that allows such a client application to communicate advanced component relationships directly and avoid having Far rebuilding them redundantly. include opensubdivfartopologyRefinerFactory.h include opensubdivfarprimvarRefiner.h include cstdio ------------------------------------------------------------------------------ using namespace OpenSubdiv ------------------------------------------------------------------------------ For this tutorial, we provide the complete topological representation of a simple pyramid. In our case, we store it as a simple sequence of integers, with the understanding that client-code would provide a fully implemented data-structure such as quad-edges or winged-edges. Pyramid geometry from catmark_pyramid.h - extended for this tutorial static int g_nverts 5 , g_nedges 8 , g_nfaces 5 vertex positions static float g_verts 5 3 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 2.0f , 0.0f , 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 0.0f number of vertices in each face static int g_facenverts 5 3 , 3 , 3 , 3 , 4 index of face vertices static int g_faceverts 16 0 , 1 , 2 , 0 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 4 , 3 , 2 , 1 index of edge vertices 2 per edge static int g_edgeverts 16 0 , 1 , 1 , 2 , 2 , 0 , 2 , 3 , 3 , 0 , 3 , 4 , 4 , 0 , 4 , 1 index of face edges static int g_faceedges 16 0 , 1 , 2 , 2 , 3 , 4 , 4 , 5 , 6 , 6 , 7 , 0 , 5 , 3 , 1 , 7 number of faces adjacent to each edge static int g_edgenfaces 8 2 , 2 , 2 , 2 , 2 , 2 , 2 , 2 index of faces incident to a given edge static int g_edgefaces 16 0 , 3 , 0 , 4 , 0 , 1 , 1 , 4 , 1 , 2 , 2 , 4 , 2 , 3 , 3 , 4 number of faces incident to each vertex static int g_vertexnfaces 5 4 , 3 , 3 , 3 , 3 index of faces incident to each vertex static int g_vertexfaces 25 0 , 1 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 1 , 4 , 2 , 2 , 4 , 3 number of edges incident to each vertex static int g_vertexnedges 5 4 , 3 , 3 , 3 , 3 index of edges incident to each vertex static int g_vertexedges 25 0 , 2 , 4 , 6 , 1 , 0 , 7 , 2 , 1 , 3 , 4 , 3 , 5 , 6 , 5 , 7 Edge crease sharpness static float g_edgeCreases 8 0.0f , 2.5f , 0.0f , 2.5f , 0.0f , 2.5f , 0.0f , 2.5f ------------------------------------------------------------------------------ Because existing client-code may not provide an exact match for the topological queries required by Fars interface, we can provide a converter class. This can be particularly useful for instance if the client data-structure requires additional relationships to be mapped. For instance, half-edge representations do not store unique edge indices and it can be difficult to traverse edges or faces adjacent to a given vertex. Using an intermediate wrapper class allows us to leverage existing relationships information from a mesh, and generate the missing components temporarily. For a practical example, you can look at the file hbr_to_vtr.h in the same tutorial directory. This example implements a OsdHbrConverter class as a way of interfacing PRmans half-edge representation to Far. struct Converter public Sdc SchemeType GetType const return Sdc SCHEME_CATMARK Sdc Options GetOptions const Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY return options int GetNumFaces const return g_nfaces int GetNumEdges const return g_nedges int GetNumVertices const return g_nverts Face relationships int GetNumFaceVerts int face const return g_facenverts face int const GetFaceVerts int face const return g_faceverts getCompOffset g_facenverts , face int const GetFaceEdges int face const return g_faceedges getCompOffset g_facenverts , face Edge relationships int const GetEdgeVertices int edge const return g_edgeverts edge 2 int GetNumEdgeFaces int edge const return g_edgenfaces edge int const GetEdgeFaces int edge const return g_edgefaces getCompOffset g_edgenfaces , edge Vertex relationships int GetNumVertexEdges int vert const return g_vertexnedges vert int const GetVertexEdges int vert const return g_vertexedges getCompOffset g_vertexnedges , vert int GetNumVertexFaces int vert const return g_vertexnfaces vert int const GetVertexFaces int vert const return g_vertexfaces getCompOffset g_vertexnfaces , vert private int getCompOffset int const comps , int comp const int ofs 0 for int i 0 i comp i ofs comps i return ofs ------------------------------------------------------------------------------ namespace OpenSubdiv namespace OPENSUBDIV_VERSION namespace Far template bool TopologyRefinerFactory Converter resizeComponentTopology TopologyRefiner refiner , Converter const conv Faces and face-verts int nfaces conv . GetNumFaces setNumBaseFaces refiner , nfaces for int face 0 face nfaces face int nv conv . GetNumFaceVerts face setNumBaseFaceVertices refiner , face , nv Edges and edge-faces int nedges conv . GetNumEdges setNumBaseEdges refiner , nedges for int edge 0 edge nedges edge int nf conv . GetNumEdgeFaces edge setNumBaseEdgeFaces refiner , edge , nf Vertices and vert-faces and vert-edges int nverts conv . GetNumVertices setNumBaseVertices refiner , nverts for int vert 0 vert nverts vert int ne conv . GetNumVertexEdges vert , nf conv . GetNumVertexFaces vert setNumBaseVertexEdges refiner , vert , ne setNumBaseVertexFaces refiner , vert , nf return true template bool TopologyRefinerFactory Converter assignComponentTopology TopologyRefiner refiner , Converter const conv using Far IndexArray Face relations int nfaces conv . GetNumFaces for int face 0 face nfaces face IndexArray dstFaceVerts getBaseFaceVertices refiner , face IndexArray dstFaceEdges getBaseFaceEdges refiner , face int const faceverts conv . GetFaceVerts face int const faceedges conv . GetFaceEdges face for int vert 0 vert conv . GetNumFaceVerts face vert dstFaceVerts vert faceverts vert dstFaceEdges vert faceedges vert Edge relations Note if your representation is unable to provide edge relationships ex half-edges, you can comment out this section and Far will automatically generate the missing information. int nedges conv . GetNumEdges for int edge 0 edge nedges edge Edge-vertices IndexArray dstEdgeVerts getBaseEdgeVertices refiner , edge dstEdgeVerts 0 conv . GetEdgeVertices edge 0 dstEdgeVerts 1 conv . GetEdgeVertices edge 1 Edge-faces IndexArray dstEdgeFaces getBaseEdgeFaces refiner , edge for int face 0 face conv . GetNumEdgeFaces face face dstEdgeFaces face conv . GetEdgeFaces edge face Vertex relations int nverts conv . GetNumVertices for int vert 0 vert nverts vert Vert-Faces IndexArray vertFaces getBaseVertexFaces refiner , vert LocalIndexArray vertInFaceIndices getBaseVertexFaceLocalIndicesrefiner, vert for int face 0 face conv . GetNumVertexFaces vert face vertFaces face conv . GetVertexFaces vert face Vert-Edges IndexArray vertEdges getBaseVertexEdges refiner , vert LocalIndexArray vertInEdgeIndices getBaseVertexEdgeLocalIndicesrefiner, vert for int edge 0 edge conv . GetNumVertexEdges vert edge vertEdges edge conv . GetVertexEdges vert edge populateBaseLocalIndices refiner return true template bool TopologyRefinerFactory Converter assignComponentTags TopologyRefiner refiner , Converter const conv arbitrarily sharpen the 4 bottom edges of the pyramid to 2.5f for int edge 0 edge conv . GetNumEdges edge setBaseEdgeSharpness refiner , edge , g_edgeCreases edge return true ifdef _MSC_VER template void TopologyRefinerFactory Converter reportInvalidTopology TopologyError errCode , char const msg , Converter const mesh Optional topology validation error reporting This method is called whenever the factory encounters topology validation errors. By default, nothing is reported Warning msg template bool TopologyRefinerFactory Converter assignFaceVaryingTopology TopologyRefiner refiner , Converter const conv Because of the way MSVC specializes templated functions, we had to remove the default stubs in FarTopologyRefinerFactory. In this example, no face-varying data is being added, but we still need to implement a template specialization or MSVC linker fails. return true endif namespace Far namespace OPENSUBDIV_VERSION namespace OpenSubdiv ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 _position 0 _position 1 _position 2 0.0f void AddWithWeight Vertex const src , float weight _position 0 weight src . _position 0 _position 1 weight src . _position 1 _position 2 weight src . _position 2 Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 ------------------------------------------------------------------------------ int main int , char Converter conv Far TopologyRefiner refiner Far TopologyRefinerFactory Converter Create conv , Far TopologyRefinerFactory Converter Options conv . GetType , conv . GetOptions int maxlevel 5 Uniformly refine the topology up to maxlevel refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Allocate a buffer for vertex primvar data. The buffer length is set to be the sum of all children vertices up to the highest level of refinement. std vector Vertex vbuffer refiner - GetNumVerticesTotal Vertex verts vbuffer 0 Initialize coarse mesh positions int nCoarseVerts g_nverts for int i 0 i nCoarseVerts i verts i . SetPosition g_verts i 0 , g_verts i 1 , g_verts i 2 Interpolate vertex primvar data Far PrimvarRefiner primvarRefiner refiner Vertex src verts for int level 1 level maxlevel level Vertex dst src refiner - GetLevel level -1 . GetNumVertices primvarRefiner . Interpolate level , src , dst src dst Output OBJ of the highest level refined ----------- Far TopologyLevel const refLastLevel refiner - GetLevel maxlevel int nverts refLastLevel . GetNumVertices int nfaces refLastLevel . GetNumFaces Print vertex positions int firstOfLastVerts refiner - GetNumVerticesTotal - nverts for int vert 0 vert nverts vert float const pos verts firstOfLastVerts vert . GetPosition printf v f f f n , pos 0 , pos 1 , pos 2 Print faces for int face 0 face nfaces face Far ConstIndexArray fverts refLastLevel . GetFaceVertices face all refined Catmark faces should be quads assert fverts . size 4 printf f for int vert 0 vert fverts . size vert printf d , fverts vert 1 OBJ uses 1-based arrays... printf n delete refiner return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "far_tutorial_3_1.html" │ │ │ │ │ + }, { │ │ │ │ │ "title": "far_tutorial_2_1.cpp", │ │ │ │ │ "text": "far_tutorial_2_1.cpp far_tutorial_2_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_2_1far_tutorial_2_1.cpp ------------------------------------------------------------------------------ Tutorial description Building on tutorial 0, this example shows how to instantiate a simple mesh, refine it uniformly and then interpolate additional sets of primvar data. include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include cstdio ------------------------------------------------------------------------------ Vertex container implementation. We are adding a per-vertex color attribute to our primvar data. While they are separate properties and exist in separate buffers as when read from an Alembic file they are both of the form float3 and so we can use the same underlying type. While color and position may be the same, well make the color a varying primvar, e.g. it is constrained to being linearly interpolated between vertices, rather than smoothly like position and other vertex data. struct Point3 Minimal required interface ---------------------- Point3 void Clear void 0 _point 0 _point 1 _point 2 0.0f void AddWithWeight Point3 const src , float weight _point 0 weight src . _point 0 _point 1 weight src . _point 1 _point 2 weight src . _point 2 Public interface ------------------------------------ void SetPoint float x , float y , float z _point 0 x _point 1 y _point 2 z const float GetPoint const return _point private float _point 3 typedef Point3 VertexPosition typedef Point3 VertexColor ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 8 3 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f Per-vertex RGB color data static float g_colors 8 3 1.0f , 0.0f , 0.5f , 0.0f , 1.0f , 0.0f , 0.0f , 0.0f , 1.0f , 1.0f , 1.0f , 1.0f , 1.0f , 1.0f , 0.0f , 0.0f , 1.0f , 1.0f , 1.0f , 0.0f , 1.0f , 0.0f , 0.0f , 0.0f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv static Far TopologyRefiner createFarTopologyRefiner ------------------------------------------------------------------------------ int main int , char int maxlevel 5 Far TopologyRefiner refiner createFarTopologyRefiner Uniformly refine the topology up to maxlevel refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Allocate buffers for vertex primvar data. We assume we received the coarse data for the mesh in separate buffers from some other source, e.g. an Alembic file. Meanwhile, we want buffers for the lastfinest subdivision level to persist. We have no interest in the intermediate levels. Determine the sizes for our needs int nCoarseVerts g_nverts int nFineVerts refiner - GetLevel maxlevel . GetNumVertices int nTotalVerts refiner - GetNumVerticesTotal int nTempVerts nTotalVerts - nCoarseVerts - nFineVerts Allocate and initialize the primvar data for the original coarse vertices std vector VertexPosition coarsePosBuffer nCoarseVerts std vector VertexColor coarseClrBuffer nCoarseVerts for int i 0 i nCoarseVerts i coarsePosBuffer i . SetPoint g_verts i 0 , g_verts i 1 , g_verts i 2 coarseClrBuffer i . SetPoint g_colors i 0 , g_colors i 1 , g_colors i 2 Allocate intermediate and final storage to be populated std vector VertexPosition tempPosBuffer nTempVerts std vector VertexPosition finePosBuffer nFineVerts std vector VertexColor tempClrBuffer nTempVerts std vector VertexColor fineClrBuffer nFineVerts Interpolate all primvar data -- separate buffers can be populated on separate threads if desired VertexPosition srcPos coarsePosBuffer 0 VertexPosition dstPos tempPosBuffer 0 VertexColor srcClr coarseClrBuffer 0 VertexColor dstClr tempClrBuffer 0 Far PrimvarRefiner primvarRefiner refiner for int level 1 level maxlevel level primvarRefiner . Interpolate level , srcPos , dstPos primvarRefiner . InterpolateVarying level , srcClr , dstClr srcPos dstPos , dstPos refiner - GetLevel level . GetNumVertices srcClr dstClr , dstClr refiner - GetLevel level . GetNumVertices Interpolate the last level into the separate buffers for our final data primvarRefiner . Interpolate maxlevel , srcPos , finePosBuffer primvarRefiner . InterpolateVarying maxlevel , srcClr , fineClrBuffer Visualization with Maya print a MEL script that generates colored particles at the location of the refined vertices dont forget to turn shading on in the viewport to see the colors int nverts nFineVerts Output particle positions printf particle for int vert 0 vert nverts vert float const pos finePosBuffer vert . GetPoint printf -p f f f n , pos 0 , pos 1 , pos 2 printf n Set particle point size 20 -- very large printf addAttr -is true -ln pointSize -at long -dv 20 particleShape1 n Add per-particle color attribute rgbPP printf addAttr -ln rgbPP -dt vectorArray particleShape1 n Set per-particle color values from our primvar data printf setAttr particleShape1.rgbPP -type vectorArray d , nverts for int vert 0 vert nverts vert float const color fineClrBuffer vert . GetPoint printf f f f n , color 0 , color 1 , color 2 printf n delete refiner return EXIT_SUCCESS ------------------------------------------------------------------------------ Creates FarTopologyRefiner from raw geometry see tutorial_1_1 for more details static Far TopologyRefiner createFarTopologyRefiner Populate a topology descriptor with our raw data typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options return refiner ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "far_tutorial_2_1.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "far_tutorial_1_2.cpp", │ │ │ │ │ - "text": "far_tutorial_1_2.cpp far_tutorial_1_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_1_2far_tutorial_1_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial illustrates two different styles of defining classes for interpolating primvar data with the template methods in Far. The most common usage involves data of a fixed size, so the focus here is on an alternative supporting variable length data. include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include cstdio using namespace OpenSubdiv Vertex data containers for interpolation - Coord3 is fixed to support 3 floats - Coord2 is fixed to support 2 floats - CoordBuffer can support a specified number of floats struct Coord3 Coord3 Coord3 float x , float y , float z _xyz 0 x , _xyz 1 y , _xyz 2 z void Clear _xyz 0 _xyz 1 _xyz 2 0.0f void AddWithWeight Coord3 const src , float weight _xyz 0 weight src . _xyz 0 _xyz 1 weight src . _xyz 1 _xyz 2 weight src . _xyz 2 float const Coords const return _xyz 0 private float _xyz 3 struct Coord2 Coord2 Coord2 float u , float v _uv 0 u , _uv 1 v void Clear _uv 0 _uv 1 0.0f void AddWithWeight Coord2 const src , float weight _uv 0 weight src . _uv 0 _uv 1 weight src . _uv 1 float const Coords const return _uv 0 private float _uv 2 struct CoordBuffer The head of an external buffer and stride is specified on construction CoordBuffer float data , int size _data data , _size size CoordBuffer _data 0 , _size 0 void Clear for int i 0 i _size i _data i 0.0f void AddWithWeight CoordBuffer const src , float weight assert src . _size _size for int i 0 i _size i _data i weight src . _data i float const Coords const return _data Defining to return a location elsewhere in the buffer is the key requirement to supporting interpolatible data of varying size CoordBuffer operator int index const return CoordBuffer _data index _size , _size private float _data int _size Global cube geometry from catmark_cube.h Topology static int g_nverts 8 static int g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 Primvar data static float g_verts 8 3 0.0f , 0.0f , 1.0f , 1.0f , 0.0f , 1.0f , 0.0f , 1.0f , 1.0f , 1.0f , 1.0f , 1.0f , 0.0f , 1.0f , 0.0f , 1.0f , 1.0f , 0.0f , 0.0f , 0.0f , 0.0f , 1.0f , 0.0f , 0.0f Creates FarTopologyRefiner from raw geometry above see tutorial_1_1 for more details static Far TopologyRefiner createFarTopologyRefiner typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options return refiner Overview of main - create a FarTopologyRefiner and uniformly refine it - allocate separate and combined data buffers for vertex positions and UVs - populate all refined data buffers and compare results - write the result in Obj format Disable warnings for exact floating point comparisons ifdef __INTEL_COMPILER pragma warning disable 1572 endif int main int , char Instantiate a FarTopologyRefiner from the global geometry Far TopologyRefiner refiner createFarTopologyRefiner Uniformly refine the topology up to maxlevel int maxlevel 2 refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Allocate and populate data buffers for vertex primvar data -- positions and UVs. We assign UV coordiantes by simply projectingassigning XY values. The position and UV buffers use their associated data types, while the combined buffer uses 5 floats per vertex. int numBaseVertices g_nverts int numTotalVertices refiner - GetNumVerticesTotal std vector Coord3 posData numTotalVertices std vector Coord2 uvData numTotalVertices int combinedStride 3 2 std vector float combinedData numTotalVertices combinedStride for int i 0 i numBaseVertices i posData i Coord3 g_verts i 0 , g_verts i 1 , g_verts i 2 uvData i Coord2 g_verts i 0 , g_verts i 1 float coordCombined combinedData i combinedStride coordCombined 0 g_verts i 0 coordCombined 1 g_verts i 1 coordCombined 2 g_verts i 2 coordCombined 3 g_verts i 0 coordCombined 4 g_verts i 1 Interpolate vertex primvar data Far PrimvarRefiner primvarRefiner refiner Coord3 posSrc posData 0 Coord2 uvSrc uvData 0 CoordBuffer combinedSrc combinedData 0 , combinedStride for int level 1 level maxlevel level int numLevelVerts refiner - GetLevel level -1 . GetNumVertices Coord3 posDst posSrc numLevelVerts Coord2 uvDst uvSrc numLevelVerts CoordBuffer combinedDst combinedSrc numLevelVerts primvarRefiner . Interpolate level , posSrc , posDst primvarRefiner . Interpolate level , uvSrc , uvDst primvarRefiner . Interpolate level , combinedSrc , combinedDst posSrc posDst uvSrc uvDst combinedSrc combinedDst Verify that the combined coords match the separate results for int i numBaseVertices i numTotalVertices i float const posCoords posData i . Coords float const uvCoords uvData i . Coords float const combCoords combinedData combinedStride i assert combCoords 0 posCoords 0 assert combCoords 1 posCoords 1 assert combCoords 2 posCoords 2 assert combCoords 3 uvCoords 0 assert combCoords 4 uvCoords 1 Output OBJ of the highest level refined Far TopologyLevel const refLastLevel refiner - GetLevel maxlevel int firstOfLastVerts numTotalVertices - refLastLevel . GetNumVertices Print vertex positions printf Vertices n for int vert firstOfLastVerts vert numTotalVertices vert float const pos combinedData vert combinedStride printf v f f f n , pos 0 , pos 1 , pos 2 printf UV coordinates n for int vert firstOfLastVerts vert numTotalVertices vert float const uv combinedData vert combinedStride 3 printf vt f f n , uv 0 , uv 1 Print faces int numFaces refLastLevel . GetNumFaces printf Faces n for int face 0 face numFaces face Far ConstIndexArray fverts refLastLevel . GetFaceVertices face printf f for int fvert 0 fvert fverts . size fvert int objIndex 1 fverts fvert OBJ uses 1-based arrays... printf dd , objIndex , objIndex printf n delete refiner return EXIT_SUCCESS Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "far_tutorial_1_1.cpp", │ │ │ │ │ + "text": "far_tutorial_1_1.cpp far_tutorial_1_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_1_1far_tutorial_1_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial presents in a very succinct way the requisite steps to instantiate and refine a mesh with Far from simple topological data. include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include cstdio ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 _position 0 _position 1 _position 2 0.0f void AddWithWeight Vertex const src , float weight _position 0 weight src . _position 0 _position 1 weight src . _position 1 _position 2 weight src . _position 2 Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 8 3 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv ------------------------------------------------------------------------------ int main int , char Populate a topology descriptor with our raw data typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options int maxlevel 2 Uniformly refine the topology up to maxlevel refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Allocate a buffer for vertex primvar data. The buffer length is set to be the sum of all children vertices up to the highest level of refinement. std vector Vertex vbuffer refiner - GetNumVerticesTotal Vertex verts vbuffer 0 Initialize coarse mesh positions int nCoarseVerts g_nverts for int i 0 i nCoarseVerts i verts i . SetPosition g_verts i 0 , g_verts i 1 , g_verts i 2 Interpolate vertex primvar data Far PrimvarRefiner primvarRefiner refiner Vertex src verts for int level 1 level maxlevel level Vertex dst src refiner - GetLevel level -1 . GetNumVertices primvarRefiner . Interpolate level , src , dst src dst Output OBJ of the highest level refined ----------- Far TopologyLevel const refLastLevel refiner - GetLevel maxlevel int nverts refLastLevel . GetNumVertices int nfaces refLastLevel . GetNumFaces Print vertex positions int firstOfLastVerts refiner - GetNumVerticesTotal - nverts for int vert 0 vert nverts vert float const pos verts firstOfLastVerts vert . GetPosition printf v f f f n , pos 0 , pos 1 , pos 2 Print faces for int face 0 face nfaces face Far ConstIndexArray fverts refLastLevel . GetFaceVertices face all refined Catmark faces should be quads assert fverts . size 4 printf f for int vert 0 vert fverts . size vert printf d , fverts vert 1 OBJ uses 1-based arrays... printf n delete refiner return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "far_tutorial_1_2.html" │ │ │ │ │ + "loc": "far_tutorial_1_1.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "hbr_tutorial_2.cpp", │ │ │ │ │ "text": "hbr_tutorial_2.cpp hbr_tutorial_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialshbrtutorial_2hbr_tutorial_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to subdivide uniformly a simple Hbr mesh. We are building upon previous tutorials and assuming a fully instantiated mesh we start with an HbrMesh pointer initialized from the same pyramid shape used in hbr_tutorial_0. We then apply the Refine function sequentially to all the faces in the mesh to generate several levels of uniform subdivision. The resulting data is then dumped to the terminal in Wavefront OBJ format for inspection. include opensubdivhbrmesh.h include opensubdivhbrcatmark.h include cassert include cstdio ------------------------------------------------------------------------------ For this tutorial, we have to flesh out the Vertex class further. Note that now the copy constructor, Clear and AddwithWeight methods have been implemented to interpolate our float3 position data. This vertex specialization pattern leaves client-code free to implement arbitrary vertex primvar data schemes or none at all to conserve efficiency struct Vertex Hbr minimal required interface ---------------------- Vertex Vertex int i Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 _position 0 _position 1 _position 2 0.0f void AddWithWeight Vertex const src , float weight _position 0 weight src . _position 0 _position 1 weight src . _position 1 _position 2 weight src . _position 2 void AddVaryingWithWeight Vertex const , float Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 typedef OpenSubdiv HbrMesh Vertex Hmesh typedef OpenSubdiv HbrFace Vertex Hface typedef OpenSubdiv HbrVertex Vertex Hvertex typedef OpenSubdiv HbrHalfedge Vertex Hhalfedge Hmesh createMesh ------------------------------------------------------------------------------ int main int , char Hmesh hmesh createMesh int maxlevel 2 , 2 levels of subdivision firstface 0 , marker to the first face index of level 2 firstvertex 0 marker to the first vertex index of level 2 Refine the mesh to maxlevel for int level 0 level maxlevel level Total number of faces in the mesh, across all levels Note this function iterates over the list of faces and can be slow int nfaces hmesh - GetNumFaces if level maxlevel -1 Save our vertex marker firstvertex hmesh - GetNumVertices Iterate over the faces of the current level of subdivision for int face firstface face nfaces face Hface f hmesh - GetFace face Note hole tags would have to be dealt with here. f - Refine Save our face index marker for the next level firstface nfaces Output OBJ of the highest level refined ----------- Print vertex positions int nverts hmesh - GetNumVertices for int vert firstvertex vert nverts vert float const pos hmesh - GetVertex vert - GetData . GetPosition printf v f f f n , pos 0 , pos 1 , pos 2 Print faces for int face firstface face hmesh - GetNumFaces face Hface f hmesh - GetFace face assert f - GetNumVertices 4 printf f for int vert 0 vert 4 vert OBJ uses 1-based arrays printf d , f - GetVertex vert - GetID - firstvertex 1 printf n ------------------------------------------------------------------------------ Creates an Hbr mesh see hbr_tutorial_0 and hbr_tutorial_1 for more details Hmesh createMesh Pyramid geometry from catmark_pyramid.h static float verts 5 3 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 2.0f , 0.0f , 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 0.0f static int nverts 5 , nfaces 5 static int facenverts 5 3 , 3 , 3 , 3 , 4 static int faceverts 16 0 , 1 , 2 , 0 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 4 , 3 , 2 , 1 OpenSubdiv HbrCatmarkSubdivision Vertex catmark new OpenSubdiv HbrCatmarkSubdivision Vertex Hmesh hmesh new Hmesh catmark Populate the vertices Vertex v for int i 0 i nverts i v . SetPosition verts i 0 , verts i 1 , verts i 2 hmesh - NewVertex i , v Create the topology int fv faceverts for int i 0 i nfaces i int nv facenverts i bool valid true for int j 0 j nv j Hvertex const origin hmesh - GetVertex fv j , destination hmesh - GetVertex fv j 1 nv Hhalfedge const opposite destination - GetEdge origin Make sure that the vertices exist in the mesh if origin NULL destination NULL printf An edge was specified that connected a nonexistent vertex n valid false break Check for a degenerate edge if origin destination printf An edge was specified that connected a vertex to itself n valid false break Check that no more than 2 faces are adjacent to the edge if opposite opposite - GetOpposite printf A non-manifold edge incident to more than 2 faces was found n valid false break Check that the edge is unique and oriented properly if origin - GetEdge destination printf An edge connecting two vertices was specified more than once. Its likely that an incident face was flipped n valid false break if valid hmesh - NewFace nv , fv , 0 else printf Skipped face d n , i fv nv hmesh - SetInterpolateBoundaryMethod Hmesh k_InterpolateBoundaryEdgeOnly hmesh - Finish return hmesh ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "hbr_tutorial_2.html" │ │ │ │ │ }, { │ │ │ │ │ + "title": "far_tutorial_1_2.cpp", │ │ │ │ │ + "text": "far_tutorial_1_2.cpp far_tutorial_1_2.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_1_2far_tutorial_1_2.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial illustrates two different styles of defining classes for interpolating primvar data with the template methods in Far. The most common usage involves data of a fixed size, so the focus here is on an alternative supporting variable length data. include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include cstdio using namespace OpenSubdiv Vertex data containers for interpolation - Coord3 is fixed to support 3 floats - Coord2 is fixed to support 2 floats - CoordBuffer can support a specified number of floats struct Coord3 Coord3 Coord3 float x , float y , float z _xyz 0 x , _xyz 1 y , _xyz 2 z void Clear _xyz 0 _xyz 1 _xyz 2 0.0f void AddWithWeight Coord3 const src , float weight _xyz 0 weight src . _xyz 0 _xyz 1 weight src . _xyz 1 _xyz 2 weight src . _xyz 2 float const Coords const return _xyz 0 private float _xyz 3 struct Coord2 Coord2 Coord2 float u , float v _uv 0 u , _uv 1 v void Clear _uv 0 _uv 1 0.0f void AddWithWeight Coord2 const src , float weight _uv 0 weight src . _uv 0 _uv 1 weight src . _uv 1 float const Coords const return _uv 0 private float _uv 2 struct CoordBuffer The head of an external buffer and stride is specified on construction CoordBuffer float data , int size _data data , _size size CoordBuffer _data 0 , _size 0 void Clear for int i 0 i _size i _data i 0.0f void AddWithWeight CoordBuffer const src , float weight assert src . _size _size for int i 0 i _size i _data i weight src . _data i float const Coords const return _data Defining to return a location elsewhere in the buffer is the key requirement to supporting interpolatible data of varying size CoordBuffer operator int index const return CoordBuffer _data index _size , _size private float _data int _size Global cube geometry from catmark_cube.h Topology static int g_nverts 8 static int g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 Primvar data static float g_verts 8 3 0.0f , 0.0f , 1.0f , 1.0f , 0.0f , 1.0f , 0.0f , 1.0f , 1.0f , 1.0f , 1.0f , 1.0f , 0.0f , 1.0f , 0.0f , 1.0f , 1.0f , 0.0f , 0.0f , 0.0f , 0.0f , 1.0f , 0.0f , 0.0f Creates FarTopologyRefiner from raw geometry above see tutorial_1_1 for more details static Far TopologyRefiner createFarTopologyRefiner typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options return refiner Overview of main - create a FarTopologyRefiner and uniformly refine it - allocate separate and combined data buffers for vertex positions and UVs - populate all refined data buffers and compare results - write the result in Obj format Disable warnings for exact floating point comparisons ifdef __INTEL_COMPILER pragma warning disable 1572 endif int main int , char Instantiate a FarTopologyRefiner from the global geometry Far TopologyRefiner refiner createFarTopologyRefiner Uniformly refine the topology up to maxlevel int maxlevel 2 refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Allocate and populate data buffers for vertex primvar data -- positions and UVs. We assign UV coordiantes by simply projectingassigning XY values. The position and UV buffers use their associated data types, while the combined buffer uses 5 floats per vertex. int numBaseVertices g_nverts int numTotalVertices refiner - GetNumVerticesTotal std vector Coord3 posData numTotalVertices std vector Coord2 uvData numTotalVertices int combinedStride 3 2 std vector float combinedData numTotalVertices combinedStride for int i 0 i numBaseVertices i posData i Coord3 g_verts i 0 , g_verts i 1 , g_verts i 2 uvData i Coord2 g_verts i 0 , g_verts i 1 float coordCombined combinedData i combinedStride coordCombined 0 g_verts i 0 coordCombined 1 g_verts i 1 coordCombined 2 g_verts i 2 coordCombined 3 g_verts i 0 coordCombined 4 g_verts i 1 Interpolate vertex primvar data Far PrimvarRefiner primvarRefiner refiner Coord3 posSrc posData 0 Coord2 uvSrc uvData 0 CoordBuffer combinedSrc combinedData 0 , combinedStride for int level 1 level maxlevel level int numLevelVerts refiner - GetLevel level -1 . GetNumVertices Coord3 posDst posSrc numLevelVerts Coord2 uvDst uvSrc numLevelVerts CoordBuffer combinedDst combinedSrc numLevelVerts primvarRefiner . Interpolate level , posSrc , posDst primvarRefiner . Interpolate level , uvSrc , uvDst primvarRefiner . Interpolate level , combinedSrc , combinedDst posSrc posDst uvSrc uvDst combinedSrc combinedDst Verify that the combined coords match the separate results for int i numBaseVertices i numTotalVertices i float const posCoords posData i . Coords float const uvCoords uvData i . Coords float const combCoords combinedData combinedStride i assert combCoords 0 posCoords 0 assert combCoords 1 posCoords 1 assert combCoords 2 posCoords 2 assert combCoords 3 uvCoords 0 assert combCoords 4 uvCoords 1 Output OBJ of the highest level refined Far TopologyLevel const refLastLevel refiner - GetLevel maxlevel int firstOfLastVerts numTotalVertices - refLastLevel . GetNumVertices Print vertex positions printf Vertices n for int vert firstOfLastVerts vert numTotalVertices vert float const pos combinedData vert combinedStride printf v f f f n , pos 0 , pos 1 , pos 2 printf UV coordinates n for int vert firstOfLastVerts vert numTotalVertices vert float const uv combinedData vert combinedStride 3 printf vt f f n , uv 0 , uv 1 Print faces int numFaces refLastLevel . GetNumFaces printf Faces n for int face 0 face numFaces face Far ConstIndexArray fverts refLastLevel . GetFaceVertices face printf f for int fvert 0 fvert fverts . size fvert int objIndex 1 fverts fvert OBJ uses 1-based arrays... printf dd , objIndex , objIndex printf n delete refiner return EXIT_SUCCESS Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "far_tutorial_1_2.html" │ │ │ │ │ + }, { │ │ │ │ │ "title": "hbr_tutorial_1.cpp", │ │ │ │ │ "text": "hbr_tutorial_1.cpp hbr_tutorial_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialshbrtutorial_1hbr_tutorial_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial shows how to safely create Hbr meshes from arbitrary topology. Because Hbr is a half-edge data structure, it cannot represent non-manifold topology. Ensuring that the geometry used is manifold is a requirement to use Hbr safely. This tutorial presents some simple tests to detect inappropriate topology. include opensubdivhbrmesh.h include opensubdivhbrcatmark.h include cstdio ------------------------------------------------------------------------------ struct Vertex Hbr minimal required interface ---------------------- Vertex Vertex int i Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 void AddWithWeight Vertex const , float void AddVaryingWithWeight Vertex const , float Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 typedef OpenSubdiv HbrMesh Vertex Hmesh typedef OpenSubdiv HbrFace Vertex Hface typedef OpenSubdiv HbrVertex Vertex Hvertex typedef OpenSubdiv HbrHalfedge Vertex Hhalfedge ------------------------------------------------------------------------------ Non-manifold geometry from catmark_fan.h o o f2 o------------o------------o f0 f1 o------------ o------------o The shared edge of a fan is adjacent to 3 faces, and therefore non-manifold. static float verts 8 3 -1.0 , 0.0 , -1.0 , -1.0 , 0.0 , 0.0 , 0.0 , 0.0 , 0.0 , 0.0 , 0.0 , -1.0 , 1.0 , 0.0 , 0.0 , 1.0 , 0.0 , -1.0 , 0.0 , 1.0 , 0.0 , 0.0 , 1.0 , -1.0 static int nverts 8 , nfaces 3 static int facenverts 3 4 , 4 , 4 static int faceverts 12 0 , 1 , 2 , 3 , 3 , 2 , 4 , 5 , 3 , 2 , 6 , 7 ------------------------------------------------------------------------------ int main int , char OpenSubdiv HbrCatmarkSubdivision Vertex catmark new OpenSubdiv HbrCatmarkSubdivision Vertex Hmesh hmesh new Hmesh catmark Vertex v for int i 0 i nverts i v . SetPosition verts i 0 , verts i 1 , verts i 2 hmesh - NewVertex i , v Create the topology int fv faceverts for int i 0 i nfaces i int nv facenverts i bool valid true for int j 0 j nv j Hvertex const origin hmesh - GetVertex fv j , destination hmesh - GetVertex fv j 1 nv Hhalfedge const opposite destination - GetEdge origin Make sure that the vertices exist in the mesh if origin NULL destination NULL printf An edge was specified that connected a nonexistent vertex n valid false break Check for a degenerate edge if origin destination printf An edge was specified that connected a vertex to itself n valid false break Check that no more than 2 faces are adjacent to the edge if opposite opposite - GetOpposite printf A non-manifold edge incident to more than 2 faces was found n valid false break Check that the edge is unique and oriented properly if origin - GetEdge destination printf An edge connecting two vertices was specified more than once. Its likely that an incident face was flipped n valid false break if valid hmesh - NewFace nv , fv , 0 else printf Skipped face d n , i fv nv hmesh - SetInterpolateBoundaryMethod Hmesh k_InterpolateBoundaryEdgeOnly hmesh - Finish printf Created a fan with d faces and d vertices. n , hmesh - GetNumFaces , hmesh - GetNumVertices delete hmesh delete catmark ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "hbr_tutorial_1.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "far_tutorial_1_1.cpp", │ │ │ │ │ - "text": "far_tutorial_1_1.cpp far_tutorial_1_1.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialsfartutorial_1_1far_tutorial_1_1.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial presents in a very succinct way the requisite steps to instantiate and refine a mesh with Far from simple topological data. include opensubdivfartopologyDescriptor.h include opensubdivfarprimvarRefiner.h include cstdio ------------------------------------------------------------------------------ Vertex container implementation. struct Vertex Minimal required interface ---------------------- Vertex Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 _position 0 _position 1 _position 2 0.0f void AddWithWeight Vertex const src , float weight _position 0 weight src . _position 0 _position 1 weight src . _position 1 _position 2 weight src . _position 2 Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 ------------------------------------------------------------------------------ Cube geometry from catmark_cube.h static float g_verts 8 3 -0.5f , -0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , 0.5f , 0.5f , 0.5f , -0.5f , 0.5f , -0.5f , 0.5f , 0.5f , -0.5f , -0.5f , -0.5f , -0.5f , 0.5f , -0.5f , -0.5f static int g_nverts 8 , g_nfaces 6 static int g_vertsperface 6 4 , 4 , 4 , 4 , 4 , 4 static int g_vertIndices 24 0 , 1 , 3 , 2 , 2 , 3 , 5 , 4 , 4 , 5 , 7 , 6 , 6 , 7 , 1 , 0 , 1 , 7 , 5 , 3 , 6 , 0 , 2 , 4 using namespace OpenSubdiv ------------------------------------------------------------------------------ int main int , char Populate a topology descriptor with our raw data typedef Far TopologyDescriptor Descriptor Sdc SchemeType type OpenSubdiv Sdc SCHEME_CATMARK Sdc Options options options . SetVtxBoundaryInterpolation Sdc Options VTX_BOUNDARY_EDGE_ONLY Descriptor desc desc . numVertices g_nverts desc . numFaces g_nfaces desc . numVertsPerFace g_vertsperface desc . vertIndicesPerFace g_vertIndices Instantiate a FarTopologyRefiner from the descriptor Far TopologyRefiner refiner Far TopologyRefinerFactory Descriptor Create desc , Far TopologyRefinerFactory Descriptor Options type , options int maxlevel 2 Uniformly refine the topology up to maxlevel refiner - RefineUniform Far TopologyRefiner UniformOptions maxlevel Allocate a buffer for vertex primvar data. The buffer length is set to be the sum of all children vertices up to the highest level of refinement. std vector Vertex vbuffer refiner - GetNumVerticesTotal Vertex verts vbuffer 0 Initialize coarse mesh positions int nCoarseVerts g_nverts for int i 0 i nCoarseVerts i verts i . SetPosition g_verts i 0 , g_verts i 1 , g_verts i 2 Interpolate vertex primvar data Far PrimvarRefiner primvarRefiner refiner Vertex src verts for int level 1 level maxlevel level Vertex dst src refiner - GetLevel level -1 . GetNumVertices primvarRefiner . Interpolate level , src , dst src dst Output OBJ of the highest level refined ----------- Far TopologyLevel const refLastLevel refiner - GetLevel maxlevel int nverts refLastLevel . GetNumVertices int nfaces refLastLevel . GetNumFaces Print vertex positions int firstOfLastVerts refiner - GetNumVerticesTotal - nverts for int vert 0 vert nverts vert float const pos verts firstOfLastVerts vert . GetPosition printf v f f f n , pos 0 , pos 1 , pos 2 Print faces for int face 0 face nfaces face Far ConstIndexArray fverts refLastLevel . GetFaceVertices face all refined Catmark faces should be quads assert fverts . size 4 printf f for int vert 0 vert fverts . size vert printf d , fverts vert 1 OBJ uses 1-based arrays... printf n delete refiner return EXIT_SUCCESS ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "hbr_tutorial_0.cpp", │ │ │ │ │ + "text": "hbr_tutorial_0.cpp hbr_tutorial_0.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialshbrtutorial_0hbr_tutorial_0.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial presents in a very succinct way the requisite steps to instantiate an Hbr mesh from simple topological data. include opensubdivhbrmesh.h include opensubdivhbrcatmark.h include cstdio ------------------------------------------------------------------------------ Vertex container implementation. The HbrMeshT class is a templated interface that expects a vertex class to perform interpolation on arbitrary vertex data. For the template specialization of the HbrMesh interface to be met, our Vertex object to implement a minimal set of constructors and member functions. Since we are not going to subdivide the mesh, the struct presented here has been left minimalistic. The only customization added to our container was to provide storage and accessors for the position of a 3D vertex. struct Vertex Hbr minimal required interface ---------------------- Vertex Vertex int i Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 void AddWithWeight Vertex const , float void AddVaryingWithWeight Vertex const , float Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 typedef OpenSubdiv HbrMesh Vertex Hmesh typedef OpenSubdiv HbrFace Vertex Hface typedef OpenSubdiv HbrVertex Vertex Hvertex typedef OpenSubdiv HbrHalfedge Vertex Hhalfedge ------------------------------------------------------------------------------ Pyramid geometry from catmark_pyramid.h static float verts 5 3 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 2.0f , 0.0f , 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 0.0f static int nverts 5 , nfaces 5 static int facenverts 5 3 , 3 , 3 , 3 , 4 static int faceverts 16 0 , 1 , 2 , 0 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 4 , 3 , 2 , 1 ------------------------------------------------------------------------------ int main int , char Create a subdivision scheme Catmull-Clark here OpenSubdiv HbrCatmarkSubdivision Vertex catmark new OpenSubdiv HbrCatmarkSubdivision Vertex Create an empty Hbr mesh Hmesh hmesh new Hmesh catmark Populate the vertices Vertex v for int i 0 i nverts i Primitive variable data must be set here in our case we set the 3D position of the vertex. v . SetPosition verts i 0 , verts i 1 , verts i 2 Add the vertex to the mesh. hmesh - NewVertex i , v Create the topology int fv faceverts for int i 0 i nfaces i int nv facenverts i hmesh - NewFace nv , fv , 0 fv nv Set subdivision options By default vertex interpolation is set to none on boundaries, which can produce un-expected results, so we change it to edge-only. hmesh - SetInterpolateBoundaryMethod Hmesh k_InterpolateBoundaryEdgeOnly Call Finish to finalize the data structures before using the mesh. hmesh - Finish printf Created a pyramid with d faces and d vertices. n , hmesh - GetNumFaces , hmesh - GetNumVertices delete hmesh delete catmark ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "far_tutorial_1_1.html" │ │ │ │ │ + "loc": "hbr_tutorial_0.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "Vtr Overview", │ │ │ │ │ "text": "Vtr Overview Vtr Overview 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Vectorized Topology Representation Vtr VtrLevel Topological Relationships Memory Efficiency VtrRefinement Parent-child and child-parent relationships Data flexibility Vectorized Topology Representation Vtr Vtr consists of a suite of classes that collectively provide an intermediate representation of topology that supports efficient refinement. Vtr is intended for internal use only and is currently accessed through the Far layer by the FarTopologyRefiner , which assembles these Vtr classes to meet the topological and refinement needs of the Far layer. What follows is therefore more intended to provide insite into the underlying architecture than to describe particular usage. For documentation more relevant to direct usage, proceed to the Far section previously noted. Vtr is vectorized in that its topological data is stored more as a collection of vectors of primitive elements rather than as the faces, vertices and edges that make up many other topological representations. It is essentially a structure-of-arrays SOA approach to topology in contrast to the more common array-of-structures pattern found in many other topological representations. Vtrs use of vectors allows it to be fairly efficient in its use of memory and similarly efficient to refine, but the topology is fixed once defined. Vtr classes are purely topological. They are even more independent of the representation of vertices, faces, etc. than Hbr in that they are not even parameterized by an interface to such components. So the same set of Vtr objects can eventually be used to serve more than one representation of these components. The primary requirement is that a mesh be expressable as an indexable set i.e. a vector or array of vertices, edges and faces. The index of a component uniquely identifies it and properties are retrieved by referring to it by index. Its worth qualifying the term topological here and elsewhere -- we generally refer to topology as subdivision topology rather than mesh topology. A subdivision hierarchy is impacted by the presence of semi-sharp creasing, as the subdivision rules change in response to that creasing. So subdivision topology includes the sharpness values assigned to edges and vertices that affect the semi-sharp creasing. The two primary classes in Vtr consist of VtrLevel - a class representing complete vertex topology for a level VtrRefinement - a class mapping a parent VtrLevel to a child level Others exist to represent the following selection and appropriate tagging of components for sparse refinement divergence of face-varying topology from the vertex topology mapping between face-varying topology at successive levels common low-level utilities, e.g. simple array classes VtrLevel VtrLevel is a complete topological description of a subdivision level, with the topological relations, sharpness values and component tags all stored in vectors literally stdvectors, but easily changed via typedefs. There are no classes or objects for the mesh component types i.e. faces, edges and vertices but simply an integer index to identify each. It can be viewed as a structure-of-arrays representation of the topology any property related to a particular component is stored in an array and accessible using the index identifying that component. So with no classes the for the components, its difficult to say what constitutes a vertex or a face they are each the sum of all the fields scattered amongst the many vectors included. Level represents a single level of a potential hierarchy and is capable of representing the complete base mesh. There are no members that relate data in one level to any other, either below or above. As such, any Level can be used as the base level for a new subdivision hierarchy potentially more than one. All relationships between separate levels are maintained in the VtrRefinement class. Topological Relationships Level requires the definition of and associations between a fixed set of indexable components for all three component types, i.e. an explicit edge list in addition to the expected set of vertices and faces. There are no explicit component objects in the representation, only an integer index VtrIndex identifying each component within the set and data associated with that component in the various vectors. The topology is stored as six sets of incident relations between the components two each for the two other component types incident each component type, i.e. for each face, its incident vertices and incident edges for each edge, its incident vertices and incident faces for each vertex, its incident edges and incident faces The collection of incidence relations is a vectorized variation of AIF the Adjacency and Incidence Framework. The set of these six incidence relations is not minimal only four are required, but that set excludes the most desired face-vertex relation but all six are kept and maintained to facilitate faster refinement. While the sizes of several vectors are directly proportional to the number of vertices, edges or faces to which the data is associated, the sizes of some of the vectors for these relations is more cumulative and so additional vectors of offsets is required typical of the face-vertex list commonly used as the minimal definition of mesh topology. Vectors for the sharpness values associated with crease edges and corner vertices are included and so sized according to the number of edges and vertices, along with additional tags for the components that may be helpful to refinement i.e. the type of subdivision Rule associated with each vertex. A Level is really just a container for data in a subdivision level, and so its public methods are primarily to access that data. Modification of the data is protected and only made available to classes that are intended to construct Levels currently the Far factory class that is responsible for building the base level, and the VtrRefinement class that constructs subsequent levels during refinement. Memory Efficiency One of the advantages in storing data in what is essentially a structure-of-arrays, rather than the array-of-structures more typical of topological representations, is that we can be more selective about memory usage in some cases. Particularly in the case of uniform refinement, when the data in subsequent levels is typically 4x its predecessor, we can minimize what we either generate or keep around at each level. For instance, if only a face-list is required at the finest level, we only need to generate one of the six topological relations the vertices incident each face. When we do keep Levels around in memory as is the case with the FarTopologyRefiner we do have do have the opportunity to prune what is not strictly necessary after the refinement. Just as with construction, whatever classes are privileged to construct a Level are likely those that will be privileged to prune its contents when needed. The current implementation of Level is far from optimal though -- there are opportunities for improvement. After one level of subdivision, the faces in a Level will be either all quads or tris. Having specializations for these cases and using the more general case in support of N-sided faces for the base level only is one possibility. Levels also allocate dozens of vectors in which to store all data. Since these vectors are of fixed size once created, they could be aggregated by partitioning one or a smaller number of larger block of memory into the desired pieces. The desire to make some of these improvements is part of why Vtr is not directly exposed for public use and instead exposed via Far. VtrRefinement While VtrLevel contains the topology for each subdivision level, VtrRefinement is responsible for creating a new level via refinement of an existing one, and for maintaining the relationships between the components in the parent and child levels. So a simplified view of a subdivision hierarchy with Vtr is a set of Levels with a Refinement between each successive pair. Refinement is a friend of Level and will populate a child level from a parent given a set of refinement parameters. Aside from parameters related to data or depth, there are two kinds of refinement supported uniform and sparse. The latter sparse refinement requires selection of an arbitrary set of components -- any dependent or neighboring components that are required for the limit will be automatically included. So feature-adaptive refinement is just one form of this selective sparse refinement, the criteria being the topological features of interest creases and extra-ordinary vertices. The intent is to eventually provide more flexibility to facilitate the refinement of particular regions of interest or more dynamicadaptive needs. Refinement has also been subclassed according to the type of topological split being performed, i.e. splitting all faces into quads or tris via the QuadRefinement and TriRefinement subclasses. As noted with VtrLevel , there is further room for improvement in memory andor performance here by combining more optimal specializations for both Refinement and Level -- with consideration of separating the uniform and sparse cases. Parent-child and child-parent relationships While Refinement populates a new child Level as part of its refinement operation, it also accumulates the relationships between the parent and child level and as with Level , this data is stored in vectors indexable by the components. The associations between components in the two levels was initially only uni-directional child components were associated with incident components of a parent component based on the parent components topology, so we had a parent-to-child mapping one to many. Storing the reverse child-to-parent mapping was avoided to reduce memory particularly in the case of uniform refinement as it often was not necessary, but a growing need for it, particularly in the case of sparse feature-adaptive refinement, lead to it being included. Data flexibility One of the advantages of the structure-of-arrays representation in both Level and Refinement is that we can make more dynamic choices about what type of data we choose to allocate and use based on needs. For instance, we can choose between maintaining the parent-child or child-parent mapping in Refinement , or both if needed, and we can remove one if no longer necessary. An active example of this is uniform refinement if we only require the face-vertex list at the finest subdivision level, there is no need to generate a complete topological description of that level as would be required of more traditional representations, and given that level is 4x the magnitude of its parent, the savings are considerable. Currently there is nothing specific to a subdivision scheme in the refinement other than the type of topological splitting to apply. The refinement does subdivide sharpness values for creasing, but that too is independent of scheme. Tags were added to the base level that are propagated through the refinement and these too are dependent on the scheme, but are applied externally. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "vtr_overview.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "hbr_tutorial_0.cpp", │ │ │ │ │ - "text": "hbr_tutorial_0.cpp hbr_tutorial_0.cpp 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE httpsgithub.comPixarAnimationStudiosOpenSubdivblobreleasetutorialshbrtutorial_0hbr_tutorial_0.cpp ------------------------------------------------------------------------------ Tutorial description This tutorial presents in a very succinct way the requisite steps to instantiate an Hbr mesh from simple topological data. include opensubdivhbrmesh.h include opensubdivhbrcatmark.h include cstdio ------------------------------------------------------------------------------ Vertex container implementation. The HbrMeshT class is a templated interface that expects a vertex class to perform interpolation on arbitrary vertex data. For the template specialization of the HbrMesh interface to be met, our Vertex object to implement a minimal set of constructors and member functions. Since we are not going to subdivide the mesh, the struct presented here has been left minimalistic. The only customization added to our container was to provide storage and accessors for the position of a 3D vertex. struct Vertex Hbr minimal required interface ---------------------- Vertex Vertex int i Vertex Vertex const src _position 0 src . _position 0 _position 1 src . _position 1 _position 2 src . _position 2 void Clear void 0 void AddWithWeight Vertex const , float void AddVaryingWithWeight Vertex const , float Public interface ------------------------------------ void SetPosition float x , float y , float z _position 0 x _position 1 y _position 2 z const float GetPosition const return _position private float _position 3 typedef OpenSubdiv HbrMesh Vertex Hmesh typedef OpenSubdiv HbrFace Vertex Hface typedef OpenSubdiv HbrVertex Vertex Hvertex typedef OpenSubdiv HbrHalfedge Vertex Hhalfedge ------------------------------------------------------------------------------ Pyramid geometry from catmark_pyramid.h static float verts 5 3 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 2.0f , 0.0f , 0.0f , 0.0f , 2.0f , 0.0f , -2.0f , 0.0f , 0.0f static int nverts 5 , nfaces 5 static int facenverts 5 3 , 3 , 3 , 3 , 4 static int faceverts 16 0 , 1 , 2 , 0 , 2 , 3 , 0 , 3 , 4 , 0 , 4 , 1 , 4 , 3 , 2 , 1 ------------------------------------------------------------------------------ int main int , char Create a subdivision scheme Catmull-Clark here OpenSubdiv HbrCatmarkSubdivision Vertex catmark new OpenSubdiv HbrCatmarkSubdivision Vertex Create an empty Hbr mesh Hmesh hmesh new Hmesh catmark Populate the vertices Vertex v for int i 0 i nverts i Primitive variable data must be set here in our case we set the 3D position of the vertex. v . SetPosition verts i 0 , verts i 1 , verts i 2 Add the vertex to the mesh. hmesh - NewVertex i , v Create the topology int fv faceverts for int i 0 i nfaces i int nv facenverts i hmesh - NewFace nv , fv , 0 fv nv Set subdivision options By default vertex interpolation is set to none on boundaries, which can produce un-expected results, so we change it to edge-only. hmesh - SetInterpolateBoundaryMethod Hmesh k_InterpolateBoundaryEdgeOnly Call Finish to finalize the data structures before using the mesh. hmesh - Finish printf Created a pyramid with d faces and d vertices. n , hmesh - GetNumFaces , hmesh - GetNumVertices delete hmesh delete catmark ------------------------------------------------------------------------------ Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "hbr_tutorial_0.html" │ │ │ │ │ - }, { │ │ │ │ │ "title": "Using Hbr", │ │ │ │ │ "text": "Using Hbr Using Hbr 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Vertex Template API Creating a Mesh Instantiating an HbrMesh Creating Vertices Creating Faces Wrapping Things Up Boundary Interpolation Rules Adding Creases Vertex Creases Edge Creases Holes Hierarchical Edits Face-varying Data Instantiating the HbrMesh Setting the Face-Varying Data Retrieving the Face-Varying Data Valence Operators Managing Singular Vertices Note As of OpenSubdiv 3.0, all Hbr dependencies have been removed from the core APIs Sdc , Vtr , Far , Osd . The legacy source code of Hbr is provided purely for regression and legacy purposes. If your code is currently depending on Hbr functionality, we recommend migrating to the newer APIs as we cannot guarantee that this code will be maintained in future releases. For more information see the 3.0 release notes Vertex Template API The Hbr API abstracts the vertex class through templating. Client-code is expected to provide a vertex class that implements the requisite interpolation functionality. Here is an example of a simple vertex class that accounts for 3D position, but does not support arbitrary variables or varying interpolation. struct Vertex Vertex Vertex int i Vertex const Vertex src _pos 0 src . _pos 0 _pos 1 src . _pos 1 _pos 2 src . _pos 2 Vertex void AddWithWeight const Vertex src , float weight , void 0 _pos 0 weight src . _pos 0 _pos 1 weight src . _pos 1 _pos 2 weight src . _pos 2 void AddVaryingWithWeight const Vertex , float , void 0 void Clear void 0 _pos 0 _pos 1 _pos 2 0.0f void SetPosition float x , float y , float z _pos 0 x _pos 1 y _pos 2 z void ApplyVertexEdit const OpenSubdiv HbrVertexEdit Vertex edit const float src edit . GetEdit switch edit . GetOperation case OpenSubdiv HbrHierarchicalEdit Vertex Set _pos 0 src 0 _pos 1 src 1 _pos 2 src 2 break case OpenSubdiv HbrHierarchicalEdit Vertex Add _pos 0 src 0 _pos 1 src 1 _pos 2 src 2 break case OpenSubdiv HbrHierarchicalEdit Vertex Subtract _pos 0 - src 0 _pos 1 - src 1 _pos 2 - src 2 break void ApplyMovingVertexEdit const OpenSubdiv HbrMovingVertexEdit Vertex custom functions data not required by Hbr ------------------------- Vertex float x , float y , float z _pos 0 x _pos 1 y _pos 2 z const float GetPos const return _pos float _pos 3 In some cases, if only topological analysis is required, the class can be left un-implemented. Far and Osd for instance store vertex data in serialized interleaved vectors. Here is the OsdVertex class for reference class Vertex public Vertex Vertex int index Vertex Vertex const src void AddWithWeight Vertex const i , float weight , void 0 void AddVaryingWithWeight const Vertex i , float weight , void 0 void Clear void 0 void ApplyVertexEdit FarVertexEdit const Creating a Mesh The following tutorial walks through the steps of instantiating a simple Hbr mesh. The code found in regressioncommonshape_utils.h can also be used as an example. While this implementation covers many of Hbr s features, it does not provide coverage for the complete Renderman specification though. Instantiating an HbrMesh First we need to instantiate a mesh object. Hbr supports 3 subdivision schemes Catmull-Clark catmark Loop Bilinear The scheme is selected by passing an specialized instance of HbrSubdivisionT , HbrCatmarkSubdivisionT in this case. The scheme can be shared across multiple mesh objects, so we only need a single instance. static OpenSubdiv HbrCatmarkSubdivision Vertex _scheme OpenSubdiv HbrMesh Vertex mesh new OpenSubdiv HbrMesh Vertex _scheme Creating Vertices Adding vertices to the mesh is accomplished using the HbrMeshNewVertex method. Because Hbr uses a dedicated vertex allocator to help alleviate the performance impact of intensive fragmented memory allocations. This optimization results in the following design pattern Vertex vtx for int i 0 i numVerts i Vertex v mesh - NewVertex i , vtx v-SetPosition We instantiate a single default vertex object named vtx on the stack. We then recover the pointer to the actual vertex created in the mesh from the NewVertex method. Once we have recovered that pointer, we can set the data for our vertex by using any of the custom accessors. Creating Faces Once all the vertices have been registered in the mesh, we can start adding the faces with HbrMeshNewFace . Assuming we had an obj style reader, we need to know the number of vertices in the face and the indices of these vertices. for int f 0 f numFaces f int nverts obj - GetNumVertices f const int faceverts obj - GetFaceVerts f mesh - NewFace nv , fv , 0 However, Hbr is not able to handle non-manifold geometry. In order to avoid tripping asserts or causing memory violations, lets rewrite the previous loop with some some prototype code to check the validity of the topology. for int f 0 f numFaces f int nv obj - GetNumVertices f const int fv obj - GetFaceVerts f triangles only for Loop subdivision if scheme kLoop and nv 3 printf Trying to create a Loop subd with non-triangle face n continue now check the half-edges connectivity for int j 0 j nv j OpenSubdiv HbrVertex T origin mesh - GetVertex fv j OpenSubdiv HbrVertex T destination mesh - GetVertex fv j 1 nv OpenSubdiv HbrHalfedge T opposite destination - GetEdge origin if origin NULL destination NULL printf An edge was specified that connected a nonexistent vertex n continue if origin destination printf An edge was specified that connected a vertex to itself n continue if opposite opposite - GetOpposite printf A non-manifold edge incident to more than 2 faces was found n continue if origin - GetEdge destination printf An edge connecting two vertices was specified more than once. Its likely that an incident face was flipped n continue mesh - NewFace nv , fv , 0 Wrapping Things Up Once we have vertices and faces set in our mesh, we still need to wrap things up by calling HbrMeshFinish mesh - Finish Finish iterates over the mesh to apply the boundary interpolation rules and checks for singular vertices. At this point, there is one final topology check remaining to validate the mesh mesh - Finish if mesh - GetNumDisconnectedVertices printf The specified subdivmesh contains disconnected surface components. n abort or iterate over the mesh to remove the offending vertices Boundary Interpolation Rules The rule-set can be selected using the following accessors Vertex and varying data mesh - SetInterpolateBoundaryMethod OpenSubdiv HbrMesh Vertex k_InterpolateBoundaryEdgeOnly Face-varying data mesh - SetFVarInterpolateBoundaryMethod OpenSubdiv HbrMesh Vertex k_InterpolateBoundaryEdgeOnly Additional information on boundary interpolation rules can be found here Warning The boundary interpolation rules must be set before the call to HbrMeshFinish , which sets the sharpness values to boundary edges and vertices based on these rules. Adding Creases Hbr supports a sharpness attribute on both edges and vertices. Sharpness is set using the SetSharpnessfloat accessors. Vertex Creases Given an index, vertices are very easy to access in the mesh. int idx vertex index float sharp the edge sharpness OpenSubdiv HbrVertex Vertex v mesh - GetVertex idx if v v - SetSharpness std max 0.0f , sharp else printf cannot find vertex for corner tag d n , idx Edge Creases Usually, edge creases are described with a vertex indices pair. Here is some sample code to locate the matching half-edge and set a crease sharpness. int v0 , v1 vertex indices float sharp the edge sharpness OpenSubdiv HbrVertex Vertex v mesh - GetVertex v0 , w mesh - GetVertex v1 OpenSubdiv HbrHalfedge Vertex e 0 if v w if e v - GetEdge w 0 e w - GetEdge v if e e - SetSharpness std max 0.0f , sharp else printf cannot find edge for crease tag d,d n , v0 , v1 Holes Hbr faces support a hole tag. int idx the face index OpenSubdiv HbrFace Vertex f mesh - GetFace idx if f f - SetHole else printf cannot find face for hole tag d n , idx Note The hole tag is hierarchical sub-faces can also be marked as holes. See Hierarchical Edits Hierarchical Edits Hbr supports the following types of hierarchical edits Type Function Corner edits Modify vertex sharpness Crease edits Modify edge sharpness FaceEdit Modify custom face data FVarEdit Modify face-varying data VertexEdit Modify vertex and varying data HoleEdit Set hole tag Modifications are one of the following 3 operations Operation Set Add Subtract Here is a simple example that creates a hierarchical vertex edit. path 655, 2, 3, 0 int faceid 655 , nsubfaces 2 , subfaces 2 2 , 3 , vertexid 0 int offset 0 , offset to the vertex or varying data numElems 3 number of elements to apply the modifier to x,y,z 3 bool isP false shortcut to identify modifications to the vertex position P OpenSubdiv HbrHierarchicalEdit Vertex Operation op OpenSubdiv HbrHierarchicalEdit T Set float values 3 1.0f , 0.5f , 0.0f edit values OpenSubdiv HbrVertexEdit T edit new OpenSubdiv HbrVertexEdit T faceid , nsubfaces , subfaces , vertexid , offset , floatwidth , isP , op , values Face-varying Data Here is a walk-through of how to store face-varying data for a u,v pair. Unlike vertex and varying data which is accessed through the templated vertex API, face-varying data is directly aggregated as vectors of float data. Instantiating the HbrMesh The HbrMesh needs to retain some knowledge about the face-varying data that it carries in order to refine it correctly. int fvarwidth 2 total width of the fvar data static int indices 1 0 , 1 offset set to 0 widths 1 2 2 floats in a u,v pair int const fvarcount fvarwidth 0 1 0 , fvarindices fvarwidth 0 indices NULL , fvarwidths fvarwidth 0 widths NULL mesh new OpenSubdiv HbrMesh T _scheme , fvarcount , fvarindices , fvarwidths , fvarwidth Setting the Face-Varying Data After the topology has been created, Hbr is ready to accept face-varying data. Here is some sample code for int i 0 , idx 0 i numFaces i OpenSubdiv HbrFace Vertex f mesh - GetFace i int nv f - GetNumVertices note this is not the fastest way OpenSubdiv HbrHalfedge Vertex e f - GetFirstEdge for int j 0 j nv j , e e - GetNext OpenSubdiv HbrFVarData Vertex fvt e - GetOrgVertex - GetFVarData f float const fvdata GetFaceVaryingData i , j if not fvt . IsInitialized if no fvar daa exists yet on the vertex fvt . SetAllData 2 , fvdata else if not fvt . CompareAll 2 , fvdata if there already is fvar data and there is a boundary add the new data OpenSubdiv HbrFVarData T nfvt e - GetOrgVertex - NewFVarData f nfvt . SetAllData 2 , fvdata Retrieving the Face-Varying Data The HbrFVarData structures are expanded during the refinement process, with every sub-face being assigned a set of interpolated face-varying data. This data can be accessed in 2 ways From a face, passing a vertex index OpenSubdivHbrFaceVertex f OpenSubdiv HbrFVarData const fv f . GetFVarData vindex const float data fv . GetData From a vertex, passing a pointer to an incident face OpenSubdivHbrFaceVertex f OpenSubdiv HbrFVarData const fv myVertex . GetFVarData f const float data fv . GetData Valence Operators When manipulating meshes, it is often necessary to iterate over neighboring faces or vertices. Rather than gather lists of pointers and return them, Hbr exposes an operator pattern that guarantees consistent mesh traversals. The following example shows how to use an operator to count the number of neighboring vertices use HbrVertexGetValence for proper valence counts OpenSubdivHbrVertexVertex v class MyOperator public OpenSubdiv HbrVertexOperator Vertex public int count MyOperator count 0 virtual void operator OpenSubdiv HbrVertex Vertex v count MyOperator op v - ApplyOperatorSurroundingVertices op Managing Singular Vertices Certain topological configurations would force vertices to share multiple half-edge cycles. Because Hbr is a half-edge representation, these singular vertices have to be duplicated as part of the HbrMeshFinish phase of the instantiation. These duplicated vertices can cause problems for client-code that tries to populate buffers of vertex or varying data. The following sample code shows how to match the vertex data to singular vertex splits Populating an OsdCpuVertexBuffer with vertex data positions,... float const vtxData inMeshFn . getRawPoints returnStatus OpenSubdiv OsdCpuVertexBuffer vertexBuffer OpenSubdiv OsdCpuVertexBuffer Create numVertexElements , numFarVerts vertexBuffer - UpdateData vtxData , 0 , numVertices Duplicate the vertex data into the split singular vertices std vector std pair int , int const splits hbrMesh - GetSplitVertices for int i 0 i int splits . size i vertexBuffer - UpdateData vtxData splits i . second numVertexElements , splits i . first , 1 Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "using_osd_hbr.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Sdc Overview", │ │ │ │ │ - "text": "Sdc Overview Sdc Overview 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Subdivision Core Sdc Types, Traits and Options Creasing support Scheme-specific support The FACE, EDGE and VERTEX interfaces The MASK interface Subdivision Core Sdc Sdc is the lowest level layer in OpenSubdiv. Its intent is to separate the core subdivision details from any particular representation of a mesh it was previously bound to Hbr to facilitate the generation of consistent results with other mesh representations, both internal and external to OpenSubdiv. The functionality can be divided roughly into three sections types, traits and options for the supported subdivision schemes computations required to support semi-sharp creasing computations for mask weights of subdivided vertices for all schemes For most common usage, familiarity with only the first of these is necessary -- primarily the use of public types and constants for the choice of subdivision scheme and its associated options. The latter two provide the basis for a more comprehensive implementation of subdivision, which requires considerably more understanding and effort. Overall, the approach was to extract the functionality at the lowest level possible. In some cases, the implementation is not far from being simple global functions. The intent was to start at a low level and build any higher level functionality as needed. What exists now is functional for ongoing development and anticipated needs within OpenSubdiv for the near future. The intent of Sdc is to provide the building blocks for OpenSubdiv and its clients to efficiently process the specific set of supported subdivision schemes. It is not intended to be a general framework for defining customized subdivision schemes. Types, Traits and Options The most basic type is the enum SdcSchemeType that identifies the fixed set of subdivision schemes supported by OpenSubdiv Bilinear , Catmark and Loop . With this alone, we intend to avoid all dynamic casting issues related to the scheme by simply adding members to the associated subclasses for inspection. In addition to the type enum itself, a class defining a fixed set of traits associated with each scheme is provided. While these traits are available as static methods in the interface of a class supporting more functionality for each scheme to be described shortly, the SchemeTypeTraits provide queries of the traits for a variable of type SdcSchemeType -- enabling parameterization of code by the value of a trait without templates or virtual inheritance a simple internal table of traits is constructed and trivially indexed. The second contribution is the collection of all variations in one place that can be applied to the subdivision schemes, i.e. the boundary interpolation rules, creasing method, edge subdivision choices, etc. The fact that these are all declared in one place alone should help clients see the full set of variations that are possible. A simple Options struct a set of bitfields aggregates all of these variations into a single object the equivalent of an integer in this case that are passed around to other Sdc classes andor methods and are expected to be used at a higher level both within OpenSubdiv and externally. By aggregating the options and passing them around as a group, it allows us to extend the set easily in future without the need to rewire a lot of interfaces to accommodate the new choice. Clients can enable new choices at the highest level and be assured that they will propagate to the lowest level where they are relevant. Unlike other options structs used elsewhere to specify variations of a particular method, SdcOptions defines all options that affect the shape of the underlying limit surface of a subdivision mesh. Other operations at higher levels in the library may have options that approximate the shape and so create a slightly different appearance, but SdcOptions is a fundamental part of the definition of the true limit surface. Creasing support Since the computations involved in the support of semi-sharp creasing are independent of the subdivision scheme, the goal in Sdc was to encapsulate all related creasing functionality in a similarly independent manner. Computations involving sharpness values are also much less dependent on topology -- there are vertices and edges with sharpness values, but knowledge of faces or boundary edges is not required, -- so the complexity of topological neighborhoods required for more scheme-specific functionality is arguably not necessary here. Creasing computations have been provided as methods defined on a Crease class that is constructed with a set of Options. Its methods typically take sharpness values as inputs and compute a corresponding set of sharpness values as a result. For the Uniform creasing method previously known as Normal , the computations may be so trivial as to question whether such an interface is worth it, but for Chaikin or other schemes in the future that are non-trivial, the benefits should be clear. Functionality is divided between both uniform and non-uniform, so clients have some control over avoiding unnecessary overhead, e.g. non-uniform computations typically require neighboring sharpness values around a vertex, while uniform does not. Also included as part of the Crease class is the Rule enum -- this indicates if a vertex is Smooth, Crease, Dart or Corner referred to as the mask in Hbr and is a function of the sharpness values at and around a vertex. Knowing the Rule for a vertex can accelerate mask queries, and the Rule can often be inferred based on the origin of a vertex e.g. it originated from the middle of a face, was the child of a Smooth vertex, etc.. Methods are defined for the Crease class to subdivide edge and vertex sharpness values determine the Rule for a vertex based on incident sharpness values determine the transitional weight between two sets of sharpness values Being all low-level and working directly on sharpness values, it is a clients responsibility to coordinate the application of any hierarchical crease edits with their computations. Similarly, in keeping with this as a low-level interface, values are passed as primitive arrays. This follows the trend in OpenSubdiv of dealing with data of various kinds e.g. weights, component indices, now sharpness values, etc. in small contiguous sets of values. In most internal cases we can refer to a set of values or gather what will typically be a small number of values on the stack for temporary use. Scheme-specific support While the SchemeTypeTraits class provides traits for each subdivision scheme supported by OpenSubdiv i.e. Bilinear , Catmark and Loop , the Scheme class provides these more directly, Additionally, the Scheme class provides methods for computing the various sets of weights used to compute new vertices resulting from subdivision. The collection of weights used to compute a single vertex at a new subdivision level is typically referred to as a mask . The primary purpose of the Scheme class is to provide such masks in a manner both general and efficient. Each subdivision scheme has its own values for its masks, and each are provided as specializations of the template class SchemeSchemeType TYPE . The intent is to minimize the amount of code specific to each scheme. The computation of mask weights for subdivided vertices is the most significant contribution of Sdc. The use of semi-sharp creasing with each non-linear subdivision scheme complicates what are otherwise simple masks determined solely by the topology, and packaging that functionality to achieve both the generality and efficiency desired has been a challenge. Mask queries are defined in the Scheme class template, which has specializations for each of the supported subdivision schemes. Mask queries are defined in terms of interfaces for two template parameters the first defining the topological neighborhood of a vertex, and a second defining a container in which to gather the individual weights template typename FACE , typename MASK void ComputeFaceVertexMask FACE const faceNeighborhood , MASK faceVertexMask , ... const Each mask query is expected to call methods defined for the FACE , EDGE or VERTEX classes to obtain the information they require typically these methods are simple queries about the topology and associated sharpness values. Clients are free to use their own mesh representations to gather the requested information as quickly as possible, or to cache some subset as member variables for immediate inline retrieval. In general, the set of weights for a subdivided vertex is dependent on the following the topology around the parent component from which the vertex originates the type of subdivision Rule applicable to the parent component the type of subdivision Rule applicable to the new child vertex a transitional weight blending the effect between differing parent and child rules This seems fairly straight-forward, until we look at some of the dependencies involved the parent Rule requires the sharpness values at and around the parent component the child Rule requires the subdivided sharpness values at and around the new child vertex though it can sometimes be trivially inferred from the parent the transitional weight between differing rules requires all parent and child sharpness values Clearly the sharpness values are inspected multiple times and so it pays to have them available for retrieval. Computing them on an as-needed basis may be simple for uniform creasing, but a non-uniform creasing method requires traversing topological neighborhoods, and that in addition to the computation itself can be costly. The point here is that it is potentially unreasonable to expect to evaluate the mask weights completely independent of any other consideration. Expecting and encouraging the client to have subdivided sharpness values first, for use in more than one place, is therefore recommended. The complexity of the general case above is also unnecessary for most vertices. Any client using Sdc typically has more information about the nature of the vertex being subdivided and much of this can be avoided -- particularly for the smooth interior case that often dominates. More on that in the details of the Scheme classes. Given that most of the complexity has been moved into the template parameters for the mask queries, the Scheme class remains fairly simple. Like the Crease class, it is instantiated with a set of Options to avoid them cluttering the interface. It is currently little more than a few methods for the limit and refinement masks for each vertex type, plus the few fixed traits of the scheme as static methods. The mask queries have been written in a way that greatly simplifies the specializations required for each scheme. The generic implementation for both the edge-vertex and vertex-vertex masks take care of all of the creasing logic, requiring only a small set of specific masks to be assigned for each Scheme smooth and crease masks for an edge-vertex, and smooth, crease and corner masks for a vertex-vertex. Other than the Bilinear case, which will specialize the mask queries to trivialize them for linear interpolation, the specializations for each Scheme should only require defining this set of masks -- and with two of them common edge-vertex crease and vertex-vertex corner the Catmark scheme only needs to define three. The FACE, EDGE and VERTEX interfaces Mask queries require an interface to a topological neighborhood, currently labeled FACE , EDGE and VERTEX . This naming potentially implies more generality than intended, as such classes are only expected to provide the methods required of the mask queries to compute its associated weights. While all methods must be defined, some may rarely be invoked, and the client has considerable flexibility in the implementation of these they can defer some evaluations lazily until required, or be pro-active and cache information in member variables for immediate access. An approach discussed in the past has alluded to iterator classes that clients would write to traverse their meshes. The mask queries would then be parameterized in terms of a more general and generic mesh component that would make use of more general traversal iterators. The advantage here is the iterators are written once, then traversal is left to the query and only what is necessary is gathered. The disadvantages are that clients are forced to write these to do anything, getting them correct and efficient may not be trivial or possible in some cases, and that the same data e.g. subdivided sharpness may be gathered or computed multiple times for different purposes. The other extreme was to gather everything possible required at once, but that is objectionable. The approach taken here provides a reasonable compromise between the two. The mask queries ask for exactly what they want, and the provided classes are expected to deliver it as efficiently as possible. In some cases the client may already be storing it in a more accessible form and general topological iteration can be avoided. The information requested of these classes in the three mask queries is as follows For FACE the number of incident vertices For EDGE the number of incident faces the sharpness value of the parent edge the sharpness values of the two child edges the number of vertices per incident face For VERTEX the number of incident faces the number of incident edges the sharpness value of the parent vertex the sharpness values for each incident parent edge the sharpness value of the child vertex the sharpness values for each incident child edge The latter should not be surprising given the dependencies noted above. There are also a few more to consider for future use, e.g. whether the EDGE or VERTEX is manifold or not. In most cases, additional information can be provided to the mask queries i.e. pre-determined Rules, and most of the child sharpness values are not necessary. The most demanding situation is a fractional crease that decays to zero -- in which case all parent and child sharpness values in the neighborhood are required to determine the proper transitional weight. The MASK interface Methods dealing with the collections of weights defining a mask are typically parameterized by a MASK template parameter that contains the weights. The set of mask weights is currently divided into vertex-weights, edge-weights and face-weights -- consistent with previous usage in OpenSubdiv and providing some useful correlation between the full set of weights and topology. The vertex-weights refer to parent vertices incident the parent component from which a vertex originated, the edge-weights the vertices opposite incident edges of the parent, and the face-weights the center of incident parent faces. Note the latter is NOT in terms of vertices of the parent but potentially vertices in the child originating from faces of the parent. This has been done historically in OpenSubdiv but is finding less use -- particularly when it comes to providing greater support for the Loop scheme -- and is a point needing attention. So the mask queries require the following capabilities assign the number of vertex, edge andor face weights retrieve the number of vertex, edge andor face weights assign individual vertex, edge andor face weights by index retrieve individual vertex, edge andor face weights by index through a set of methods required of all MASK classes. Since the maximum number of weights is typically known based on the topology, usage within Vtr, Far or Hbr is expected to simply define buffers on the stack. Another option is to utilize pre-allocated tables, partitioned into the three sets of weights on construction of a MASK , and populated by the mask queries. A potentially useful side-effect of this is that the client can define their weights to be stored in either single or double-precision. With that possibility in mind, care was taken within the mask queries to make use of a declared type in the MASK interface MASKWeight for intermediate calculations. Having support for double-precision masks in Sdc does enable it at higher levels in OpenSubdiv if later desired, and that support is made almost trivial with MASK being generic. It is important to remember here that these masks are being defined consistent with existing usage within OpenSubdiv both Hbr and the subdivision tables generated by Far . As noted above, the face weights correspond to the centers of incident faces, i.e. vertices on the same level as the vertex for which the mask is being computed, and not relative to vertices in the parent level as with the other sets of weights. It is true that the weights can be translated into a set in terms solely of parent vertices, but in the general case i.e. Catmark subdivision with non-quads in the base mesh this requires additional topological association. In general we would need N-3 weights for the N-3 vertices between the two incident edges, where N is the number of vertices of each face typically 4 even at level 0. Perhaps such a translation method could be provided on the mask class, with an optional indication of the incident face topology for the irregular cases. The Loop scheme does not have face weights , for a vertex-vertex mask, but for an edge-vertex mask it does require weights associated with the faces incident the edge -- either the vertex opposite the edge for each triangle, or its center which has no other use for Loop. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "Subdivision Surfaces", │ │ │ │ │ + "text": "Subdivision Surfaces Subdivision Surfaces 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Overview Piecewise Parametric Surfaces Parametric Patches Piecewise Surfaces Arbitrary Topology Regular versus Irregular Features Non-manifold Topology Subdivision versus Tessellation Subdivision Tessellation Which to Use Mesh Data and Topology Separating Data from Topology Vertex and Varying Data Face-Varying Data and Topology Schemes and Options Subdivision Schemes Boundary Interpolation Rules Face-varying Interpolation Rules Semi-Sharp Creases Other Options Chaikin Rule Triangle Subdivision Rule Overview Subdivision surfaces are a common modeling primitive that has gained popularity in animation and visual effects over the past decades. As the name suggests, subdivision surfaces are fundamentally surfaces . More specifically, subdivision surfaces are piecewise parametric surfaces defined over meshes of arbitrary topology -- both concepts that will be described in the sections that follow. Subdivision is both an operation that can be applied to a polygonal mesh to refine it, and a mathematical tool that defines the underlying smooth surface to which repeated subdivision of the mesh converges. Explicit subdivision is simple to apply some number of times to provide a smoother mesh, and that simplicity has historically lead to many tools representing the shape this way. In contrast, deriving the smooth surface that ultimately defines the shape -- its limit surface -- is considerably more complex but provides greater accuracy and flexibility. These differences have led to confusion in how some tools expose subdivision surfaces. The ultimate goal is to have all tools use subdivision surfaces as true surface primitives. The focus here is therefore less on subdivision and more on the nature of the surface that results from it. In addition to providing a consistent implementation of subdivision -- one that includes a number of widely used feature extensions -- a significant value of OpenSubdiv is that it makes the limit surface more accessible. Since its introduction, OpenSubdiv has received interest from users and developers with a wide variety of skills, interests and backgrounds. This document is intended to present subdivision surfaces from a perspective helpful in making use of OpenSubdiv. One purpose it serves is to provide a high level overview for those with less experience with the algorithms or mathematics of subdivision. The other is to provide an overview of the feature set available with OpenSubdiv, and to introduce those capabilities with the terminology used by OpenSubdiv as much of it is overloaded. Piecewise Parametric Surfaces Piecewise parametric surfaces are arguably the most widely used geometric representation in industrial design, entertainment and many other areas. Many of the objects we deal with everyday -- cars, mobile phones, laptops -- were all designed and visualized first as piecewise parametric surfaces before those designs were approved and pursued. Piecewise parametric surfaces are ultimately just collections of simpler modeling primitives referred to as patches. Patches constitute the pieces of the larger surface in much the same way as a face or polygon constitutes a piece of a polygonal mesh. Parametric Patches Patches are the building blocks of piecewise smooth surfaces, and many different kinds of patches have evolved to meet the needs of geometric modeling. Two of the more effective and common patches are illustrated below Single bicubic B-Spline patch Single bicubic Bezier patch Patches consist of a set of points or vertices that affect a rectangular piece of smooth surface triangular patches also exist. That rectangle is parameterized in its two directions, transforming a simple 2D rectangle into the 3D surface u,v 2D domain of a patch Mapping from u,v to x,y,z The points that control the shape of the surface are usually referred to as control points or control vertices, and the collection of the entire set defining a patch as the control mesh, the control hull, the control cage or simply the hull, the cage, etc. For the sake of brevity we will frequently use the term cage, which serves us more generally later. So a patch essentially consist of two entities its control points and the surface affected by them. The way the control points affect the surface is what makes the different types of patches unique. Even patches defined by the same number of points can have different behavior. Note that all 16 points of the B-Spline patch above are relatively far from the surface they define compared to the similar Bezier patch. The two patches in that example actually represent exactly the same piece of surface -- each with a set of control points having different effects on it. In mathematical terms, each control point has a basis function associated with it that affects the surface in a particular way when only that point is moved Bicubic B-Spline basis function Bicubic Bezier basis funciton It is these basis functions that often give rise to the names of the different patches. There are pros and cons to these different properties of the control points of patches, which become more apparent as we assemble patches into piecewise surfaces. Piecewise Surfaces Piecewise parametric surfaces are collections of patches. For rectangular patches, one of the simplest ways to construct a collection is to define a set of patches using a rectangular grid of control points Piecewise B-Spline surface Piecewise Bezier surface Note that we can overlap the points of adjacent B-spline patches. This overlapping means that moving one control point affects multiple patches -- but it also ensures that those patches always meet smoothly this was a design intention and not true for other patch types. Adjacent Bezier patches only share points at their boundaries and coordinating the points across those boundaries to keep the surface smooth is possible, but awkward. This makes B-splines a more favorable surface representation for interactive modeling, but Bezier patches serve many other useful purposes. A more complicated B-spline surface Part of a more complicated B-Spline surface Just as a patch consisted of a cage and a surface, the same is now true of the collection. The control cage is manipulated by a designer and the surface of each of the patches involved is displayed so they can assess its effect. Arbitrary Topology Piecewise surfaces discussed thus far have been restricted to collections of patches over regular grids of control points. There is a certain simplicity with rectangular parametric surfaces that is appealing, but a surface representation that supports arbitrary topology has many other advantages. Rectangular parametric surfaces gained widespread adoption despite their topological limitations, and their popularity continues today in some areas. Complex objects often need many such surfaces to represent them and a variety of techniques have evolved to assemble them effectively, including stitching multiple surfaces together or cutting holes into them trimming. These are complicated techniques, and while effective in some contexts e.g. industrial design they become cumbersome in others e.g. animation and visual effects. A single polygonal mesh can represent shapes with far more complexity than a single rectangular piecewise surface, but its faceted nature eventually becomes a problem. Subdivision surfaces combine the topological flexibility of polygonal meshes with the underlying smoothness of piecewise parametric surfaces. Just as rectangular piecewise parametric surfaces have a collection of control points its cage stored as a grid and an underlying surface, subdivision surfaces also have a collection of control points its cage stored as a mesh and an underlying surface often referred as its limit surface. Regular versus Irregular Features A mesh contains the vertices and faces that form the cage for the underlying surface, and the topology of that mesh can be arbitrarily complex. In areas where the faces and vertices of the mesh are connected to form rectangular grids, the limit surface becomes one of the rectangular piecewise parametric surfaces previously mentioned. These regions of the mesh are said to be regular they provide behavior familiar from the use of similar rectangular surfaces and their limit surface is relatively simple to deal with. All other areas are considered irregular they provide the desired topological flexibility and so are less familiar and less predictable in some cases and their limit surface can be much more complicated. Irregular features come in a number of forms. The most widely referred to is an extra-ordinary vertex, i.e. a vertex which, in the case of a quad subdivision scheme like Catmull-Clark, does not have four incident faces. Irregular vertex and incident faces Regular and irregular regions of the surface The presence of these irregular features makes the limit surface around them similarly irregular, i.e. it cannot be represented as simply as it can for regular regions. Its worth noting that irregular regions shrink in size and become more isolated as subdivision is applied. A face with a lot of extra-ordinary vertices around it makes for a very complicated surface, and isolating these features is a way to help deal with that complexity Two valence-5 vertices nearby Isolation subdivided once Isolation subdivided twice Its generally necessary to perform some kind of local subdivision in these areas to break these pieces of surface into smaller, more manageable pieces, and the term feature adaptive subdivision has become popular in recent years to describe this process. Whether this is done explicitly or implicitly, globally or locally, what matters most is that there is an underlying piece of limit surface for each face -- albeit a potentially complicated one at an irregular feature -- that can be evaluated in much the same way as rectangular piecewise surfaces. Patches of the regular regions Patches of the irregular region While supporting a smooth surface in these irregular areas is the main advantage of subdivision surfaces, both the complexity of the resulting surfaces and their quality are reasons to use them with care. When the topology is largely irregular, there is a higher cost associated with its surface, so minimizing irregularities is advantageous. And in some cases the surface quality, i.e. the perceived smoothness, of the irregular surfaces can lead to undesirable artefacts. An arbitrary polygonal mesh will often not make a good subdivision cage, regardless of how good that polygonal mesh appears. As with rectangular piecewise parametric surfaces, the cage should be shaped to affect the underlying surface it is intended to represent. See Modeling Tips for related recommendations. Non-manifold Topology Since the cage of a subdivision surface is stored in a mesh, and often manipulated in the same context as polygonal meshes, the topic of manifold versus non-manifold topology warrants some attention. There are many definitions or descriptions of what distinguishes a manifold mesh from one that is not. These range from concise but abstract mathematical definitions to sets of examples showing manifold and non-manifold meshes -- all have their value and an appropriate audience. The following is not a strict definition but serves well to illustrate most local topological configurations that cause a mesh to be non-manifold. Consider standing on the faces of a mesh and walking around each vertex in turn. Assuming a right-hand winding order of faces, stand on the side of the face in the positive normal direction. And when walking, step across each incident edge in a counter-clockwise direction to the next incident face. For an interior vertex start at the corner of any incident face walk around the vertex across each incident edge to the next unvisited face repeat if you arrive back where you started and any incident faces or edges were not visited, the mesh is non-manifold Similarly, for a boundary vertex start at the corner of the face containing the leading boundary edge walk around the vertex across each incident edge to the next unvisited face repeat if you arrive at another boundary edge and any incident faces or edges were not visited, the mesh is non-manifold If you can walk around all vertices this way and dont encounter any non-manifold features, the mesh is likely manifold. Obviously if a vertex has no faces, there is nothing to walk around and this test cant succeed, so it is again non-manifold. All of the faces around a vertex should also be in the same orientation, otherwise two adjacent faces have normals in opposite directions and the mesh will be considered non-manifold, so we should really include that constraint when stepping to the next face to be more strict. Consider walking around the indicated vertices of the following non-manifold meshes Edges with 2 incident faces Faces sharing a vertex but no edges As mentioned earlier, many tools do not support non-manifold meshes, and in some contexts, e.g. 3D printing, they should be strictly avoided. Sometimes a manifold mesh may be desired and enforced as an end result, but the mesh may temporarily become non-manifold due to a particular sequence of modeling operations. Rather than supporting or advocating the use of non-manifold meshes, OpenSubdiv strives to be robust in the presence of non-manifold features to simplify the usage of its clients -- sparing them the need for topological analysis to determine when OpenSubdiv can or cannot be used. Although subdivision rules are not as well standardized in areas where the mesh is not manifold, OpenSubdiv provides simple rules and a reasonable limit surface in most cases. Surface around edges with 2 incident faces Surface for faces sharing a vertex but no edges As with the case of regular versus irregular features, since every face has a corresponding piece of surface associated with it -- whether locally manifold or not -- the term arbitrary topology can be said to include non-manifold topology. Subdivision versus Tessellation The preceding sections illustrate subdivision surfaces as piecewise parametric surfaces of arbitrary topology. As piecewise parametric surfaces, they consist of a cage and the underlying surface defined by that cage. Two techniques used to display subdivision surfaces are subdivision and tessellation. Both have their legitimate uses, but there is an important distinction between them subdivision operates on a cage and produces a refined cage tessellation operates on a surface and produces a discretization of that surface The existence and relative simplicity of the subdivision algorithm makes it easy to apply repeatedly to approximate the shape of the surface, but with the result being a refined cage, that approximation is not always very accurate. When compared to a cage refined to a different level, or a tessellation that uses points evaluated directly on the limit surface, the discrepancies can be confusing. Subdivision Subdivision is the process that gives subdivision surfaces their name, but it is not unique to them. Being piecewise parametric surfaces, lets first look at subdivision in the context of the simpler parametric patches that comprise them. Subdivision is a special case of refinement , which is key to the success of some of the most widely used types of parametric patches and their aggregate surfaces. A surface can be refined when an algorithm exists such that more control points can be introduced while keeping the shape of the surface exactly the same . For interactive and design purposes, this allows a designer to introduce more resolution for finer control without introducing undesired side effects in the shape. For more analytical purposes, it allows the surface to be broken into pieces, often adaptively, while being faithful to the original shape. One reason why both B-spline and Bezier patches are so widely used is that both of them can be refined. Uniform subdivision -- the process of splitting each of the patches in one or both of its directions -- is a special case of refinement that both of these patch types support B-Spline surface and its cage Cage subdivided 1x Cage subdivided 2x In the cases illustrated above for B-Splines, the uniformly refined cages produce the same limit surface as the original granted in more pieces. So it is fair to say that both uniform B-splines and Bezier surfaces are subdivision surfaces. The limit surface remains the same with the many more control points roughly 4x with each iteration of subdivision, and those points are closer to but not on the surface. It may be tempting to use these new control points to represent the surface, but using the same number of points evaluated at corresponding uniformly spaced parametric locations on the surface is usually simpler and more effective. Note also that points of the cage typically do not have any normal vectors associated with them, though we can evaluate normals explicitly for arbitrary locations on the surface just as we do for position. So if displaying a cage as a shaded surface, normal vectors at each of the control points must be contrived. Both the positions and normals of the points on the finer cage are therefore both approximations. For more general subdivision surfaces, the same is true. Subdivision will refine a mesh of arbitrary topology, but the resulting points will not lie on the limit surface and any normal vectors contrived from and associated with these points will only be approximations to those of the limit surface. Tessellation There is little need to use subdivision to approximate a parametric surface when it can be computed directly, i.e. it can be tessellated. We can evaluate at arbitrary locations on the surface and connect the resulting points to form a tessellation -- a discretization of the limit surface -- that is far more flexible than the results achieved from uniform subdivision Uniform 3x3 tessellation of B-spline surface Curvature-adaptive tessellation of B-spline surface For a simple parametric surface, the direct evaluation of the limit surface is also simple, but for more complicated subdivision surfaces of arbitrary topology, this is less the case. The lack of a clear understanding of the relationship between the limit surface and the cage has historically lead to many applications avoiding tessellation. Its worth mentioning that subdivision can be used to generate a tessellation even when the limit surface is not available for direct evaluation. The recursive nature of subdivision does give rise to formulae that allow a point on the limit surface to be computed that corresponds to each point of the cage. This process is often referred to as snapping or pushing the points of the cage onto the limit surface. Subdivided 1x and snapped to limit surface Subdivided 2x and snapped to limit surface Since the end result is a connected set of points on the limit surface, this forms a tessellation of the limit surface, and we consider it a separate process to subdivision though it does make use of it. The fact that such a tessellation might have been achieved using subdivision is indistinguishable from the final result -- the same tessellation might just as easily have been generated by evaluating limit patches of the cage uniformly 2x, 4x, 8x, etc. along each edge. Which to Use Subdivision is undeniably useful in creating finer cages to manipulate the surface, but tessellation is preferred for displaying the surface when the patches are available for direct evaluation. There was a time when global refinement was pursued in limited circles as a way of rapidly evaluating parametric surfaces along isoparametric lines, but patch evaluation, i.e. tessellation, generally prevails. Considerable confusion has arisen due the way the two techniques have been employed and presented when displaying the shape in end-user applications. One can argue that if an application displays a representation of the surface that is satisfactory for its purposes, then it is not necessary to burden the user with additional terminology and choices. But when two representations of the same surface differ considerably between two applications, the lack of any explanation or control leads to confusion. As long as applications make different choices on how to display the surface, we seek a balance between simplicity and control. Since subdivided points do not lie on the limit surface, it is important to make it clear to users when subdivision is being used instead of tessellation. This is particularly true in applications where the cage and the surface are displayed in the same style as there is no visual cue for users to make that distinction. Mesh Data and Topology The ability of subdivision surfaces to support arbitrary topology leads to the use of meshes to store both the topology of the cage and the data values associated with its control points, i.e. its vertices. The shape of a mesh, or the subdivision surface that results from it, is a combination of the topology of the mesh and the position data associated with its vertices. When dealing with meshes there are advantages to separating the topology from the data, and this is even more important when dealing with subdivision surfaces. The shape referred to above is not just the shape of the mesh the cage in this case but could be the shape of a refined cage or the limit surface. By observing the roles that both the data and topology play in operations such as subdivision and evaluation, significant advantages can be gained by managing data, topology and the associated computations accordingly. While the main purpose of subdivision surfaces is to use position data associated with the vertices to define a smooth, continuous limit surface, there are many cases where non-positional data is associated with a mesh. That data may often be interpolated smoothly like position, but often it is preferred to interpolate it linearly or even make it discontinuous along edges of the mesh. Texture coordinates and color are common examples here. Other than position, which is assigned to and associated with vertices, there are no constraints on how arbitrary data can or should be associated or interpolated. Texture coordinates, for example, can be assigned to create a completely smooth limit surface like the position, linearly interpolated across faces, or even made discontinuous between them. There are, however, consequences to consider -- both in terms of data management and performance -- which are described below as the terminology and techniques used to achieve each are defined. Separating Data from Topology While the topology of meshes used to store subdivision surfaces is arbitrarily complex and variable, the topology of the parametric patches that make up its limit surface are simple and fixed. Bicubic B-Spline and Bezier patches are both defined by a simple 4x4 grid of control points and a set of basis functions for each point that collectively form the resulting surface. For such a patch, the position at a given parametric location is the result of the combination of position data associated with its control points and the weights of the corresponding basis functions weights being the values of basis functions evaluated at a parametric location. The topology and the basis functions remain the same, so we can make use of the weights independent of the data. If the positions of the control points change, we can simply recombine the new position data with the weights that we just used and apply the same combination. The fixed topology of a parametric patch and two shapes resulting from two sets of positions. Similarly, for a piecewise surface, the position at a given parametric location is the result of the single patch containing that parametric location evaluated at the given position. The control points involved are the subset of control points associated with that particular patch. If the topology of the surface is fixed, so too is the topology of the collection of patches that comprise that surface. If the positions of those control points change, we can recombine the new position data with the same weights for the subset of points associated with the patch. More complex but fixed topology of a surface and two shapes resulting from two sets of positions. This holds for a piecewise surface of arbitrary topology. Regardless of how complex the topology, as long as it remains fixed i.e. relationships between vertices, edges and faces does not change or anything other settings affecting subdivision rules, the same techniques apply. This is just one example of the value of separating computations involving topology from those involving the data. Both subdivision and evaluation can be factored into steps involving topology computing the weights and combining the data separately. Three shapes resulting from three sets of positions for a mesh of fixed topology. When the topology is fixed, enormous savings are possible by pre-computing information associated with the topology and organizing the data associated with the control points in a way that can be efficiently combined with it. This is key to understanding some of the techniques used to process subdivision surfaces. For a mesh of arbitrary topology, the control points of the underlying surface are the vertices, and position data associated with them is most familiar. But there is nothing that requires that the control points of a patch have to represent position -- the same techniques apply regardless of the type of data involved. Vertex and Varying Data The most typical and fundamental operation is to evaluate a position on the surface, i.e. evaluate the underlying patches of the limit surface using the x,y,z positions at the vertices of the mesh. Given a parametric u,v location on one such patch, the data-independent evaluation method first computes the weights and then combines the x,y,z vertex positions resulting in an x,y,z position at that location. But the weights and their combination can be applied to any data at the vertices, e.g. color, texture coordinates or anything else. Data associated with the vertices that is interpolated this way, including position, is said to be vertex data or to have vertex interpolation. Specifying other data as vertex data will result in it being smoothly interpolated in exactly the same way using exactly the same weights as the position. So to capture a simple 2D projection of the surface for texture coordinates, 2D values matching the x,y of the positions would be used. If linear interpolation of data associated with vertices is desired instead, the data is said to be varying data or to have varying interpolation. Here the non-linear evaluation of the patches defining the smooth limit surface is ignored and weights for simple linear interpolation are used. This is a common choice for texture coordinates as evaluation of texture without the need of bicubic patches is computationally cheaper. The linear interpolation will not capture the smoothness required of a true projection between the vertices, but both vertex and varying interpolation have their uses. Projected texture smoothly interpolated from vertex data Projected texture linearly interpolated from varying data Since both vertex and varying data is associated with vertices a unique value assigned to each, the resulting surface will be continuous -- piecewise smooth in the case of vertex data and piecewise linear in the case of varying. Face-Varying Data and Topology In order to support discontinuities in data on the surface, unlike vertex and varying data, there must be multiple values associated with vertices, edges andor faces, in order for a discontinuity to exist. Discontinuities are made possible by assigning values to the corners of faces, similar to the way in which vertices are assigned to the corners of faces when defining the topology of the mesh. Recalling the assignment of vertices to faces Vertex indices are assigned to all corners of each face as part of mesh construction and are often referred to as the face-vertices of an individual face or the mesh. All face-vertices that share the same vertex index will be connected by that vertex and share the same vertex data associated with it. By assigning a different set of indices to the face-vertices -- indices not referring to the vertices but some set of data to be associated with the corners of each face -- corners that share the same vertex no longer need to share the same data value and the data can be made discontinuous between faces This method of associating data values with the face-vertices of the mesh is said to be assigning face-varying data for face-varying interpolation. An interpolated value will vary continuously within a face i.e. the patch of the limit surface associated with the face but not necessarily across the edges or vertices shared with adjacent faces. Disjoint face-varying UV regions applied to the limit surface The combination of associating data values not with the vertices the control points but the face corners, and the resulting data-dependent discontinuities that result, make this a considerably more complicated approach than vertex or varying. The added complexity of the data alone is reason to only use it when necessary, i.e. when discontinuities are desired and present. Part of the complexity of dealing with face-varying data and interpolation is the way in which the interpolation behavior can be defined. Where the data is continuous, the interpolation can be specified to be as smooth as the underlying limit surface of vertex data or simply linear as achieved with varying data. Where the data is discontinuous -- across interior edges and around vertices -- the discontinuities create boundaries for the data, and partition the underlying surface into disjoint regions. The interpolation along these boundaries can also be specified as smooth or linear in a number of ways many of which have a historical basis. A more complete description of the different linear interpolation options with face-varying data and interpolation is given later. These options make it possible to treat the data as either vertex or varying, but with the added presence of discontinuities. An essential point to remember with face-varying interpolation is that each set of data is free to have its own discontinuities -- this leads to each data set having both unique topology and size. The topology specified for a collection of face-varying data is referred to as a channel and is unique to face-varying interpolation. Unlike vertex and varying interpolation, which both associate a data value with a vertex, the number of values in a face-varying channel is not fixed by the number of vertices or faces. The number of indices assigned to the face-corners will be the same for all channels, but the number of unique values referred to by these indices may not. We can take advantage of the common mesh topology in areas where the data is continuous, but we lose some of those advantages around the discontinuities. This results in the higher complexity and cost of a face-varying channel compared to vertex or varying data. If the topology for a channel is fixed, though, similar techniques can be applied to factor computation related to the topology so that changes to the data can be processed efficiently. Schemes and Options While previous sections have described subdivision surfaces in more general terms, this section describes a number of common variations often referred to as extensions to the subdivision algorithms and the ways that they are represented in OpenSubdiv. The number and nature of the extensions here significantly complicate what are otherwise fairly simple subdivision algorithms. Historically applications have supported either a subset or have had varying implementations of the same feature. OpenSubdiv strives to provide a consistent and efficient implementation of this feature set. Given the varying presentations of some of these features elsewhere, the naming chosen by OpenSubdiv is emphasized here. Subdivision Schemes OpenSubdiv provides two well known subdivision surface types -- Catmull-Clark often referred to more tersely as Catmark and Loop subdivision. Catmull-Clark is more widely used and suited to quad-dominant meshes, while Loop is preferred for and requires purely triangulated meshes. The many examples from previous sections have illustrated the more popular Catmull-Clark scheme. For an example of Loop Boundary Interpolation Rules Boundary interpolation rules control how subdivision and the limit surface behave for faces adjacent to boundary edges and vertices. The following choices are available via the enumeration SdcOptionsVtxBoundaryInterpolation Mode Behavior VTX_BOUNDARY_NONE No boundary edge interpolation is applied by default boundary faces are tagged as holes so that the boundary vertices continue to support the adjacent interior faces, but no surface corresponding to the boundary faces is generated boundary faces can be selectively interpolated by sharpening all boundary edges incident the vertices of the face VTX_BOUNDARY_EDGE_ONLY A sequence of boundary vertices defines a smooth curve to which the limit surface along boundary faces extends VTX_BOUNDARY_EDGE_AND_CORNER Similar to edge-only but the smooth curve resulting on the boundary is made to interpolate corner vertices vertices with exactly one incident face On a grid example In practice, it is rare to use no boundary interpolation at all -- this feature has its uses in allowing separate meshes to be seamlessly joined together by replicating the vertices along boundaries, but these uses are limited. Given the global nature of the setting, it is usually preferable to explicitly make the boundary faces holes in the areas where surfaces from separate meshes are joined, rather than sharpening edges to interpolate the desired boundaries everywhere else. The remaining edge only and edge and corner choices are then solely distinguished by whether or not the surface at corner vertices is smooth or sharp. Face-varying Interpolation Rules Face-varying interpolation rules control how face-varying data is interpolated both in the interior of face-varying regions smooth or linear and at the boundaries where it is discontinuous constrained to be linear or pinned in a number of ways. Where the topology is continuous and the interpolation chosen to be smooth, the behavior of face-varying interpolation will match that of the vertex interpolation. Choices for face-varying interpolation are most commonly available in the context of UVs for texture coordinates and a number of names for such choices have evolved in different applications over the years. The choices offered by OpenSubdiv cover a wide range of popular applications. The feature is named face-varying linear interpolation -- rather than boundary interpolation commonly used -- to emphasize that it can be applied to the entire surface not just boundaries and that the effects are to make the surface behave more linearly in various ways. The following choices are available for the SdcOptionsFVarLinearInterpolation enum -- the ordering here applying progressively more linear constraints Mode Behavior FVAR_LINEAR_NONE smooth everywhere the mesh is smooth FVAR_LINEAR_CORNERS_ONLY linearly interpolate sharpen or pin corners only FVAR_LINEAR_CORNERS_PLUS1 CORNERS_ONLY sharpening of junctions of 3 or more regions FVAR_LINEAR_CORNERS_PLUS2 CORNERS_PLUS1 sharpening of darts and concave corners FVAR_LINEAR_BOUNDARIES linear interpolation along all boundary edges and corners FVAR_LINEAR_ALL linear interpolation everywhere boundaries and interior These rules cannot make the interpolation of the face-varying data smoother than that of the vertices. The presence of sharp features of the mesh created by sharpness values, boundary interpolation rules, or the subdivision scheme itself e.g. Bilinear take precedence. All face-varying interpolation modes illustrated in UV space using a simple 4x4 grid of quads segmented into three UV regions their control point locations implied by interpolation in the FVAR_LINEAR_ALL case For those familiar, this shape and its assigned UV sets are available for inspection in the catmark_fvar_bound1 shape of OpenSubdivs example and regression shapes. Semi-Sharp Creases Just as some types of parametric surfaces support additional shaping controls to affect creasing along the boundaries between surface elements, OpenSubdiv provides additional sharpness values or weights associated with edges and vertices to achieve similar results over arbitrary topology. Setting sharpness values to a maximum value 10 in this case -- a number chosen for historical reasons effectively modifies the subdivision rules so that the boundaries between the piecewise smooth surfaces are infinitely sharp or discontinuous. But since real world surfaces never really have infinitely sharp edges, especially when viewed sufficiently close, it is often preferable to set the sharpness lower than this value, making the crease semi-sharp. A constant weight value assigned to a sequence of edges connected edges therefore enables the creation of features akin to fillets and blends without adding extra rows of vertices though that technique still has its merits Sharpness values range from 0-10, with a value of 0 or less having no effect on the surface and a value of 10 or more making the feature completely sharp. It should be noted that infinitely sharp creases are really tangent discontinuities in the surface, implying that the geometric normals are also discontinuous there. Therefore, displacing along the normal will likely tear apart the surface along the crease. If you really want to displace a surface at a crease, it may be better to make the crease semi-sharp. Other Options While the preceding options represent features available in a wide-variety of tools and modeling formats, a few others exist whose recognition and adoption is more limited. In some cases, they offer improvements to undesirable behavior of the subdivision algorithms, but their effects are less than ideal. Given both their limited effectiveness and lack of recognition, these options should be used with caution. Chaikin Rule The Chaikin Rule is a variation of the semi-sharp creasing method that attempts to improve the appearance of creases along a sequence of connected edges when the sharpness values differ. This choice modifies the subdivision of sharpness values using Chaikins curve subdivision algorithm to consider all sharpness values of edges around a common vertex when determining the sharpness of child edges. The creasing method can be set using the values defined in the enumeration SdcOptionsCreasingMethod Mode Behavior CREASE_UNIFORM Apply regular semi-sharp crease rules CREASE_CHAIKIN Apply Chaikin semi-sharp crease rules Example of contiguous semi-sharp creases interpolation Triangle Subdivision Rule The triangle subdivision rule is a rule added to the Catmull-Clark scheme that modifies the behavior at triangular faces to improve the undesirable surface artefacts that often result in such areas. Mode Behavior TRI_SUB_CATMARK Default Catmark scheme weights TRI_SUB_SMOOTH Smooth triangle weights Cylinder example This rule was empirically determined to make triangles subdivide more smoothly. However, this rule breaks the nice property that two separate meshes can be joined seamlessly by overlapping their boundaries i.e. when there are triangles at either boundary, it is impossible to join the meshes seamlessly Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "sdc_overview.html" │ │ │ │ │ + "loc": "subdivision_surfaces.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "Tutorials", │ │ │ │ │ "text": "Tutorials Tutorials 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Bfr Tutorials 1. Basic Evaluation and Tessellation Tutorial 1.1 Tutorial 1.2 Tutorial 1.3 Tutorial 1.4 Tutorial 1.5 2. More on Tessellation Tutorial 2.1 Tutorial 2.2 3. Additional Topics Tutorial 3.1 Tutorial 3.2 Far Tutorials 1. Basic Construction and Interpolation Tutorial 1.1 Tutorial 1.2 2. Uniform Refinement and Primvar Data Types Tutorial 2.1 Tutorial 2.2 Tutorial 2.3 3. Creating a Custom FarTopologyRefinerFactory Tutorial 3.1 4. Construction and Usage of FarStencilTables Tutorial 4.1 Tutorial 4.2 Tutorial 4.3 5. Construction and Usage of FarPatchTables Tutorial 5.1 Tutorial 5.2 Tutorial 5.3 Osd Tutorials Tutorial 0 Hbr Tutorials Tutorial 0 Tutorial 1 Tutorial 2 The tutorial source code can be found in the github.com repository or in your local repository roottutorials . Bfr Tutorials All tutorials for the Bfr interface follow a similar pattern without any command line arguments, a default mesh usually a cube is used and the results printed to standard output in Obj format. Command line arguments can be used to specify an alternate mesh for input, as well as directing the output to a specified Obj file. Some tutorials may offer additional command line options to trigger internal options relevant to the topic, e.g. those illustrating tessellation may support a -quads option to use the option to tessellate quad-bases subdivision meshes with quads. 1. Basic Evaluation and Tessellation Tutorial 1.1 This tutorial illustrates the use of BfrSurfaceFactory and BfrSurface to evaluate points on the limit of each face. The limit positions at all corners of the face are evaluated and connected to the limit position in the center of the face -- creating a simple triangular tessellation. code Tutorial 1.2 This tutorial shows the added use of BfrTessellation to identify the set of points and connectivity for a uniform tessellation. Both a Surface and Tessellation is identified for each face, with the Tessellation indicating which points are to be evaluated by the Surface. code Tessellation patterns for quad-based subdivision schemes can optionally preserve quads left or be fully triangulated center, while triangular schemes always yield triangles right Tutorial 1.3 This tutorial extends the previous tutorial on uniform Tessellation by adding face-varying Surfaces to compute corresponding UVs for each evaluated position. code Tutorial 1.4 This tutorial extends the previous tutorial on uniform tessellation of position and UV by illustrating how additional mesh data interleaved with the position and UV data is easily handled. code Tutorial 1.5 This tutorial is similar to the first tutorial showing uniform tessellation of position but makes use of limit stencils for its evaluation of points of the tessellation pattern. code 2. More on Tessellation Tutorial 2.1 This tutorial extends the use of Tessellation to illustrate the use of non-uniform tessellation rates per edge. A simple edge-length metric is used to determine the tessellation rate for each edge of a face. code The following contrasts uniform tessellation left with the resulting length-based tessellations -- preserving quads center and fully triangulated right Tutorial 2.2 This tutorial is a more complex extension of the use of Tessellation that illustrates how the separation and association of tessellation data with the boundary and interior of the face can be used. Limit points evaluated on the vertices and edges of a face the boundary of the Tessellation are computed once and shared with adjacent faces -- creating a topologically watertight tessellation of the mesh. code 3. Additional Topics Tutorial 3.1 This tutorial shows a basic example of the more advanced topic of creating a subclass of SurfaceFactory adapted to a connected mesh representation -- requiring an implementation of the SurfaceFactoryMeshAdapter interface for that mesh. A simplified version of the implementation of FarTopologyRefiner is provided. Note that the code imported here is that of the main program, not the separate header and source files of the custom subclass illustrated -- which current documentation scripts cannot import. Tutorial 3.2 This tutorial shows how to initialize and retain Surfaces for later use. The simple uniform tessellation tutorial is modified to first create and populate a simple caching structure that initializes and stores the Surfaces for all faces of the mesh. The loop for each face of the mesh then retrieves its Surface and associated patch points from the cache. code Far Tutorials 1. Basic Construction and Interpolation Tutorial 1.1 This tutorial presents the requisite steps to instantiate a mesh as a FarTopologyRefiner from simple topological data and to interpolate vertex data associated with the mesh. code Tutorial 1.2 This tutorial makes use of a different vertex data definition for use when vertex data is of arbitrary width. Uniform refinement is applied to data buffers of three types two of fixed but different sizes and the third a union of the two that is dynamically sized and constructed. code 2. Uniform Refinement and Primvar Data Types Tutorial 2.1 Building on the basic tutorial, this example shows how to instantiate a simple mesh, refine it uniformly and then interpolate both vertex and varying primvar data. code Tutorial 2.2 Building on the previous tutorial, this example shows how to instantiate a simple mesh, refine it uniformly and then interpolate both vertex and face-varying primvar data. The resulting interpolated data is output in Obj format, with the face-varying data recorded in the UV texture layout. code Tutorial 2.3 Building on previous tutorials, this example shows how to instantiate a simple mesh, refine it uniformly, interpolate both vertex and face-varying primvar data, and finally calculate approximated smooth normals. The resulting interpolated data is output in Obj format. code 3. Creating a Custom FarTopologyRefinerFactory Tutorial 3.1 Previous tutorials have instantiated topology from a simple face-vertex list via the FarTopologyDescriptor and its TopologyRefinerFactory. This tutorial shows how to more efficiently convert an existing high-level topology representation to a FarTopologyDescriptor with a custom factory class. code 4. Construction and Usage of FarStencilTables Tutorial 4.1 This tutorial shows how to create and manipulate a StencilTable. Factorized stencils are used to efficiently interpolate vertex primvar data buffers. code Tutorial 4.2 This tutorial shows how to create and manipulate StencilTables for both vertex and varying primvar data buffers vertex positions and varying colors. code Tutorial 4.3 This tutorial shows how to create and manipulate tables of cascading stencils to apply hierarchical vertex edits. code 5. Construction and Usage of FarPatchTables Tutorial 5.1 This tutorial shows how to compute points on the limit surface at arbitrary parametric locations using a FarPatchTable constructed from adaptive refinement. code Tutorial 5.2 Building on the previous tutorial, this example shows how to manage the limit surface of a potentially large mesh by creating and evaluating separate PatchTables for selected groups of faces of the mesh. code Tutorial 5.3 Building on the previous tutorials for both PatchTables and StencilTables, this example shows how to construct a LimitStencilTable to repeatedly evaluate an arbitrary collection of points on the limit surface. code Osd Tutorials Tutorial 0 This tutorial demonstrates the manipulation of Osd Evaluator and BufferDescriptor. code Hbr Tutorials Use of Hbr is no longer recommended -- these tutorials are included solely for historical reference. Tutorial 0 This tutorial presents, in a very succinct way, the requisite steps to instantiate an Hbr mesh from simple topological data. code Tutorial 1 This tutorial shows how to safely create Hbr meshes from arbitrary topology. Because Hbr is a half-edge data structure, it cannot represent non-manifold topology. Ensuring that the geometry used is manifold is a requirement to use Hbr safely. This tutorial presents some simple tests to detect inappropriate topology. code Tutorial 2 This tutorial shows how to subdivide uniformly a simple Hbr mesh. We are building upon previous tutorials and assuming a fully instantiated mesh we start with an HbrMesh pointer initialized from the same pyramid shape used in hbr_tutorial_0. We then apply the Refine function sequentially to all the faces in the mesh to generate several levels of uniform subdivision. The resulting data is then dumped to the terminal in Wavefront OBJ format for inspection. code Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "tutorials.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Subdivision Surfaces", │ │ │ │ │ - "text": "Subdivision Surfaces Subdivision Surfaces 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Overview Piecewise Parametric Surfaces Parametric Patches Piecewise Surfaces Arbitrary Topology Regular versus Irregular Features Non-manifold Topology Subdivision versus Tessellation Subdivision Tessellation Which to Use Mesh Data and Topology Separating Data from Topology Vertex and Varying Data Face-Varying Data and Topology Schemes and Options Subdivision Schemes Boundary Interpolation Rules Face-varying Interpolation Rules Semi-Sharp Creases Other Options Chaikin Rule Triangle Subdivision Rule Overview Subdivision surfaces are a common modeling primitive that has gained popularity in animation and visual effects over the past decades. As the name suggests, subdivision surfaces are fundamentally surfaces . More specifically, subdivision surfaces are piecewise parametric surfaces defined over meshes of arbitrary topology -- both concepts that will be described in the sections that follow. Subdivision is both an operation that can be applied to a polygonal mesh to refine it, and a mathematical tool that defines the underlying smooth surface to which repeated subdivision of the mesh converges. Explicit subdivision is simple to apply some number of times to provide a smoother mesh, and that simplicity has historically lead to many tools representing the shape this way. In contrast, deriving the smooth surface that ultimately defines the shape -- its limit surface -- is considerably more complex but provides greater accuracy and flexibility. These differences have led to confusion in how some tools expose subdivision surfaces. The ultimate goal is to have all tools use subdivision surfaces as true surface primitives. The focus here is therefore less on subdivision and more on the nature of the surface that results from it. In addition to providing a consistent implementation of subdivision -- one that includes a number of widely used feature extensions -- a significant value of OpenSubdiv is that it makes the limit surface more accessible. Since its introduction, OpenSubdiv has received interest from users and developers with a wide variety of skills, interests and backgrounds. This document is intended to present subdivision surfaces from a perspective helpful in making use of OpenSubdiv. One purpose it serves is to provide a high level overview for those with less experience with the algorithms or mathematics of subdivision. The other is to provide an overview of the feature set available with OpenSubdiv, and to introduce those capabilities with the terminology used by OpenSubdiv as much of it is overloaded. Piecewise Parametric Surfaces Piecewise parametric surfaces are arguably the most widely used geometric representation in industrial design, entertainment and many other areas. Many of the objects we deal with everyday -- cars, mobile phones, laptops -- were all designed and visualized first as piecewise parametric surfaces before those designs were approved and pursued. Piecewise parametric surfaces are ultimately just collections of simpler modeling primitives referred to as patches. Patches constitute the pieces of the larger surface in much the same way as a face or polygon constitutes a piece of a polygonal mesh. Parametric Patches Patches are the building blocks of piecewise smooth surfaces, and many different kinds of patches have evolved to meet the needs of geometric modeling. Two of the more effective and common patches are illustrated below Single bicubic B-Spline patch Single bicubic Bezier patch Patches consist of a set of points or vertices that affect a rectangular piece of smooth surface triangular patches also exist. That rectangle is parameterized in its two directions, transforming a simple 2D rectangle into the 3D surface u,v 2D domain of a patch Mapping from u,v to x,y,z The points that control the shape of the surface are usually referred to as control points or control vertices, and the collection of the entire set defining a patch as the control mesh, the control hull, the control cage or simply the hull, the cage, etc. For the sake of brevity we will frequently use the term cage, which serves us more generally later. So a patch essentially consist of two entities its control points and the surface affected by them. The way the control points affect the surface is what makes the different types of patches unique. Even patches defined by the same number of points can have different behavior. Note that all 16 points of the B-Spline patch above are relatively far from the surface they define compared to the similar Bezier patch. The two patches in that example actually represent exactly the same piece of surface -- each with a set of control points having different effects on it. In mathematical terms, each control point has a basis function associated with it that affects the surface in a particular way when only that point is moved Bicubic B-Spline basis function Bicubic Bezier basis funciton It is these basis functions that often give rise to the names of the different patches. There are pros and cons to these different properties of the control points of patches, which become more apparent as we assemble patches into piecewise surfaces. Piecewise Surfaces Piecewise parametric surfaces are collections of patches. For rectangular patches, one of the simplest ways to construct a collection is to define a set of patches using a rectangular grid of control points Piecewise B-Spline surface Piecewise Bezier surface Note that we can overlap the points of adjacent B-spline patches. This overlapping means that moving one control point affects multiple patches -- but it also ensures that those patches always meet smoothly this was a design intention and not true for other patch types. Adjacent Bezier patches only share points at their boundaries and coordinating the points across those boundaries to keep the surface smooth is possible, but awkward. This makes B-splines a more favorable surface representation for interactive modeling, but Bezier patches serve many other useful purposes. A more complicated B-spline surface Part of a more complicated B-Spline surface Just as a patch consisted of a cage and a surface, the same is now true of the collection. The control cage is manipulated by a designer and the surface of each of the patches involved is displayed so they can assess its effect. Arbitrary Topology Piecewise surfaces discussed thus far have been restricted to collections of patches over regular grids of control points. There is a certain simplicity with rectangular parametric surfaces that is appealing, but a surface representation that supports arbitrary topology has many other advantages. Rectangular parametric surfaces gained widespread adoption despite their topological limitations, and their popularity continues today in some areas. Complex objects often need many such surfaces to represent them and a variety of techniques have evolved to assemble them effectively, including stitching multiple surfaces together or cutting holes into them trimming. These are complicated techniques, and while effective in some contexts e.g. industrial design they become cumbersome in others e.g. animation and visual effects. A single polygonal mesh can represent shapes with far more complexity than a single rectangular piecewise surface, but its faceted nature eventually becomes a problem. Subdivision surfaces combine the topological flexibility of polygonal meshes with the underlying smoothness of piecewise parametric surfaces. Just as rectangular piecewise parametric surfaces have a collection of control points its cage stored as a grid and an underlying surface, subdivision surfaces also have a collection of control points its cage stored as a mesh and an underlying surface often referred as its limit surface. Regular versus Irregular Features A mesh contains the vertices and faces that form the cage for the underlying surface, and the topology of that mesh can be arbitrarily complex. In areas where the faces and vertices of the mesh are connected to form rectangular grids, the limit surface becomes one of the rectangular piecewise parametric surfaces previously mentioned. These regions of the mesh are said to be regular they provide behavior familiar from the use of similar rectangular surfaces and their limit surface is relatively simple to deal with. All other areas are considered irregular they provide the desired topological flexibility and so are less familiar and less predictable in some cases and their limit surface can be much more complicated. Irregular features come in a number of forms. The most widely referred to is an extra-ordinary vertex, i.e. a vertex which, in the case of a quad subdivision scheme like Catmull-Clark, does not have four incident faces. Irregular vertex and incident faces Regular and irregular regions of the surface The presence of these irregular features makes the limit surface around them similarly irregular, i.e. it cannot be represented as simply as it can for regular regions. Its worth noting that irregular regions shrink in size and become more isolated as subdivision is applied. A face with a lot of extra-ordinary vertices around it makes for a very complicated surface, and isolating these features is a way to help deal with that complexity Two valence-5 vertices nearby Isolation subdivided once Isolation subdivided twice Its generally necessary to perform some kind of local subdivision in these areas to break these pieces of surface into smaller, more manageable pieces, and the term feature adaptive subdivision has become popular in recent years to describe this process. Whether this is done explicitly or implicitly, globally or locally, what matters most is that there is an underlying piece of limit surface for each face -- albeit a potentially complicated one at an irregular feature -- that can be evaluated in much the same way as rectangular piecewise surfaces. Patches of the regular regions Patches of the irregular region While supporting a smooth surface in these irregular areas is the main advantage of subdivision surfaces, both the complexity of the resulting surfaces and their quality are reasons to use them with care. When the topology is largely irregular, there is a higher cost associated with its surface, so minimizing irregularities is advantageous. And in some cases the surface quality, i.e. the perceived smoothness, of the irregular surfaces can lead to undesirable artefacts. An arbitrary polygonal mesh will often not make a good subdivision cage, regardless of how good that polygonal mesh appears. As with rectangular piecewise parametric surfaces, the cage should be shaped to affect the underlying surface it is intended to represent. See Modeling Tips for related recommendations. Non-manifold Topology Since the cage of a subdivision surface is stored in a mesh, and often manipulated in the same context as polygonal meshes, the topic of manifold versus non-manifold topology warrants some attention. There are many definitions or descriptions of what distinguishes a manifold mesh from one that is not. These range from concise but abstract mathematical definitions to sets of examples showing manifold and non-manifold meshes -- all have their value and an appropriate audience. The following is not a strict definition but serves well to illustrate most local topological configurations that cause a mesh to be non-manifold. Consider standing on the faces of a mesh and walking around each vertex in turn. Assuming a right-hand winding order of faces, stand on the side of the face in the positive normal direction. And when walking, step across each incident edge in a counter-clockwise direction to the next incident face. For an interior vertex start at the corner of any incident face walk around the vertex across each incident edge to the next unvisited face repeat if you arrive back where you started and any incident faces or edges were not visited, the mesh is non-manifold Similarly, for a boundary vertex start at the corner of the face containing the leading boundary edge walk around the vertex across each incident edge to the next unvisited face repeat if you arrive at another boundary edge and any incident faces or edges were not visited, the mesh is non-manifold If you can walk around all vertices this way and dont encounter any non-manifold features, the mesh is likely manifold. Obviously if a vertex has no faces, there is nothing to walk around and this test cant succeed, so it is again non-manifold. All of the faces around a vertex should also be in the same orientation, otherwise two adjacent faces have normals in opposite directions and the mesh will be considered non-manifold, so we should really include that constraint when stepping to the next face to be more strict. Consider walking around the indicated vertices of the following non-manifold meshes Edges with 2 incident faces Faces sharing a vertex but no edges As mentioned earlier, many tools do not support non-manifold meshes, and in some contexts, e.g. 3D printing, they should be strictly avoided. Sometimes a manifold mesh may be desired and enforced as an end result, but the mesh may temporarily become non-manifold due to a particular sequence of modeling operations. Rather than supporting or advocating the use of non-manifold meshes, OpenSubdiv strives to be robust in the presence of non-manifold features to simplify the usage of its clients -- sparing them the need for topological analysis to determine when OpenSubdiv can or cannot be used. Although subdivision rules are not as well standardized in areas where the mesh is not manifold, OpenSubdiv provides simple rules and a reasonable limit surface in most cases. Surface around edges with 2 incident faces Surface for faces sharing a vertex but no edges As with the case of regular versus irregular features, since every face has a corresponding piece of surface associated with it -- whether locally manifold or not -- the term arbitrary topology can be said to include non-manifold topology. Subdivision versus Tessellation The preceding sections illustrate subdivision surfaces as piecewise parametric surfaces of arbitrary topology. As piecewise parametric surfaces, they consist of a cage and the underlying surface defined by that cage. Two techniques used to display subdivision surfaces are subdivision and tessellation. Both have their legitimate uses, but there is an important distinction between them subdivision operates on a cage and produces a refined cage tessellation operates on a surface and produces a discretization of that surface The existence and relative simplicity of the subdivision algorithm makes it easy to apply repeatedly to approximate the shape of the surface, but with the result being a refined cage, that approximation is not always very accurate. When compared to a cage refined to a different level, or a tessellation that uses points evaluated directly on the limit surface, the discrepancies can be confusing. Subdivision Subdivision is the process that gives subdivision surfaces their name, but it is not unique to them. Being piecewise parametric surfaces, lets first look at subdivision in the context of the simpler parametric patches that comprise them. Subdivision is a special case of refinement , which is key to the success of some of the most widely used types of parametric patches and their aggregate surfaces. A surface can be refined when an algorithm exists such that more control points can be introduced while keeping the shape of the surface exactly the same . For interactive and design purposes, this allows a designer to introduce more resolution for finer control without introducing undesired side effects in the shape. For more analytical purposes, it allows the surface to be broken into pieces, often adaptively, while being faithful to the original shape. One reason why both B-spline and Bezier patches are so widely used is that both of them can be refined. Uniform subdivision -- the process of splitting each of the patches in one or both of its directions -- is a special case of refinement that both of these patch types support B-Spline surface and its cage Cage subdivided 1x Cage subdivided 2x In the cases illustrated above for B-Splines, the uniformly refined cages produce the same limit surface as the original granted in more pieces. So it is fair to say that both uniform B-splines and Bezier surfaces are subdivision surfaces. The limit surface remains the same with the many more control points roughly 4x with each iteration of subdivision, and those points are closer to but not on the surface. It may be tempting to use these new control points to represent the surface, but using the same number of points evaluated at corresponding uniformly spaced parametric locations on the surface is usually simpler and more effective. Note also that points of the cage typically do not have any normal vectors associated with them, though we can evaluate normals explicitly for arbitrary locations on the surface just as we do for position. So if displaying a cage as a shaded surface, normal vectors at each of the control points must be contrived. Both the positions and normals of the points on the finer cage are therefore both approximations. For more general subdivision surfaces, the same is true. Subdivision will refine a mesh of arbitrary topology, but the resulting points will not lie on the limit surface and any normal vectors contrived from and associated with these points will only be approximations to those of the limit surface. Tessellation There is little need to use subdivision to approximate a parametric surface when it can be computed directly, i.e. it can be tessellated. We can evaluate at arbitrary locations on the surface and connect the resulting points to form a tessellation -- a discretization of the limit surface -- that is far more flexible than the results achieved from uniform subdivision Uniform 3x3 tessellation of B-spline surface Curvature-adaptive tessellation of B-spline surface For a simple parametric surface, the direct evaluation of the limit surface is also simple, but for more complicated subdivision surfaces of arbitrary topology, this is less the case. The lack of a clear understanding of the relationship between the limit surface and the cage has historically lead to many applications avoiding tessellation. Its worth mentioning that subdivision can be used to generate a tessellation even when the limit surface is not available for direct evaluation. The recursive nature of subdivision does give rise to formulae that allow a point on the limit surface to be computed that corresponds to each point of the cage. This process is often referred to as snapping or pushing the points of the cage onto the limit surface. Subdivided 1x and snapped to limit surface Subdivided 2x and snapped to limit surface Since the end result is a connected set of points on the limit surface, this forms a tessellation of the limit surface, and we consider it a separate process to subdivision though it does make use of it. The fact that such a tessellation might have been achieved using subdivision is indistinguishable from the final result -- the same tessellation might just as easily have been generated by evaluating limit patches of the cage uniformly 2x, 4x, 8x, etc. along each edge. Which to Use Subdivision is undeniably useful in creating finer cages to manipulate the surface, but tessellation is preferred for displaying the surface when the patches are available for direct evaluation. There was a time when global refinement was pursued in limited circles as a way of rapidly evaluating parametric surfaces along isoparametric lines, but patch evaluation, i.e. tessellation, generally prevails. Considerable confusion has arisen due the way the two techniques have been employed and presented when displaying the shape in end-user applications. One can argue that if an application displays a representation of the surface that is satisfactory for its purposes, then it is not necessary to burden the user with additional terminology and choices. But when two representations of the same surface differ considerably between two applications, the lack of any explanation or control leads to confusion. As long as applications make different choices on how to display the surface, we seek a balance between simplicity and control. Since subdivided points do not lie on the limit surface, it is important to make it clear to users when subdivision is being used instead of tessellation. This is particularly true in applications where the cage and the surface are displayed in the same style as there is no visual cue for users to make that distinction. Mesh Data and Topology The ability of subdivision surfaces to support arbitrary topology leads to the use of meshes to store both the topology of the cage and the data values associated with its control points, i.e. its vertices. The shape of a mesh, or the subdivision surface that results from it, is a combination of the topology of the mesh and the position data associated with its vertices. When dealing with meshes there are advantages to separating the topology from the data, and this is even more important when dealing with subdivision surfaces. The shape referred to above is not just the shape of the mesh the cage in this case but could be the shape of a refined cage or the limit surface. By observing the roles that both the data and topology play in operations such as subdivision and evaluation, significant advantages can be gained by managing data, topology and the associated computations accordingly. While the main purpose of subdivision surfaces is to use position data associated with the vertices to define a smooth, continuous limit surface, there are many cases where non-positional data is associated with a mesh. That data may often be interpolated smoothly like position, but often it is preferred to interpolate it linearly or even make it discontinuous along edges of the mesh. Texture coordinates and color are common examples here. Other than position, which is assigned to and associated with vertices, there are no constraints on how arbitrary data can or should be associated or interpolated. Texture coordinates, for example, can be assigned to create a completely smooth limit surface like the position, linearly interpolated across faces, or even made discontinuous between them. There are, however, consequences to consider -- both in terms of data management and performance -- which are described below as the terminology and techniques used to achieve each are defined. Separating Data from Topology While the topology of meshes used to store subdivision surfaces is arbitrarily complex and variable, the topology of the parametric patches that make up its limit surface are simple and fixed. Bicubic B-Spline and Bezier patches are both defined by a simple 4x4 grid of control points and a set of basis functions for each point that collectively form the resulting surface. For such a patch, the position at a given parametric location is the result of the combination of position data associated with its control points and the weights of the corresponding basis functions weights being the values of basis functions evaluated at a parametric location. The topology and the basis functions remain the same, so we can make use of the weights independent of the data. If the positions of the control points change, we can simply recombine the new position data with the weights that we just used and apply the same combination. The fixed topology of a parametric patch and two shapes resulting from two sets of positions. Similarly, for a piecewise surface, the position at a given parametric location is the result of the single patch containing that parametric location evaluated at the given position. The control points involved are the subset of control points associated with that particular patch. If the topology of the surface is fixed, so too is the topology of the collection of patches that comprise that surface. If the positions of those control points change, we can recombine the new position data with the same weights for the subset of points associated with the patch. More complex but fixed topology of a surface and two shapes resulting from two sets of positions. This holds for a piecewise surface of arbitrary topology. Regardless of how complex the topology, as long as it remains fixed i.e. relationships between vertices, edges and faces does not change or anything other settings affecting subdivision rules, the same techniques apply. This is just one example of the value of separating computations involving topology from those involving the data. Both subdivision and evaluation can be factored into steps involving topology computing the weights and combining the data separately. Three shapes resulting from three sets of positions for a mesh of fixed topology. When the topology is fixed, enormous savings are possible by pre-computing information associated with the topology and organizing the data associated with the control points in a way that can be efficiently combined with it. This is key to understanding some of the techniques used to process subdivision surfaces. For a mesh of arbitrary topology, the control points of the underlying surface are the vertices, and position data associated with them is most familiar. But there is nothing that requires that the control points of a patch have to represent position -- the same techniques apply regardless of the type of data involved. Vertex and Varying Data The most typical and fundamental operation is to evaluate a position on the surface, i.e. evaluate the underlying patches of the limit surface using the x,y,z positions at the vertices of the mesh. Given a parametric u,v location on one such patch, the data-independent evaluation method first computes the weights and then combines the x,y,z vertex positions resulting in an x,y,z position at that location. But the weights and their combination can be applied to any data at the vertices, e.g. color, texture coordinates or anything else. Data associated with the vertices that is interpolated this way, including position, is said to be vertex data or to have vertex interpolation. Specifying other data as vertex data will result in it being smoothly interpolated in exactly the same way using exactly the same weights as the position. So to capture a simple 2D projection of the surface for texture coordinates, 2D values matching the x,y of the positions would be used. If linear interpolation of data associated with vertices is desired instead, the data is said to be varying data or to have varying interpolation. Here the non-linear evaluation of the patches defining the smooth limit surface is ignored and weights for simple linear interpolation are used. This is a common choice for texture coordinates as evaluation of texture without the need of bicubic patches is computationally cheaper. The linear interpolation will not capture the smoothness required of a true projection between the vertices, but both vertex and varying interpolation have their uses. Projected texture smoothly interpolated from vertex data Projected texture linearly interpolated from varying data Since both vertex and varying data is associated with vertices a unique value assigned to each, the resulting surface will be continuous -- piecewise smooth in the case of vertex data and piecewise linear in the case of varying. Face-Varying Data and Topology In order to support discontinuities in data on the surface, unlike vertex and varying data, there must be multiple values associated with vertices, edges andor faces, in order for a discontinuity to exist. Discontinuities are made possible by assigning values to the corners of faces, similar to the way in which vertices are assigned to the corners of faces when defining the topology of the mesh. Recalling the assignment of vertices to faces Vertex indices are assigned to all corners of each face as part of mesh construction and are often referred to as the face-vertices of an individual face or the mesh. All face-vertices that share the same vertex index will be connected by that vertex and share the same vertex data associated with it. By assigning a different set of indices to the face-vertices -- indices not referring to the vertices but some set of data to be associated with the corners of each face -- corners that share the same vertex no longer need to share the same data value and the data can be made discontinuous between faces This method of associating data values with the face-vertices of the mesh is said to be assigning face-varying data for face-varying interpolation. An interpolated value will vary continuously within a face i.e. the patch of the limit surface associated with the face but not necessarily across the edges or vertices shared with adjacent faces. Disjoint face-varying UV regions applied to the limit surface The combination of associating data values not with the vertices the control points but the face corners, and the resulting data-dependent discontinuities that result, make this a considerably more complicated approach than vertex or varying. The added complexity of the data alone is reason to only use it when necessary, i.e. when discontinuities are desired and present. Part of the complexity of dealing with face-varying data and interpolation is the way in which the interpolation behavior can be defined. Where the data is continuous, the interpolation can be specified to be as smooth as the underlying limit surface of vertex data or simply linear as achieved with varying data. Where the data is discontinuous -- across interior edges and around vertices -- the discontinuities create boundaries for the data, and partition the underlying surface into disjoint regions. The interpolation along these boundaries can also be specified as smooth or linear in a number of ways many of which have a historical basis. A more complete description of the different linear interpolation options with face-varying data and interpolation is given later. These options make it possible to treat the data as either vertex or varying, but with the added presence of discontinuities. An essential point to remember with face-varying interpolation is that each set of data is free to have its own discontinuities -- this leads to each data set having both unique topology and size. The topology specified for a collection of face-varying data is referred to as a channel and is unique to face-varying interpolation. Unlike vertex and varying interpolation, which both associate a data value with a vertex, the number of values in a face-varying channel is not fixed by the number of vertices or faces. The number of indices assigned to the face-corners will be the same for all channels, but the number of unique values referred to by these indices may not. We can take advantage of the common mesh topology in areas where the data is continuous, but we lose some of those advantages around the discontinuities. This results in the higher complexity and cost of a face-varying channel compared to vertex or varying data. If the topology for a channel is fixed, though, similar techniques can be applied to factor computation related to the topology so that changes to the data can be processed efficiently. Schemes and Options While previous sections have described subdivision surfaces in more general terms, this section describes a number of common variations often referred to as extensions to the subdivision algorithms and the ways that they are represented in OpenSubdiv. The number and nature of the extensions here significantly complicate what are otherwise fairly simple subdivision algorithms. Historically applications have supported either a subset or have had varying implementations of the same feature. OpenSubdiv strives to provide a consistent and efficient implementation of this feature set. Given the varying presentations of some of these features elsewhere, the naming chosen by OpenSubdiv is emphasized here. Subdivision Schemes OpenSubdiv provides two well known subdivision surface types -- Catmull-Clark often referred to more tersely as Catmark and Loop subdivision. Catmull-Clark is more widely used and suited to quad-dominant meshes, while Loop is preferred for and requires purely triangulated meshes. The many examples from previous sections have illustrated the more popular Catmull-Clark scheme. For an example of Loop Boundary Interpolation Rules Boundary interpolation rules control how subdivision and the limit surface behave for faces adjacent to boundary edges and vertices. The following choices are available via the enumeration SdcOptionsVtxBoundaryInterpolation Mode Behavior VTX_BOUNDARY_NONE No boundary edge interpolation is applied by default boundary faces are tagged as holes so that the boundary vertices continue to support the adjacent interior faces, but no surface corresponding to the boundary faces is generated boundary faces can be selectively interpolated by sharpening all boundary edges incident the vertices of the face VTX_BOUNDARY_EDGE_ONLY A sequence of boundary vertices defines a smooth curve to which the limit surface along boundary faces extends VTX_BOUNDARY_EDGE_AND_CORNER Similar to edge-only but the smooth curve resulting on the boundary is made to interpolate corner vertices vertices with exactly one incident face On a grid example In practice, it is rare to use no boundary interpolation at all -- this feature has its uses in allowing separate meshes to be seamlessly joined together by replicating the vertices along boundaries, but these uses are limited. Given the global nature of the setting, it is usually preferable to explicitly make the boundary faces holes in the areas where surfaces from separate meshes are joined, rather than sharpening edges to interpolate the desired boundaries everywhere else. The remaining edge only and edge and corner choices are then solely distinguished by whether or not the surface at corner vertices is smooth or sharp. Face-varying Interpolation Rules Face-varying interpolation rules control how face-varying data is interpolated both in the interior of face-varying regions smooth or linear and at the boundaries where it is discontinuous constrained to be linear or pinned in a number of ways. Where the topology is continuous and the interpolation chosen to be smooth, the behavior of face-varying interpolation will match that of the vertex interpolation. Choices for face-varying interpolation are most commonly available in the context of UVs for texture coordinates and a number of names for such choices have evolved in different applications over the years. The choices offered by OpenSubdiv cover a wide range of popular applications. The feature is named face-varying linear interpolation -- rather than boundary interpolation commonly used -- to emphasize that it can be applied to the entire surface not just boundaries and that the effects are to make the surface behave more linearly in various ways. The following choices are available for the SdcOptionsFVarLinearInterpolation enum -- the ordering here applying progressively more linear constraints Mode Behavior FVAR_LINEAR_NONE smooth everywhere the mesh is smooth FVAR_LINEAR_CORNERS_ONLY linearly interpolate sharpen or pin corners only FVAR_LINEAR_CORNERS_PLUS1 CORNERS_ONLY sharpening of junctions of 3 or more regions FVAR_LINEAR_CORNERS_PLUS2 CORNERS_PLUS1 sharpening of darts and concave corners FVAR_LINEAR_BOUNDARIES linear interpolation along all boundary edges and corners FVAR_LINEAR_ALL linear interpolation everywhere boundaries and interior These rules cannot make the interpolation of the face-varying data smoother than that of the vertices. The presence of sharp features of the mesh created by sharpness values, boundary interpolation rules, or the subdivision scheme itself e.g. Bilinear take precedence. All face-varying interpolation modes illustrated in UV space using a simple 4x4 grid of quads segmented into three UV regions their control point locations implied by interpolation in the FVAR_LINEAR_ALL case For those familiar, this shape and its assigned UV sets are available for inspection in the catmark_fvar_bound1 shape of OpenSubdivs example and regression shapes. Semi-Sharp Creases Just as some types of parametric surfaces support additional shaping controls to affect creasing along the boundaries between surface elements, OpenSubdiv provides additional sharpness values or weights associated with edges and vertices to achieve similar results over arbitrary topology. Setting sharpness values to a maximum value 10 in this case -- a number chosen for historical reasons effectively modifies the subdivision rules so that the boundaries between the piecewise smooth surfaces are infinitely sharp or discontinuous. But since real world surfaces never really have infinitely sharp edges, especially when viewed sufficiently close, it is often preferable to set the sharpness lower than this value, making the crease semi-sharp. A constant weight value assigned to a sequence of edges connected edges therefore enables the creation of features akin to fillets and blends without adding extra rows of vertices though that technique still has its merits Sharpness values range from 0-10, with a value of 0 or less having no effect on the surface and a value of 10 or more making the feature completely sharp. It should be noted that infinitely sharp creases are really tangent discontinuities in the surface, implying that the geometric normals are also discontinuous there. Therefore, displacing along the normal will likely tear apart the surface along the crease. If you really want to displace a surface at a crease, it may be better to make the crease semi-sharp. Other Options While the preceding options represent features available in a wide-variety of tools and modeling formats, a few others exist whose recognition and adoption is more limited. In some cases, they offer improvements to undesirable behavior of the subdivision algorithms, but their effects are less than ideal. Given both their limited effectiveness and lack of recognition, these options should be used with caution. Chaikin Rule The Chaikin Rule is a variation of the semi-sharp creasing method that attempts to improve the appearance of creases along a sequence of connected edges when the sharpness values differ. This choice modifies the subdivision of sharpness values using Chaikins curve subdivision algorithm to consider all sharpness values of edges around a common vertex when determining the sharpness of child edges. The creasing method can be set using the values defined in the enumeration SdcOptionsCreasingMethod Mode Behavior CREASE_UNIFORM Apply regular semi-sharp crease rules CREASE_CHAIKIN Apply Chaikin semi-sharp crease rules Example of contiguous semi-sharp creases interpolation Triangle Subdivision Rule The triangle subdivision rule is a rule added to the Catmull-Clark scheme that modifies the behavior at triangular faces to improve the undesirable surface artefacts that often result in such areas. Mode Behavior TRI_SUB_CATMARK Default Catmark scheme weights TRI_SUB_SMOOTH Smooth triangle weights Cylinder example This rule was empirically determined to make triangles subdivide more smoothly. However, this rule breaks the nice property that two separate meshes can be joined seamlessly by overlapping their boundaries i.e. when there are triangles at either boundary, it is impossible to join the meshes seamlessly Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "Sdc Overview", │ │ │ │ │ + "text": "Sdc Overview Sdc Overview 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Subdivision Core Sdc Types, Traits and Options Creasing support Scheme-specific support The FACE, EDGE and VERTEX interfaces The MASK interface Subdivision Core Sdc Sdc is the lowest level layer in OpenSubdiv. Its intent is to separate the core subdivision details from any particular representation of a mesh it was previously bound to Hbr to facilitate the generation of consistent results with other mesh representations, both internal and external to OpenSubdiv. The functionality can be divided roughly into three sections types, traits and options for the supported subdivision schemes computations required to support semi-sharp creasing computations for mask weights of subdivided vertices for all schemes For most common usage, familiarity with only the first of these is necessary -- primarily the use of public types and constants for the choice of subdivision scheme and its associated options. The latter two provide the basis for a more comprehensive implementation of subdivision, which requires considerably more understanding and effort. Overall, the approach was to extract the functionality at the lowest level possible. In some cases, the implementation is not far from being simple global functions. The intent was to start at a low level and build any higher level functionality as needed. What exists now is functional for ongoing development and anticipated needs within OpenSubdiv for the near future. The intent of Sdc is to provide the building blocks for OpenSubdiv and its clients to efficiently process the specific set of supported subdivision schemes. It is not intended to be a general framework for defining customized subdivision schemes. Types, Traits and Options The most basic type is the enum SdcSchemeType that identifies the fixed set of subdivision schemes supported by OpenSubdiv Bilinear , Catmark and Loop . With this alone, we intend to avoid all dynamic casting issues related to the scheme by simply adding members to the associated subclasses for inspection. In addition to the type enum itself, a class defining a fixed set of traits associated with each scheme is provided. While these traits are available as static methods in the interface of a class supporting more functionality for each scheme to be described shortly, the SchemeTypeTraits provide queries of the traits for a variable of type SdcSchemeType -- enabling parameterization of code by the value of a trait without templates or virtual inheritance a simple internal table of traits is constructed and trivially indexed. The second contribution is the collection of all variations in one place that can be applied to the subdivision schemes, i.e. the boundary interpolation rules, creasing method, edge subdivision choices, etc. The fact that these are all declared in one place alone should help clients see the full set of variations that are possible. A simple Options struct a set of bitfields aggregates all of these variations into a single object the equivalent of an integer in this case that are passed around to other Sdc classes andor methods and are expected to be used at a higher level both within OpenSubdiv and externally. By aggregating the options and passing them around as a group, it allows us to extend the set easily in future without the need to rewire a lot of interfaces to accommodate the new choice. Clients can enable new choices at the highest level and be assured that they will propagate to the lowest level where they are relevant. Unlike other options structs used elsewhere to specify variations of a particular method, SdcOptions defines all options that affect the shape of the underlying limit surface of a subdivision mesh. Other operations at higher levels in the library may have options that approximate the shape and so create a slightly different appearance, but SdcOptions is a fundamental part of the definition of the true limit surface. Creasing support Since the computations involved in the support of semi-sharp creasing are independent of the subdivision scheme, the goal in Sdc was to encapsulate all related creasing functionality in a similarly independent manner. Computations involving sharpness values are also much less dependent on topology -- there are vertices and edges with sharpness values, but knowledge of faces or boundary edges is not required, -- so the complexity of topological neighborhoods required for more scheme-specific functionality is arguably not necessary here. Creasing computations have been provided as methods defined on a Crease class that is constructed with a set of Options. Its methods typically take sharpness values as inputs and compute a corresponding set of sharpness values as a result. For the Uniform creasing method previously known as Normal , the computations may be so trivial as to question whether such an interface is worth it, but for Chaikin or other schemes in the future that are non-trivial, the benefits should be clear. Functionality is divided between both uniform and non-uniform, so clients have some control over avoiding unnecessary overhead, e.g. non-uniform computations typically require neighboring sharpness values around a vertex, while uniform does not. Also included as part of the Crease class is the Rule enum -- this indicates if a vertex is Smooth, Crease, Dart or Corner referred to as the mask in Hbr and is a function of the sharpness values at and around a vertex. Knowing the Rule for a vertex can accelerate mask queries, and the Rule can often be inferred based on the origin of a vertex e.g. it originated from the middle of a face, was the child of a Smooth vertex, etc.. Methods are defined for the Crease class to subdivide edge and vertex sharpness values determine the Rule for a vertex based on incident sharpness values determine the transitional weight between two sets of sharpness values Being all low-level and working directly on sharpness values, it is a clients responsibility to coordinate the application of any hierarchical crease edits with their computations. Similarly, in keeping with this as a low-level interface, values are passed as primitive arrays. This follows the trend in OpenSubdiv of dealing with data of various kinds e.g. weights, component indices, now sharpness values, etc. in small contiguous sets of values. In most internal cases we can refer to a set of values or gather what will typically be a small number of values on the stack for temporary use. Scheme-specific support While the SchemeTypeTraits class provides traits for each subdivision scheme supported by OpenSubdiv i.e. Bilinear , Catmark and Loop , the Scheme class provides these more directly, Additionally, the Scheme class provides methods for computing the various sets of weights used to compute new vertices resulting from subdivision. The collection of weights used to compute a single vertex at a new subdivision level is typically referred to as a mask . The primary purpose of the Scheme class is to provide such masks in a manner both general and efficient. Each subdivision scheme has its own values for its masks, and each are provided as specializations of the template class SchemeSchemeType TYPE . The intent is to minimize the amount of code specific to each scheme. The computation of mask weights for subdivided vertices is the most significant contribution of Sdc. The use of semi-sharp creasing with each non-linear subdivision scheme complicates what are otherwise simple masks determined solely by the topology, and packaging that functionality to achieve both the generality and efficiency desired has been a challenge. Mask queries are defined in the Scheme class template, which has specializations for each of the supported subdivision schemes. Mask queries are defined in terms of interfaces for two template parameters the first defining the topological neighborhood of a vertex, and a second defining a container in which to gather the individual weights template typename FACE , typename MASK void ComputeFaceVertexMask FACE const faceNeighborhood , MASK faceVertexMask , ... const Each mask query is expected to call methods defined for the FACE , EDGE or VERTEX classes to obtain the information they require typically these methods are simple queries about the topology and associated sharpness values. Clients are free to use their own mesh representations to gather the requested information as quickly as possible, or to cache some subset as member variables for immediate inline retrieval. In general, the set of weights for a subdivided vertex is dependent on the following the topology around the parent component from which the vertex originates the type of subdivision Rule applicable to the parent component the type of subdivision Rule applicable to the new child vertex a transitional weight blending the effect between differing parent and child rules This seems fairly straight-forward, until we look at some of the dependencies involved the parent Rule requires the sharpness values at and around the parent component the child Rule requires the subdivided sharpness values at and around the new child vertex though it can sometimes be trivially inferred from the parent the transitional weight between differing rules requires all parent and child sharpness values Clearly the sharpness values are inspected multiple times and so it pays to have them available for retrieval. Computing them on an as-needed basis may be simple for uniform creasing, but a non-uniform creasing method requires traversing topological neighborhoods, and that in addition to the computation itself can be costly. The point here is that it is potentially unreasonable to expect to evaluate the mask weights completely independent of any other consideration. Expecting and encouraging the client to have subdivided sharpness values first, for use in more than one place, is therefore recommended. The complexity of the general case above is also unnecessary for most vertices. Any client using Sdc typically has more information about the nature of the vertex being subdivided and much of this can be avoided -- particularly for the smooth interior case that often dominates. More on that in the details of the Scheme classes. Given that most of the complexity has been moved into the template parameters for the mask queries, the Scheme class remains fairly simple. Like the Crease class, it is instantiated with a set of Options to avoid them cluttering the interface. It is currently little more than a few methods for the limit and refinement masks for each vertex type, plus the few fixed traits of the scheme as static methods. The mask queries have been written in a way that greatly simplifies the specializations required for each scheme. The generic implementation for both the edge-vertex and vertex-vertex masks take care of all of the creasing logic, requiring only a small set of specific masks to be assigned for each Scheme smooth and crease masks for an edge-vertex, and smooth, crease and corner masks for a vertex-vertex. Other than the Bilinear case, which will specialize the mask queries to trivialize them for linear interpolation, the specializations for each Scheme should only require defining this set of masks -- and with two of them common edge-vertex crease and vertex-vertex corner the Catmark scheme only needs to define three. The FACE, EDGE and VERTEX interfaces Mask queries require an interface to a topological neighborhood, currently labeled FACE , EDGE and VERTEX . This naming potentially implies more generality than intended, as such classes are only expected to provide the methods required of the mask queries to compute its associated weights. While all methods must be defined, some may rarely be invoked, and the client has considerable flexibility in the implementation of these they can defer some evaluations lazily until required, or be pro-active and cache information in member variables for immediate access. An approach discussed in the past has alluded to iterator classes that clients would write to traverse their meshes. The mask queries would then be parameterized in terms of a more general and generic mesh component that would make use of more general traversal iterators. The advantage here is the iterators are written once, then traversal is left to the query and only what is necessary is gathered. The disadvantages are that clients are forced to write these to do anything, getting them correct and efficient may not be trivial or possible in some cases, and that the same data e.g. subdivided sharpness may be gathered or computed multiple times for different purposes. The other extreme was to gather everything possible required at once, but that is objectionable. The approach taken here provides a reasonable compromise between the two. The mask queries ask for exactly what they want, and the provided classes are expected to deliver it as efficiently as possible. In some cases the client may already be storing it in a more accessible form and general topological iteration can be avoided. The information requested of these classes in the three mask queries is as follows For FACE the number of incident vertices For EDGE the number of incident faces the sharpness value of the parent edge the sharpness values of the two child edges the number of vertices per incident face For VERTEX the number of incident faces the number of incident edges the sharpness value of the parent vertex the sharpness values for each incident parent edge the sharpness value of the child vertex the sharpness values for each incident child edge The latter should not be surprising given the dependencies noted above. There are also a few more to consider for future use, e.g. whether the EDGE or VERTEX is manifold or not. In most cases, additional information can be provided to the mask queries i.e. pre-determined Rules, and most of the child sharpness values are not necessary. The most demanding situation is a fractional crease that decays to zero -- in which case all parent and child sharpness values in the neighborhood are required to determine the proper transitional weight. The MASK interface Methods dealing with the collections of weights defining a mask are typically parameterized by a MASK template parameter that contains the weights. The set of mask weights is currently divided into vertex-weights, edge-weights and face-weights -- consistent with previous usage in OpenSubdiv and providing some useful correlation between the full set of weights and topology. The vertex-weights refer to parent vertices incident the parent component from which a vertex originated, the edge-weights the vertices opposite incident edges of the parent, and the face-weights the center of incident parent faces. Note the latter is NOT in terms of vertices of the parent but potentially vertices in the child originating from faces of the parent. This has been done historically in OpenSubdiv but is finding less use -- particularly when it comes to providing greater support for the Loop scheme -- and is a point needing attention. So the mask queries require the following capabilities assign the number of vertex, edge andor face weights retrieve the number of vertex, edge andor face weights assign individual vertex, edge andor face weights by index retrieve individual vertex, edge andor face weights by index through a set of methods required of all MASK classes. Since the maximum number of weights is typically known based on the topology, usage within Vtr, Far or Hbr is expected to simply define buffers on the stack. Another option is to utilize pre-allocated tables, partitioned into the three sets of weights on construction of a MASK , and populated by the mask queries. A potentially useful side-effect of this is that the client can define their weights to be stored in either single or double-precision. With that possibility in mind, care was taken within the mask queries to make use of a declared type in the MASK interface MASKWeight for intermediate calculations. Having support for double-precision masks in Sdc does enable it at higher levels in OpenSubdiv if later desired, and that support is made almost trivial with MASK being generic. It is important to remember here that these masks are being defined consistent with existing usage within OpenSubdiv both Hbr and the subdivision tables generated by Far . As noted above, the face weights correspond to the centers of incident faces, i.e. vertices on the same level as the vertex for which the mask is being computed, and not relative to vertices in the parent level as with the other sets of weights. It is true that the weights can be translated into a set in terms solely of parent vertices, but in the general case i.e. Catmark subdivision with non-quads in the base mesh this requires additional topological association. In general we would need N-3 weights for the N-3 vertices between the two incident edges, where N is the number of vertices of each face typically 4 even at level 0. Perhaps such a translation method could be provided on the mask class, with an optional indication of the incident face topology for the irregular cases. The Loop scheme does not have face weights , for a vertex-vertex mask, but for an edge-vertex mask it does require weights associated with the faces incident the edge -- either the vertex opposite the edge for each triangle, or its center which has no other use for Loop. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "subdivision_surfaces.html" │ │ │ │ │ + "loc": "sdc_overview.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "3.0 - 3.6 Release Notes", │ │ │ │ │ "text": "3.0 - 3.6 Release Notes 3.0 - 3.6 Release Notes 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Release 3.6 Release 3.6.0 - Sep 2023 Release 3.5 Release 3.5.1 - July 2023 Release 3.5.0 - Sep 2022 Release 3.4 Release 3.4.4 - Feb 2021 Release 3.4.3 - Apr 2020 Release 3.4.0 - Jun 2019 Release 3.3 Release 3.3.3 - Jul 2018 Release 3.3.2 - Jun 2018 Release 3.3.1 - Feb 1018 Release 3.3.0 - Aug 2017 Release 3.2 Release 3.2.0 - Feb 2017 Release 3.1 Release 3.1.1 - Jan 2017 Release 3.1.0 - Oct 2016 Release 3.0 Release 3.0.5 - Mar 2016 Release 3.0.4 - Feb 2016 Release 3.0.3 - Oct 2015 Release 3.0.2 - Aug 2015 Release 3.0.1 - Aug 2015 Release 3.0.0 - Jun 2015 Release 3.0.0 RC2 Release 3.0.0 RC1 Previous 2.x Release Notes Release 3.6 Release 3.6.0 - Sep 2023 Release 3.6.0 is a significant release with new features, several configuration improvements, and bug fixes. For more information on the following, see Release 3.6 Changes Updated Osd patch drawing shader source to exclude legacy shader constructs to improve compatibility with Vulkan, DX12, etc. GitHub 1320 Installed Osd patch evaluation headers to allow use from client shaders and compute kernels GitHub 1321 Updated CMake build to locate TBB using TBBs CMake config in order to support oneTBB GitHub 1319 Updated CMake FindOpenCL module to support parsing version information from recent OpenCL headers GitHub 1322 Removed obsolete .travis.yml GitHub 1324 Bug Fixes Fixed inconsistent warning levels for MSVC builds when using Ninja GitHub 1318 Fixed documentation build errors when using Ninja GitHub 1323 Fixed build errors resulting from oneTBB API changes GitHub 1317 Release 3.5 Release 3.5.1 - July 2023 Release 3.5.1 is a minor release including bug fixes and configuration improvements. Changes Updated CMake to set fallback CMAKE_CXX_STANDARD to C14 GitHub 1276 Updated CMake with OpenGL import targets to avoid link errors GitHub 1277 Updated CMake to set gpu architecture fallback only for older CUDA versions GitHub 965 1299 Updated CMake to use append for CMAKE_MODULE_PATH GitHub 1296 Fixed interface includes for CMake config GitHub 1278 Fixed warnings with newer and stricter use of Clang GitHub 1275 1289 1290 Fixed potential float constant cast errors for OpenCL GitHub 1285 Fixed generation of Apple Frameworks with no OSD_GPU targets enabled GitHub 1224 1236 Bug Fixes Fixed BfrSurface construction bug for rare topological case GitHub 1301 Fixed CUDA example dependencies with GLX on Linux GitHub 1294 Release 3.5.0 - Sep 2022 Release 3.5.0 is a significant release with new features, several configuration improvements, and a few other improvements and bug fixes. For more information on the following, see Release 3.5 Deprecation Announcements Hbr is deprecated and will be removed from subsequent releases New Features Simplified Surface Evaluation Bfr Tessellation Patterns Bfr Changes Suppression of GCC compiler warnings GitHub 1253, 1254, 1270 Additional methods for FarTopologyLevel GitHub 1227, 1255 Improved mixed partial derivative at Gregory patch corners GitHub 1252 Minor improvements to Far tutorials GitHub 1226, 1241 Added CMake config GitHub 1242 Updated CMake minimum version to 3.12 GitHub 1237, 1261 Updated documentation build scripts for Python 3 1265, 1266 Updated stringify build tool for improved cross compilation support GitHub 1267 Added NO_MACOS_FRAMEWORKS build option GitHub 1238 Updated Azure pipelines agents for Unbuntu and macOS GitHub 1247, 1256 Removed obsolete AppVeyor and Travis CI scripts GitHub 1259 Bug Fixes Cache active program for OsdGLComputeEvaluator GitHub 1244 Fixed member initialization warnings in OsdD3D11ComputeEvaluator GitHub 1239 Fixed GLSL shader source to remove storage qualifiers from struct members GitHub 1271 Fixed use of CMake variables for Apple builds GitHub 1235 Fixed build errors when using OpenGL without GLFW GitHub 1257 Fixed links to embedded videos GitHub 1231 Release 3.4 Release 3.4.4 - Feb 2021 Release 3.4.4 is a minor release including bug fixes and configuration improvements Changes The master branch on GitHub has been renamed release GitHub 1218 1219 The CMake configuration has been updated to allow use as a sub-project GitHub 1206 Removed obsolete references to hbr from examplesfarViewer GitHub 1217 Bug Fixes Fixed bug with sparse PatchTables and irregular face-varying seams GitHub 1203 Fixed loss of precision when using double precision stencil tables GitHub 1207 Fixed reset of FarTopologyRefinerGetMaxLevel after call to Unrefine GitHub 1208 Fixed linking with -ldl on unix systems GitHub 1196 Fixed naming and installation of macOS frameworks GitHub 1194 1201 Fixed GL version and extension processing and dynamic loading on macOS GitHub 1216 Fixed FindDocutils.cmake to be more robust GitHub 1213 1220 Fixed errors using build_scriptsbuild_osd.py with Python3 GitHub 1206 Release 3.4.3 - Apr 2020 Release 3.4.3 is a minor release including bug fixes and configuration improvements Changes GLEW is no longer required by default GitHub 1183 1184 Removed false Ptex link dependency from libosdCPU GitHub 1174 Removed false GLFW link dependency from DX11 and Metal examples GitHub 1178 Removed link dependency on unused TBB libraries GitHub 1064 Added option to disable building of dynamic shared libraries GitHub 1169 Added new tutorial for FarLimitStencilTable GitHub 1176 Updated use of EXT_direct_state_access to ARB_direct_state_access GitHub 1184 Fixed C strict aliasing warnings GitHub 1182 Fixed MSVC warnings in example code GitHub 1158 1172 Fixed compatibility with Visual Studio 2019 GitHub 1173 1189 Fixed CMake CMP0054 warnings GitHub 1180 Added prefix to OpenSubdiv CMake macros GitHub 1157 Moved utilities in examplescommon to regressioncommon GitHub 1167 Minor fixes to Far tutorials GitHub 1175 1177 Switched to Azure Pipelines for continuous integration testing instead of Travis-CI and AppVeyor GitHub 1168 1190 Bug Fixes Fixed selective boundary interpolation for case SdcOptionsVTX_BOUNDARY_NONE GitHub 1170 1171 Fixed static library linking to address missing symbols GitHub 1192 Additional fixes for dynamic and static linking GitHub 1193 Release 3.4.0 - Jun 2019 Release 3.4.0 is a significant release with several new features, bug fixes, and general code and configuration improvements. For more information on the following, please see Release 3.4 New Features Triangular Patches for Loop subdivision Improvements to Introductory Documentation Sparse Patch Tables and Adaptive Refinement Full Support for Double Precision in Far Changes Added new build script GitHub 1068 Added support for newer DirectX SDKs GitHub 1066 Patch arrays extended to support combined regular and irregular types GitHub 995 FarPatchTables and adaptive refinement supported for Bilinear scheme GitHub 1035 New FarPatchTableFactory method to determine adaptive refinement options GitHub 1047 New FarPatchTableFactory options to align primvar buffers of uniform tables GitHub 986 FarStencilTableUpdateValues overloaded to support separate base buffer GitHub 1011 FarLimitStencilTableFactory updated to create face-varying tables GitHub 1012 Regular patches on boundaries no longer require additional isolation GitHub 1025 Inclusion of OpenSubdiv header files in source code now consistent GitHub 767 Re-organization of and additions to Far tutorials GitHub 1083 examples now use common command-line conventions and parsing GitHub 1056 Bug Fixes Fixed FarPrimvarRefiner internal limitFVar prototype GitHub 979 Fixed FarStencilTable append when base StencilTable empty GitHub 982 Patches around non-manifold vertices now free of cracks GitHub 1013 Release 3.3 Release 3.3.3 - Jul 2018 Release 3.3.3 is bug-fix release addressing regressions from release 3.3.2 Bug Fixes Fixed a regression in PatchTable construction with varying patches GitHub 976 Fixed a regression in PatchTable construction for face-varying patches GitHub 972 Fixed a bug in the initialization of FarSourcePatch GitHub 971 Release 3.3.2 - Jun 2018 Release 3.3.2 is a minor release with potentially significant performance improvements to the patch pre-processing stages Changes Improved performance of PatchTable construction GitHub 966 The resulting improved accuracy will produce slight numerical differences in computations involving patches, e.g. StencilTable and PatchTable evaluation Bug Fixes FarPatchTableFactory now supports PatchTable construction with ENDCAP_BILINEAR_BASIS specified Release 3.3.1 - Feb 1018 Release 3.3.1 is a minor bug-fix release Bug Fixes Fixed GLSLHLSLMetal patch shader code to resolve degenerate normals GitHub 947 Fixed problems with face-varying patches in uniform PatchTables GitHub 946 Fixed integer overflow bugs for large meshes in PatchTable factories GitHub 957 Fixed computation of PatchParam for triangle refinement GitHub 962 Changes Added build options NO_GLFW and NO_GLFW_X11 Added additional shapes with infinitely sharp creases to the Metal and DX11 example viewers Disabled GL tests during CI runs on Linux Improved stability of examplesglImaging in CI runs by testing GL version Release 3.3.0 - Aug 2017 Release 3.3.0 is significant release adding an Osd implementation for Apples Metal API New Features Added an Osd implementation for Apples Metal API Added the mtlViewer example Changes Fixed several instances of local variable shadowing that could cause build warnings Updated continuous-integration build scripts and added testing on macOS Release 3.2 Release 3.2.0 - Feb 2017 Release 3.2.0 is a minor release containing API additions and bug fixes New Features Extended FarStencilTableFactory to support face-varying Extended Osd Evaluator classes to support evaluation of 1st and 2nd derivatives Added an option to disable generation of legacy sharp corner patches Changes Corrected numerous spelling errors in doxygen comments Updated glFVarViewer with improved error detection and command line parsing Added option to build using MSVC with static CRT Bug Fixes Fixed a double delete of GL program in OsdGLComputeEvaluator Release 3.1 Release 3.1.1 - Jan 2017 Release 3.1.1 is a minor bug-fix release. Bug Fixes Fixed a bug with non-manifold face-varying topology causing a crash during patch table creation Fixed GLEW compilation and linking with dynamic GLEW libraries on Windows Fixed GLFW linking with GLFW 3.2 on X11 platforms Release 3.1.0 - Oct 2016 Release 3.1.0 is a significant release with several new features, bug fixes, and general code and configuration improvements. For more information on the following, please see Release 3.1 New Features Bicubic Face-Varying Patches Varying and Face-Varying Evaluation Second Order Derivative Evaluation Separate Levels of Feature Isolation Sharp Patches for Infinitely Sharp Features Changes Enabled the use of CMakes folder feature Removed the use of iso646 alternative keywords and, or, not, etc. to improve portability Added numerical valued preprocessor directives OPENSUBDIV_VERSION_MAJOR, etc. to opensubdivversion.h Improved documentation for FarPatchParam and added Unnormalize to complement Normalize Added additional topology queries to FarTopologyLevel Updated glFVarViewer and glEvalLimit viewer to make use of bicubic face-varying patches Updated glViewer and dxViewer to add a toggle for InfSharpPatch Updated dxPtexViewer for improved feature parity with glPtexViewer Improved far_regression to exercise shapes independent of Hbr compatibility Added support for Appveyor continuous integration testing Removed cmakeFindIlmBase Removed mayaPolySmooth example Bug Fixes Fixed Ptex version parsing and compatibility issues Fixed compatibility issues with VS2015 Fixed bug interpolating face-varying data with Bilinear scheme Fixed bug with refinement using Chaikin creasing Fixed bugs with HUD sliders in the example viewers Release 3.0 Release 3.0.5 - Mar 2016 Release 3.0.5 is a minor stability release with performance and correctness bug fixes. Bug Fixes The previous release reduced transient memory use during PatchTable construction, but increased the amount of memory consumed by the resulting PatchTable itself, this regression has been fixed. The example Ptex texture sampling code has been fixed to prevent sampling beyond the texels for a face when multisample rasterization is enabled. Release 3.0.4 - Feb 2016 Release 3.0.4 is a minor stability release which includes important performance and bug fixes. New Features Added accessor methods to FarLimitStencilTable to retrieve limit stencil data including derivative weights Added support for OpenCL event control to OsdCLVertexBuffer and OsdCLEvaluator Changes Major reduction in memory use during FarPatchTable construction for topologies with large numbers of extraordinary features Improved performance for GL and D3D11 tessellation control hull shader execution when drawing BSpline patches with the single crease patch optimization enabled Bug Fixes Restored support for drawing with fractional tessellation Fixed far_tutorial_6 to refine primvar data only up to the number of levels produced by topological refinement Fixed build warnings and errors reported by Visual Studio 2015 Release 3.0.3 - Oct 2015 Release 3.0.3 is a minor stability release which includes important performance and bug fixes. New Features Smooth normal generation tutorial, far_tutorial_8 Changes Major performance improvement in PatchTable construction Improved patch approximations for non-manifold features Bug Fixes Fixed double delete in GLSL Compute controller Fixed buffer layout for GLSL Compute kernel Fixed GL buffer leak in OsdGLPatchTable Fixed out-of-bounds data access for TBB and OMP stencil evaluation Fixed WIN32_LEAN_AND_MEAN typo Fixed Loop-related shader issues glFVarViewer Release 3.0.2 - Aug 2015 Release 3.0.2 is a minor release for a specific fix. Bug Fixes Fixed drawing of single crease patches Release 3.0.1 - Aug 2015 Release 3.0.1 is a minor release focused on stability and correctness. Changes Added a references section to the documentation, please see References Removed references to AddVaryingWithWeight from examples and tutorials Added more regression test shapes Addressed general compiler warnings e.g. signed vs unsigned comparisons Addressed compiler warnings in the core libraries reported by GCCs -Wshadow Eased GCC version restriction, earlier requirement for version 4.8 or newer is no longer needed Replaced topology initialization assertions with errors Improved compatibility with ICC Improved descriptive content and formatting of Far error messages Improved build when configured to include no GPU specific code Bug Fixes Fixed handling of unconnected vertices to avoid out of bounds data access Fixed non-zero starting offsets for TbbEvalStencils and OmpEvalStencils Fixed FarStencilTableFactoryOptionsfactorizeIntermediateLevels Fixed FarPatchTablesFactoryOptionsgenerateAllLevels Fixed the behavior of VTX_BOUNDARY_NONE for meshes with bilinear scheme Fixed some template method specializations which produced duplicate definitions Disabled depth buffering when drawing the UI in the example viewers Disabled the fractional tessellation spacing option in example viewers since this mode is currently not supported Release 3.0.0 - Jun 2015 Release 3.0.0 is a major release with many significant improvements and changes. For more information on the following, please see Release 3.0 New Features Faster subdivision using less memory Support for non-manifold topology Face-Varying data specified topologically Elimination of fixed valence tables Single-crease patch for semi-sharp edges Additional irregular patch approximations Introduction of Stencil Tables Faster, simpler GPU kernels Unified adaptive shaders Updated coding style with namespaces More documentation and tutorials Bug Fixes Smooth Face-Varying interpolation around creases Release 3.0.0 RC2 New Features Documentation updates far_tutorial_3 updates for the multiple face-varying channels maya example plugin interpolates a UV channel and a vertex color channel Bug Fixes Fixed a LimitStencilTableFactory bug, which returns an invalid table PatchParam encoding changed to support refinement levels up to 10 Added Xinerama link dependency Fixed MSVC 32bit build problem Fixed minor cmake issues Fixed glViewerfarViewer stability bugs Release 3.0.0 RC1 Changes FarTopologyRefiner was split into several classes to clarify and focus the API. Interpolation of Vertex and Varying primvars in a single pass is no longer supported. The Osd layer was largely refactored. Previous 2.x Release Notes Previous releases Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "release_notes.html" │ │ │ │ │ }, { │ │ │ │ │ + "title": "Release Notes", │ │ │ │ │ + "text": "Release Notes Release Notes 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Release 2.6.0 Release 2.5.1 Release 2.5.0 Release 2.4.1 Release 2.4.0 Release 2.3.5 Release 2.3.4 Release 2.3.3 Release 2.3.2 Release 2.3.1 Release 2.3.0 Release 2.2.0 Release 2.1.0 Release 2.0.1 Release 2.0.0 Release 1.2.4 Release 1.2.3 Release 1.2.2 Release 1.2.1 Release 1.2.0 Release 1.1.0 Release 1.0.0 Release 2.6.0 New Features Add subdivision kernels for ARM NEON Add OsdUtilVertexSplit which creates a vertex-varying data table by duplicating vertices in a FarMesh Add basic functions to work with FV data via evaluator API Changes Added Catmark restricted vertex compute kernels that optimize for vertices with no semi-sharp creases Fix accessor omissions in osdmesh.h Add support for different subdivision schemes for OsdUtilMesh Bug Fixes Fix crashes when using rather low-end cards like Intel ones Fix a bug in the creation of an edge-vertex kernel batch Fix mismatch in declaration and usage of OsdCudaComputeRestrictedVertexA Fix a bug in the vertex order for restricted Catmark vertex-vertex kernel batches Fix a bug in FarCatmarkSubdivisionTablesFactory that prevented the CATMARK_QUAD_FACE_VERTEX kernel from being selected for subdivision level 2 or greater. Fix a bug in OsdUtilVertexSplit that occurs when getting the address of the end of a stdvector Fix error in createCLBuffer that occurs when the buffer size is zero Fix a bug in the CUDA computeRestrictedEdge kernel Fix duplicate variables with identical name Fix osdutil build errors Fix cmake diagnostic messsage Release 2.5.1 New Features Add CATMARK_QUAD_FACE_VERTEX and CATMARK_TRI_QUAD_FACE_VERTEX compute kernels optimization that takes advantage of all-quads or all-triange-and-quads meshes Bug Fixes Fix a compiler error in the GLSL Transform Feedback kernels on OS X Fix boundary interpolation in osdutil Fix bilinear stencil tangent computions Release 2.5.0 New Features Add ability to generate triangle patches for a uniformly subdivided mesh Add new example topologySharing Add interleaved buffer mode in glViewer Add GLSL compute kernel to glBatchViewer Add TBB compute kernel to glBatchViewer Add a PullDown widget to our HUD in examplescommon GUI updates cosmetic changes to GL example code Adding a programmable image shader to gl_hud Code cleanup for GLFrameBuffer in examplescommon Implement C-API accessor to evaluator topology osdutil Add command line option to CMakes options Add a CMake option to disable OpenCL Add a FindCLEW.cmake module in anticipation of using CLEW as a dependency Integrate CLEW into osd library and examples Changes Change interleaved buffer support in OsdCompute Removed OsdVertexDescriptor and replaced with OsdVertexBufferDescriptor Reorganize ComputeContext and ComputeController. Reorganize EvalStencilContext and EvalStencilController Moved transient states current vertex buffer etc to controller Reorganize EvalLimitContext and EvalLimitController Moved transient states current vertex buffer etc to controller Fix adaptive isolation of sharp corner vertices Fix incorrect FarMeshFactory logic for isolating multiple corner vertices in corner patches Change EvalLimit Gregory patch kernels to the large weights table to accomodate higher valences Fix calculation of screen space LOD tess factors for transition corner patches. Add a public constructor to OsdMesh Decrease compiler warning thresholds and fix outstanding warnings Make PTex support optional Add a NO_MAYA flag to CMakeLists to disable all Autodesk Maya dependencies in the build Document NO_MAYA command line option Bug Fixes Fix mistakenly deleted memory barrier in glsl OsdCompute kernel. Fix shape_utils genRIB function to use streams correctly. Temporary workaround for the synchronization bug of glsl compute kernel Fix Hud display for higher DPI MBP retina Fix Hud d3d11 Fix examples to use GL timer query to measure the GPU draw timing more precisely Fix glViewer stop updating during freeze. Fix file permissions on farPatchTablesFactory.h Fix some meory leaks in adaptive evaluator osdutil Fix OsdUtilAdaptiveEvaluator concurrency issue Fix OsdUtilRefiner incorrect Invalid size of patch array error reporting. Fix OsdUtilPatchPartitioner failure for triangle patches Fixes a bug that causes OsdUtilPatchPartitioner to fail to rebuild the face-varying data table correctly for triangle patches. Add missing third parameter to templated OsdDrawContext usage osdutilbatch.h Return success status from openSubdiv_finishEvaluatorDescr osdutil Remove debugging stdcout calls osdutil Build errors warnings Fix OSX Core Profile build GLFrameBuffer Fix ptexViewer build error on OSX Fix framebuffer shader compiling for OSX Reordering includes to address a compile error on OSXglew environment Fix compilation errors with CLEW enabled Fix icc build problems Fix compiler warnings in OsdClVertexBuffer Fix compilation error on windowsmsvc2013 Fix build warningserrors with VS2010 Pro Fix Windows build warning in FarPatchTablesFactory Fix doxygen generation errors Release 2.4.1 Changes Add correct OpenSubdiv namespace beginend blocks. Bug Fixes Compile osdutil with -fPIC for correct linking. Fix a bug of OsdUtilMeshBatch, the varying buffer isnt computed with CL kernels Fix FindGLFW.cmake to use the GLFW_LOCATION environment variable in Windows Fix Draw contexts do not fully initialize patch arrays Release 2.4.0 New Features Adding functionality to store uniform face-varying data across multiple levels of subdivision Add OsdUtilPatchPartitioner. It splits patcharray into subsets so that clients can draw partial surfaces for both adaptive and uniform. Changes Remove FarMesh dependency from OsdContext. Use DSA APIs for GL buffer update if available. Refactor Far API replace void- of all kernel applications with CONTEXT template parameter. It eliminates many static_casts from void- for both far and osd classes. move the big switch-cases of far default kernel launches out of Refine so that osd controllers can arbitrary mix default kernels and custom kernels. change FarKernelBatchkernelType from enum to int, clients can add custom kernel types. remove a back-pointer to farmesh from subdivision table. untemplate all subdivision table classes and template their compute methods instead. Those methods take a typed vertex storage. remove an unused argument FarMesh from the constructor of subdivision table factories. Refactor FarSubdivisionTables. Delete scheme specialized subdivision tables. The base class FarSubdivisionTables already has all tables, so we just need scheme enum to identify which scheme the subdivision tables belong to. This brings a lot of code cleanups around far factory classes. Move FarMultiMeshFactory to OsdUtil. Move table splicing functions of FarMultiMeshFactory into factories Change PxOsdUtil prefix to final OsdUtil prefix. Improve error reporting in osdutil refinement classes, and fix a build issue Bug Fixes Fix another multi mesh splicing bug of face varying data. Make CMake path variables more robust Fixing a crash on Marvericks wglew Update dxViewer example documentation Fix wrong logic in openSubdiv_setEvaluatorCoarsePositions Remove debug print from adaptive evaluators initialization Release 2.3.5 New Features Add the ability to read obj files to the dxViewer example Add screen-capture function to ptexViewer Update documention for Xcode builds Add documentation boundary interpolation rules and face-varying boundary interpolation rules Changes Refactoring FarPatchTables and FarPatchTablesFactory Move GL vertex buffer VBO buffer allocation out of allocate and into BindVBO Enable uvViewer on OS X now that Mavericks is released. Replacing un-necessary dynamic_cast with reinterpret_cast within FarDispatcher Minor code cleanup of FarMeshFactory Remove address space qualifiers from OpenCL kernel functions Fix OpenCL initialization to be slightly more robust Add OpenCL header include paths where necessary Add static specifiers for non-kernel CL funcs at program scope Add stddef.h to pythonosdosdshim.i Modify ptexViewer and uvViewer shaders to address some portability issues Bug Fixes Fix Gregory Boundary patch buffer overrun Fix black texels when the resolution of a ptex face is less than 4 Fix a splicing bug in FarMultiMeshFactory Fix a build error when using older versions of GLFW Fix build warnings optimized Fix FindTBB.cmake Fix FindMaya.cmake Fix glViewer support for GLSL compute Fix ptexViewer enable specular pass in both IBL and point lighting Fix Zlib include in ptexViewer Fix ptexViewer shader errors. Fix osdPolySmooth Maya plugin Fix UV merging in osdPolySmooth code example Add cleanup function to osdPolySmooth Maya plugin Fix Maya OsdPolySmooth node component output Fix GLSL array instantiation syntax for glStencilViewer Fix examples to run correctly on high DPI displays with GLFW 3 Release 2.3.4 New Features Adding CPUOMPTBB Context Controller pairs for CPU evaluation of smooth normals Added adaptiveEvaluator class inspired by Sergeys work in blender OsdUtil Changes Changed the HUD to ignore mouse clicks when not visible. Updates for blender development OsdUtil Add C compatible API to access the adaptiveEvaluator class from non-C OsdUtil Update license headers to apache OsdUtil CMake build improvement make osd a cmake object library remove compiling redundancies Improve stringification of shaders kernels in CMake build Bug Fixes Fixed iOS build Fixed VS2010 warningserrors. Fix OsdCpuEvalLimitKernel Fix maxvalence calculation in FarMeshFactory Fix FarStencilFactory control stencil caching Removing assert for high-valence vertices running off limit tangent pre-computed table. Fix degenerate stencil limit tangent code path. Fix unused variable build warnings gcc 4.8.2 - Fedora 19 Fix build warning from osdutiladaptiveEvaluator.cpp Release 2.3.3 Changes Modify Far remapping of singular vertices to point to their source vertex. Refactoring Ptex Mipmap and Analytic Displacement code Adding some documentation for Chaikin crease rule Misc. improvements to PxOsdUtilsMesh Adding recommended isolation output to OsdPolySmooth node Bug Fixes Adding an error check on version parsing of main CMakeLists Fix regex in FindMaya.cmake that breaks with recent versions of Maya Fix crashes induced by typeid Fixed VS2010 build warning Fix build break in hbr_regression Fix incorrect capitalization in GL ptexViewer shader.glsl Fix OSX build add stdlib.h include Release 2.3.2 New Features Adding control cage drawing to ptexViewer Adding Maya osdPolySmooth plugin into OpenSubdiv examples. Changes Removing some glGetError checks that are causing problems for Autodesk D3D11DrawRegistry returns the common shader config for all non-tess patcharrays. Updates to simple cpu osdutil classes Bug Fixes Fix Hbr Chaikin crease rule Fix Chaikin tag parsing Fix return value of allocate function for OsdCPUGLVertxBuffer Fixed GLSL shader portability. Fix FindGLFW.cmake for GLFW 3.03 on OSX Fixed compiler warnings. Fixed VS2010 build errors Fixed WIN32 build error when no DXSDK installed. Fix OSX build stdlib.h needs to be included in glPtexMipmapTexture.h Fix for crash in new meshrefiner code in OsdUtil Release 2.3.1 New Features Add DX11 version of ptex mipmap loader Add DX11 ptex viewer work in progress Add DX11 fractional partitioning, normal derivatives computation Add memory usage controls to Ptex loader Add face-varying boundary interpolation parsing to shape_utils Add simple HbrMesh and FarMesh wrapper classes to osdutil Changes Amend language of attribution file NOTICE.txt Optimize a bit of ptex mipmap lookup. Show ptex memory usage in GL and DX11 ptexViewers Improve ptex guttering Addding some video links to our collection of external resources Bug Fixes Fix edge-only face-varying interpolation Fix Far to handle disconnected vertices in an Hbr mesh Fixed ptex cache resource release sequence Fix build symbol conflict in Far Fix patch parambuffer generation in OsdD3D11DrawContext Fix a minor osdutil build warning seen with gcc 4.8.1 Fix VS2010 build errors Release 2.3.0 New Features Added Analytical displacement mapping Analytic Displacement Mapping using Hardware Tessellation Niessner and Loop TOG 2013 Added a new ptex mipmap loader Added face varying macros for loop subdivision Added the uvViewer example to see how face varying interpolation rule works Added a slider component and cleanup hud code. Changes Adding license attribution files, improved language of the code headers Install documentation into the Filesystem Hierarchy Standard location Set GLFW_OPENGL_FORWARD_COMPAT on Mac OS to make samples work on that platform Added surface normal mode mipmap to ptxViewer Bug Fixes Fix a bug of bad fvar splicing for loop surface. Fix incorrect bilinear limit tangents in FarStencilTablesFactory Fix boundary interpolation rules doc Added an error check on updating cuda buffer Fix face varying rendering on loop surface Fixed glBatchViewer build for GLFW 2.x Expand search paths for FindGLFW.cmake for Debian and other Linux architectures Fix CMake executable builds for ICC Fix bhr baseline regression, so reference files are real OBJs Fixed clKernelBundle.cpp to build on Android. Fix misc build warings Release 2.2.0 New Features Added subdivision stencil functionality Far OsdEval Bug Fixes Fix D3D11DrawContext to check for NULL pointers Fix cpuEvalLimitController crash bug Fixed search path suffixes for ICC libs Fixed invalid initialization of glslTransformFeedback kernel. Release 2.1.0 New Features Added TBB Compute back-end on Linux contribution from Sheng Fu Added support for ICC compiler still Beta Changes Added constructor to OsdMesh with a FarMesh as input Modify CMake to name and sym-link DSOs based on Linux ABI versioning spec Added command line input to DX11 viewer FarMultiMesh can splice uniform and adaptive meshes together. Bug Fixes Fix FarMultiMesh splicing Removed unnecessary cudaThreadSynchronize calls. Fix glViewer overlapping HUD menus Fix facevarying rendering in glBatchViewer Fix build of GLSL transform feedback kernels Fix Getting Started documentation Release 2.0.1 New Features New CLA files to reflect Apache 2.0 licensing Changes Move all public headers to includeopensubdiv... Adding Osd documentation based on Siggraph slides Bug Fixes Fix incorrect transition pattern 3 in GLSL HLSL shaders Fix CMake build to not link GPU-based libraries into libosdCPU Fix support for GLEW on OSX Fix GLFW Xrandr xf86vmode dependency paths for X11 based systems Fix HUD display overlaps in code examples Fix FindGLEW.cmake to be aware of multiarch on linux systems Fix some hard-coded include paths in CMake build Release 2.0.0 New Features New CMake build flags NO_LIB, NO_CUDA, NO_PYTHON Changes OpenSubdiv is now under Apache 2.0 license HbrHalfedge and HbrFVarData copy constructors are now private Documentation style matched to graphics.pixar.com new content Add an animation freeze button to ptexViewer Variable name changes for better readability across all example shader code Bug Fixes Fix incorrect patch generation for patches with 2 non-consecutive boundary edges Fix undefined gl_PrimitiveID shader build errors Fix for shader macro OSD_DISPLACEMENT_CALLBACK Fix out-of-bounds stdvector access in FarPatchTablesFactory Release 1.2.4 New Features Adding support for fractional tessellation of patches Adding a much needed API documention system based on Docutils RST markup Adding support for face-varying interpolation in GLSL APIs Adding varying data buffers to OsdMesh Adding accessors to the vertex buffers in OsdGlMesh Adding face-varying data to regression shapes Changes Cleanup of common bicubic patch shader code GLSL HLSL for portability ATI OSX drivers Bug Fixes Fix FarVertexEditTablesFactory to insert properly vertex edit batches fixes incorrect hierarchical hole in regression shape Fix FarPatchMap quadtree to not drop top-level non-quad faces Fix Gregory patches bug with incorrect max-valence Fix FarPatchTablesGetNumFaces and FarPatchTablesGetFaceVertices functions to return the correct values Fix face indexing GLSL code ptex works on non-quads again Fix face-varying data splicing in FarMultiMeshFactory Fix ptex face indexing in FarMultiMeshFactory Fix glew include to not break builds Fix Clang ICC build failures with FarPatchTables Fix build and example code to work with GFLW 3.0 Fix cmake to have ptex dynamically linked in OSX Release 1.2.3 New Features Adding Varying and Face-Varying data interpolation to EvalLimit Changes EvalLimit API refactor the EvalContext now has dedicated structs to track all the vertex, varying and face-varying data streams. Also renamed some buffers into tables to maintain code consistency EvalLimit optimization switch serial indexing to a quad-tree based search Bug Fixes Face-varying data bug fixes making sure the data is carried around appropriately Fixes for OpenCL use with the new batching APIs GLSL general shader code cleanup fixes for better portability GLSL Tranform Feedback initialization fix Critical fix for FarMultiMesh batching indexing was incorrect Fix osdutil CL implementation protect includes on systems with no OpenCL SDK installed Fix face-varying interpolation on adaptive patches FarPatchTables fix IsFeatureAdaptive to return the correct answer Fix Far factories to handle the absence of face-varying data correctly. Many GLSL shader code style fixes which should help with ATI OSX shader compiling Release 1.2.2 New Features Introducing the EvalLimit API the Eval module aims at providing support for computational tasks that are not related to drawing the surfaces. The EvalLimit sub-module provides an API that enables client code to evaluate primitive variables on the limit surface. OsdxxxComputeController minor optimization. Added early exit to Refine method to avoid unnecessary interop. Changes OsdGLDawContext minor API change. Protecting some member variables and adding const accessors OsdError minor API refactor, added Warning functions. Bug Fixes Fix Ptex bug prevent corner texel guttering code to from going into infinite loops Adding the ability for a FarMeshFactory to construct patchTables starting from firstLevel in uniform subdivision mode Consolidating the color coding of bicubic patch types through all our our code examples this is used mostly as a debugging tool Fixing some MSVC build warnings Update to the outdated README.md Release 1.2.1 New Features Added CUDA runtime error checking Release 1.2.0 Changes Major Far refactor around patchTables to introduce the draw batching API Renaming osd_util to osdutil Bug Fixes Fix GLSL transform feedback initialization bug in ptexViewer Minor bug typo fixes Release 1.1.0 New Features release initiated because of the switch to Git Flow Release 1.0.0 Oringal release Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "release_notes_2x.html" │ │ │ │ │ + }, { │ │ │ │ │ + "title": "Overview of Release 3.5", │ │ │ │ │ + "text": "Overview of Release 3.5 Overview of Release 3.5 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Simplified Surface Evaluation Tessellation Patterns API Additions New classes in namespace Bfr Additions to FarTopologyLevel Additions to nested Options classes in Far Other Changes Deprecation Announcements Improvements Bug Fixes New Features Simplified Surface Evaluation The new Bfr interface provides an alternative to Far and Osd for evaluating the limit surface -- treating a subdivision mesh as a piecewise parameteric surface primitive . The Bfr interface is named for Base Face Representation as all concepts and classes relate to the individual faces of the original unrefined mesh, i.e. its base faces. Each base face has a piece of limit surface associated with it BfrSurface that is parameterized BfrParameterization and so can be evaluated and tessellated The limit surface for each face can be identified and evaluated independently of any other faces without any global pre-processing of a connected mesh. The resulting evaluation interface is much simpler, more flexible and more scalable than those assembled with the table-based class in Far -- providing a preferable alternative for many CPU-based use cases though not all. See the Bfr Overview documentation for more details. Tessellation Patterns In addition to evaluation, the Bfr interface includes a Tessellation class that provides tessellation patterns for all faces of a base mesh. A Tessellation does not encapsulate the entire tessellation process but simply provides topological patterns to assemble such a process. All faces of a mesh have a Parameterization which can be used to define a Tessellation with the specification of one or more tessellation rates. A single tessellation rate defines simple uniform tessellations while tessellation rates for each edge provide more complex non-uniform patterns A small set of options is also available to define the resulting patterns e.g. the preservation of quad faces with quad-based subdivision schemes above left and center and to generate its output in a more favorable form. Tessellation patterns do not support the full flexibility of typical hardware tessellation e.g. no fractional tessellation but do provide some useful alternatives to hardware tessellation e.g. the quad preservation previously noted, and more uniform triangles for triangular patches above right . The Tessellation class is also completely independent of evaluation in Bfr , and so can be used with any other evaluation interface. See the Tessellation subsection of the Bfr Overview for more details. API Additions See associated Doxygen for full details. New classes in namespace Bfr class Parameterization class Surface class SurfaceFactory class SurfaceFactoryCache class SurfaceFactoryMeshAdapter class RefinerSurfaceFactory class Tessellation Additions to FarTopologyLevel TopologyLevelIsVertexCorner TopologyLevelIsVertexRegular TopologyLevelIsVertexInfSharp TopologyLevelIsVertexSemiSharp TopologyLevelIsEdgeInfSharp TopologyLevelIsEdgeSemiSharp Additions to nested Options classes in Far PatchTableFactoryOptionsSetMaxIsolationLevel TopologyRefinerUniformOptionsSetRefinementLevel TopologyRefinerAdaptiveOptionsSetMaxIsolationLevel TopologyRefinerAdaptiveOptionsSetMaxSecondaryLevel Other Changes Deprecation Announcements Hbr is deprecated and will be removed from subsequent releases Improvements Suppression of GCC compiler warnings GitHub 1253, 1254, 1270 Additional methods for FarTopologyLevel GitHub 1227, 1255 Improved mixed partial derivative at Gregory patch corners GitHub 1252 Minor improvements to Far tutorials GitHub 1226, 1241 Added CMake config GitHub 1242 Updated CMake minimum version to 3.12 GitHub 1237, 1261 Updated documentation build scripts for Python 3 1265, 1266 Updated stringify build tool for improved cross compilation support GitHub 1267 Added NO_MACOS_FRAMEWORKS build option GitHub 1238 Updated Azure pipelines agents for Unbuntu and macOS GitHub 1247, 1256 Removed obsolete AppVeyor and Travis CI scripts GitHub 1259 Bug Fixes Cache active program for OsdGLComputeEvaluator GitHub 1244 Fixed member initialization warnings in OsdD3D11ComputeEvaluator GitHub 1239 Fixed GLSL shader source to remove storage qualifiers from struct members GitHub 1271 Fixed use of CMake variables for Apple builds GitHub 1235 Fixed build errors when using OpenGL without GLFW GitHub 1257 Fixed links to embedded videos GitHub 1231 Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "release_35.html" │ │ │ │ │ + }, { │ │ │ │ │ "title": "Overview of Release 3.6", │ │ │ │ │ "text": "Overview of Release 3.6 Overview of Release 3.6 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Modern Graphics APIs and Parallel Computation Updated Third-party APIs and Tools API Additions Additions to OsdPatchShaderSource Osd extensions for patch evaluation from client shaders and compute kernels Other Changes Deprecation Announcements Improvements Bug Fixes New Features The purpose of this release is to address concerns which improve support for current typical use cases and provide support for significant new use cases. Modern Graphics APIs and Parallel Computation OpenSubdiv is organized as a set of components for working with subdivision surface representations, i.e. Bfr, Far, Vtr, Sdc along with a collection of back-end components in Osd supporting the use of specific low-level subsystems to work with subdivision surface data. These back-end components in Osd have taken many forms including in some cases specific complete GPU shaders along with controller classes to manage compilation and execution of these shaders. In practice it has been more effective for Osd to simply supply the functions needed to operate on subdivision surface data, allowing the client application or client library to take care of using these functions from client provided shaders and computation kernels using client provided execution controllers. This has been the direction for the Osd library for some time and the changes implemented in this release make this even more straightforward. The existing methods OsdGLSLPatchShaderSourceGetPatchBasisShaderSource OsdHLSLPatchShaderSourceGetPatchBasisShaderSource OsdMTLPatchShaderSourceGetPatchBasisShaderSource continue to return shader source strings at runtime which contain definitions and functions allowing client shader code to evaluate values and first and second derivatives on the piecewise parametric patches resulting from subdivison refinement. The identical code is now available at compile time as opensubdivosdpatchBasis.h and is essentially a shader interface that can be used from client kernels including those implemented using TBB, CUDA, C, etc. Similarly, the new methods OsdGLSLPatchShaderSourceGetPatchDrawingShaderSource OsdHLSLPatchShaderSourceGetPatchDrawingShaderSource OsdMTLPatchShaderSourceGetPatchDrawingShaderSource return shader source strings at runtime which contain definitions and functions allowing clients to draw the piecewise parametric patches resulting from subdivision, e.g. using GPU tessellation shaders or GPU mesh shaders. The returned shader source has been stripped of resource binding and other potentially problematic defintions since these are usually best handled by client shader code. These methods have been tested successfully with new client code using Vulkan and DirectX 12 in addition to existing client code using OpenGL, Metal, DirectX 11, etc. Updated Third-party APIs and Tools While the methods described above will be the most effective way to use OpenSubdiv, some of the existing back-end components have been updated to accommodate evolving third-party APIs and tools. Specifically, the TBB implementation has been updated to allow use with the oneTBB API while continuing to maintain compatibility with earlier releases of TBB. Also, there have been minor fixes to the CMake build to accommodate using the Ninja build system and also systems with OpenCL 3.0. API Additions See associated Doxygen for full details. Additions to OsdPatchShaderSource GLSLPatchShaderSourceGetPatchDrawingShaderSource HLSLPatchShaderSourceGetPatchDrawingShaderSource MTLPatchShaderSourceGetPatchDrawingShaderSource Osd extensions for patch evaluation from client shaders and compute kernels struct OsdPatchArray and OsdPatchArrayInit struct OsdPatchCoord and OsdPatchCoordInit struct OsdPatchParam and OsdPatchParamInit OsdPatchParamGetFaceId OsdPatchParamGetU OsdPatchParamGetV OsdPatchParamGetTransition OsdPatchParamGetBoundary OsdPatchParamGetNonQuadRoot OsdPatchParamGetDepth OsdPatchParamGetParamFraction OsdPatchParamIsRegular OsdPatchParamIsTriangleRotated OsdPatchParamNormalize OsdPatchParamUnnormalize OsdPatchParamNormalizeTriangle OsdPatchParamUnnormalizeTriangle OsdEvaluatePatchBasisNormalized OsdEvaluatePatchBasis Other Changes Deprecation Announcements The methods OsdTbbEvaluatorSetNumThreads and OsdOmpEvaluatorSetNumThreads have been marked deprecated. Improvements Updated Osd patch drawing shader source to exclude legacy shader constructs to improve compatibility with Vulkan, DX12, etc. GitHub 1320 Installed Osd patch evaluation headers to allow use from client shaders and compute kernels GitHub 1321 Updated CMake build to locate TBB using TBBs CMake config in order to support oneTBB GitHub 1319 Updated CMake FindOpenCL module to support parsing version information from recent OpenCL headers GitHub 1322 Removed obsolete .travis.yml GitHub 1324 Bug Fixes Fixed inconsistent warning levels for MSVC builds when using Ninja GitHub 1318 Fixed documentation build errors when using Ninja GitHub 1323 Fixed build errors resulting from oneTBB API changes GitHub 1317 Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "release_36.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Release Notes", │ │ │ │ │ - "text": "Release Notes Release Notes 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Release 2.6.0 Release 2.5.1 Release 2.5.0 Release 2.4.1 Release 2.4.0 Release 2.3.5 Release 2.3.4 Release 2.3.3 Release 2.3.2 Release 2.3.1 Release 2.3.0 Release 2.2.0 Release 2.1.0 Release 2.0.1 Release 2.0.0 Release 1.2.4 Release 1.2.3 Release 1.2.2 Release 1.2.1 Release 1.2.0 Release 1.1.0 Release 1.0.0 Release 2.6.0 New Features Add subdivision kernels for ARM NEON Add OsdUtilVertexSplit which creates a vertex-varying data table by duplicating vertices in a FarMesh Add basic functions to work with FV data via evaluator API Changes Added Catmark restricted vertex compute kernels that optimize for vertices with no semi-sharp creases Fix accessor omissions in osdmesh.h Add support for different subdivision schemes for OsdUtilMesh Bug Fixes Fix crashes when using rather low-end cards like Intel ones Fix a bug in the creation of an edge-vertex kernel batch Fix mismatch in declaration and usage of OsdCudaComputeRestrictedVertexA Fix a bug in the vertex order for restricted Catmark vertex-vertex kernel batches Fix a bug in FarCatmarkSubdivisionTablesFactory that prevented the CATMARK_QUAD_FACE_VERTEX kernel from being selected for subdivision level 2 or greater. Fix a bug in OsdUtilVertexSplit that occurs when getting the address of the end of a stdvector Fix error in createCLBuffer that occurs when the buffer size is zero Fix a bug in the CUDA computeRestrictedEdge kernel Fix duplicate variables with identical name Fix osdutil build errors Fix cmake diagnostic messsage Release 2.5.1 New Features Add CATMARK_QUAD_FACE_VERTEX and CATMARK_TRI_QUAD_FACE_VERTEX compute kernels optimization that takes advantage of all-quads or all-triange-and-quads meshes Bug Fixes Fix a compiler error in the GLSL Transform Feedback kernels on OS X Fix boundary interpolation in osdutil Fix bilinear stencil tangent computions Release 2.5.0 New Features Add ability to generate triangle patches for a uniformly subdivided mesh Add new example topologySharing Add interleaved buffer mode in glViewer Add GLSL compute kernel to glBatchViewer Add TBB compute kernel to glBatchViewer Add a PullDown widget to our HUD in examplescommon GUI updates cosmetic changes to GL example code Adding a programmable image shader to gl_hud Code cleanup for GLFrameBuffer in examplescommon Implement C-API accessor to evaluator topology osdutil Add command line option to CMakes options Add a CMake option to disable OpenCL Add a FindCLEW.cmake module in anticipation of using CLEW as a dependency Integrate CLEW into osd library and examples Changes Change interleaved buffer support in OsdCompute Removed OsdVertexDescriptor and replaced with OsdVertexBufferDescriptor Reorganize ComputeContext and ComputeController. Reorganize EvalStencilContext and EvalStencilController Moved transient states current vertex buffer etc to controller Reorganize EvalLimitContext and EvalLimitController Moved transient states current vertex buffer etc to controller Fix adaptive isolation of sharp corner vertices Fix incorrect FarMeshFactory logic for isolating multiple corner vertices in corner patches Change EvalLimit Gregory patch kernels to the large weights table to accomodate higher valences Fix calculation of screen space LOD tess factors for transition corner patches. Add a public constructor to OsdMesh Decrease compiler warning thresholds and fix outstanding warnings Make PTex support optional Add a NO_MAYA flag to CMakeLists to disable all Autodesk Maya dependencies in the build Document NO_MAYA command line option Bug Fixes Fix mistakenly deleted memory barrier in glsl OsdCompute kernel. Fix shape_utils genRIB function to use streams correctly. Temporary workaround for the synchronization bug of glsl compute kernel Fix Hud display for higher DPI MBP retina Fix Hud d3d11 Fix examples to use GL timer query to measure the GPU draw timing more precisely Fix glViewer stop updating during freeze. Fix file permissions on farPatchTablesFactory.h Fix some meory leaks in adaptive evaluator osdutil Fix OsdUtilAdaptiveEvaluator concurrency issue Fix OsdUtilRefiner incorrect Invalid size of patch array error reporting. Fix OsdUtilPatchPartitioner failure for triangle patches Fixes a bug that causes OsdUtilPatchPartitioner to fail to rebuild the face-varying data table correctly for triangle patches. Add missing third parameter to templated OsdDrawContext usage osdutilbatch.h Return success status from openSubdiv_finishEvaluatorDescr osdutil Remove debugging stdcout calls osdutil Build errors warnings Fix OSX Core Profile build GLFrameBuffer Fix ptexViewer build error on OSX Fix framebuffer shader compiling for OSX Reordering includes to address a compile error on OSXglew environment Fix compilation errors with CLEW enabled Fix icc build problems Fix compiler warnings in OsdClVertexBuffer Fix compilation error on windowsmsvc2013 Fix build warningserrors with VS2010 Pro Fix Windows build warning in FarPatchTablesFactory Fix doxygen generation errors Release 2.4.1 Changes Add correct OpenSubdiv namespace beginend blocks. Bug Fixes Compile osdutil with -fPIC for correct linking. Fix a bug of OsdUtilMeshBatch, the varying buffer isnt computed with CL kernels Fix FindGLFW.cmake to use the GLFW_LOCATION environment variable in Windows Fix Draw contexts do not fully initialize patch arrays Release 2.4.0 New Features Adding functionality to store uniform face-varying data across multiple levels of subdivision Add OsdUtilPatchPartitioner. It splits patcharray into subsets so that clients can draw partial surfaces for both adaptive and uniform. Changes Remove FarMesh dependency from OsdContext. Use DSA APIs for GL buffer update if available. Refactor Far API replace void- of all kernel applications with CONTEXT template parameter. It eliminates many static_casts from void- for both far and osd classes. move the big switch-cases of far default kernel launches out of Refine so that osd controllers can arbitrary mix default kernels and custom kernels. change FarKernelBatchkernelType from enum to int, clients can add custom kernel types. remove a back-pointer to farmesh from subdivision table. untemplate all subdivision table classes and template their compute methods instead. Those methods take a typed vertex storage. remove an unused argument FarMesh from the constructor of subdivision table factories. Refactor FarSubdivisionTables. Delete scheme specialized subdivision tables. The base class FarSubdivisionTables already has all tables, so we just need scheme enum to identify which scheme the subdivision tables belong to. This brings a lot of code cleanups around far factory classes. Move FarMultiMeshFactory to OsdUtil. Move table splicing functions of FarMultiMeshFactory into factories Change PxOsdUtil prefix to final OsdUtil prefix. Improve error reporting in osdutil refinement classes, and fix a build issue Bug Fixes Fix another multi mesh splicing bug of face varying data. Make CMake path variables more robust Fixing a crash on Marvericks wglew Update dxViewer example documentation Fix wrong logic in openSubdiv_setEvaluatorCoarsePositions Remove debug print from adaptive evaluators initialization Release 2.3.5 New Features Add the ability to read obj files to the dxViewer example Add screen-capture function to ptexViewer Update documention for Xcode builds Add documentation boundary interpolation rules and face-varying boundary interpolation rules Changes Refactoring FarPatchTables and FarPatchTablesFactory Move GL vertex buffer VBO buffer allocation out of allocate and into BindVBO Enable uvViewer on OS X now that Mavericks is released. Replacing un-necessary dynamic_cast with reinterpret_cast within FarDispatcher Minor code cleanup of FarMeshFactory Remove address space qualifiers from OpenCL kernel functions Fix OpenCL initialization to be slightly more robust Add OpenCL header include paths where necessary Add static specifiers for non-kernel CL funcs at program scope Add stddef.h to pythonosdosdshim.i Modify ptexViewer and uvViewer shaders to address some portability issues Bug Fixes Fix Gregory Boundary patch buffer overrun Fix black texels when the resolution of a ptex face is less than 4 Fix a splicing bug in FarMultiMeshFactory Fix a build error when using older versions of GLFW Fix build warnings optimized Fix FindTBB.cmake Fix FindMaya.cmake Fix glViewer support for GLSL compute Fix ptexViewer enable specular pass in both IBL and point lighting Fix Zlib include in ptexViewer Fix ptexViewer shader errors. Fix osdPolySmooth Maya plugin Fix UV merging in osdPolySmooth code example Add cleanup function to osdPolySmooth Maya plugin Fix Maya OsdPolySmooth node component output Fix GLSL array instantiation syntax for glStencilViewer Fix examples to run correctly on high DPI displays with GLFW 3 Release 2.3.4 New Features Adding CPUOMPTBB Context Controller pairs for CPU evaluation of smooth normals Added adaptiveEvaluator class inspired by Sergeys work in blender OsdUtil Changes Changed the HUD to ignore mouse clicks when not visible. Updates for blender development OsdUtil Add C compatible API to access the adaptiveEvaluator class from non-C OsdUtil Update license headers to apache OsdUtil CMake build improvement make osd a cmake object library remove compiling redundancies Improve stringification of shaders kernels in CMake build Bug Fixes Fixed iOS build Fixed VS2010 warningserrors. Fix OsdCpuEvalLimitKernel Fix maxvalence calculation in FarMeshFactory Fix FarStencilFactory control stencil caching Removing assert for high-valence vertices running off limit tangent pre-computed table. Fix degenerate stencil limit tangent code path. Fix unused variable build warnings gcc 4.8.2 - Fedora 19 Fix build warning from osdutiladaptiveEvaluator.cpp Release 2.3.3 Changes Modify Far remapping of singular vertices to point to their source vertex. Refactoring Ptex Mipmap and Analytic Displacement code Adding some documentation for Chaikin crease rule Misc. improvements to PxOsdUtilsMesh Adding recommended isolation output to OsdPolySmooth node Bug Fixes Adding an error check on version parsing of main CMakeLists Fix regex in FindMaya.cmake that breaks with recent versions of Maya Fix crashes induced by typeid Fixed VS2010 build warning Fix build break in hbr_regression Fix incorrect capitalization in GL ptexViewer shader.glsl Fix OSX build add stdlib.h include Release 2.3.2 New Features Adding control cage drawing to ptexViewer Adding Maya osdPolySmooth plugin into OpenSubdiv examples. Changes Removing some glGetError checks that are causing problems for Autodesk D3D11DrawRegistry returns the common shader config for all non-tess patcharrays. Updates to simple cpu osdutil classes Bug Fixes Fix Hbr Chaikin crease rule Fix Chaikin tag parsing Fix return value of allocate function for OsdCPUGLVertxBuffer Fixed GLSL shader portability. Fix FindGLFW.cmake for GLFW 3.03 on OSX Fixed compiler warnings. Fixed VS2010 build errors Fixed WIN32 build error when no DXSDK installed. Fix OSX build stdlib.h needs to be included in glPtexMipmapTexture.h Fix for crash in new meshrefiner code in OsdUtil Release 2.3.1 New Features Add DX11 version of ptex mipmap loader Add DX11 ptex viewer work in progress Add DX11 fractional partitioning, normal derivatives computation Add memory usage controls to Ptex loader Add face-varying boundary interpolation parsing to shape_utils Add simple HbrMesh and FarMesh wrapper classes to osdutil Changes Amend language of attribution file NOTICE.txt Optimize a bit of ptex mipmap lookup. Show ptex memory usage in GL and DX11 ptexViewers Improve ptex guttering Addding some video links to our collection of external resources Bug Fixes Fix edge-only face-varying interpolation Fix Far to handle disconnected vertices in an Hbr mesh Fixed ptex cache resource release sequence Fix build symbol conflict in Far Fix patch parambuffer generation in OsdD3D11DrawContext Fix a minor osdutil build warning seen with gcc 4.8.1 Fix VS2010 build errors Release 2.3.0 New Features Added Analytical displacement mapping Analytic Displacement Mapping using Hardware Tessellation Niessner and Loop TOG 2013 Added a new ptex mipmap loader Added face varying macros for loop subdivision Added the uvViewer example to see how face varying interpolation rule works Added a slider component and cleanup hud code. Changes Adding license attribution files, improved language of the code headers Install documentation into the Filesystem Hierarchy Standard location Set GLFW_OPENGL_FORWARD_COMPAT on Mac OS to make samples work on that platform Added surface normal mode mipmap to ptxViewer Bug Fixes Fix a bug of bad fvar splicing for loop surface. Fix incorrect bilinear limit tangents in FarStencilTablesFactory Fix boundary interpolation rules doc Added an error check on updating cuda buffer Fix face varying rendering on loop surface Fixed glBatchViewer build for GLFW 2.x Expand search paths for FindGLFW.cmake for Debian and other Linux architectures Fix CMake executable builds for ICC Fix bhr baseline regression, so reference files are real OBJs Fixed clKernelBundle.cpp to build on Android. Fix misc build warings Release 2.2.0 New Features Added subdivision stencil functionality Far OsdEval Bug Fixes Fix D3D11DrawContext to check for NULL pointers Fix cpuEvalLimitController crash bug Fixed search path suffixes for ICC libs Fixed invalid initialization of glslTransformFeedback kernel. Release 2.1.0 New Features Added TBB Compute back-end on Linux contribution from Sheng Fu Added support for ICC compiler still Beta Changes Added constructor to OsdMesh with a FarMesh as input Modify CMake to name and sym-link DSOs based on Linux ABI versioning spec Added command line input to DX11 viewer FarMultiMesh can splice uniform and adaptive meshes together. Bug Fixes Fix FarMultiMesh splicing Removed unnecessary cudaThreadSynchronize calls. Fix glViewer overlapping HUD menus Fix facevarying rendering in glBatchViewer Fix build of GLSL transform feedback kernels Fix Getting Started documentation Release 2.0.1 New Features New CLA files to reflect Apache 2.0 licensing Changes Move all public headers to includeopensubdiv... Adding Osd documentation based on Siggraph slides Bug Fixes Fix incorrect transition pattern 3 in GLSL HLSL shaders Fix CMake build to not link GPU-based libraries into libosdCPU Fix support for GLEW on OSX Fix GLFW Xrandr xf86vmode dependency paths for X11 based systems Fix HUD display overlaps in code examples Fix FindGLEW.cmake to be aware of multiarch on linux systems Fix some hard-coded include paths in CMake build Release 2.0.0 New Features New CMake build flags NO_LIB, NO_CUDA, NO_PYTHON Changes OpenSubdiv is now under Apache 2.0 license HbrHalfedge and HbrFVarData copy constructors are now private Documentation style matched to graphics.pixar.com new content Add an animation freeze button to ptexViewer Variable name changes for better readability across all example shader code Bug Fixes Fix incorrect patch generation for patches with 2 non-consecutive boundary edges Fix undefined gl_PrimitiveID shader build errors Fix for shader macro OSD_DISPLACEMENT_CALLBACK Fix out-of-bounds stdvector access in FarPatchTablesFactory Release 1.2.4 New Features Adding support for fractional tessellation of patches Adding a much needed API documention system based on Docutils RST markup Adding support for face-varying interpolation in GLSL APIs Adding varying data buffers to OsdMesh Adding accessors to the vertex buffers in OsdGlMesh Adding face-varying data to regression shapes Changes Cleanup of common bicubic patch shader code GLSL HLSL for portability ATI OSX drivers Bug Fixes Fix FarVertexEditTablesFactory to insert properly vertex edit batches fixes incorrect hierarchical hole in regression shape Fix FarPatchMap quadtree to not drop top-level non-quad faces Fix Gregory patches bug with incorrect max-valence Fix FarPatchTablesGetNumFaces and FarPatchTablesGetFaceVertices functions to return the correct values Fix face indexing GLSL code ptex works on non-quads again Fix face-varying data splicing in FarMultiMeshFactory Fix ptex face indexing in FarMultiMeshFactory Fix glew include to not break builds Fix Clang ICC build failures with FarPatchTables Fix build and example code to work with GFLW 3.0 Fix cmake to have ptex dynamically linked in OSX Release 1.2.3 New Features Adding Varying and Face-Varying data interpolation to EvalLimit Changes EvalLimit API refactor the EvalContext now has dedicated structs to track all the vertex, varying and face-varying data streams. Also renamed some buffers into tables to maintain code consistency EvalLimit optimization switch serial indexing to a quad-tree based search Bug Fixes Face-varying data bug fixes making sure the data is carried around appropriately Fixes for OpenCL use with the new batching APIs GLSL general shader code cleanup fixes for better portability GLSL Tranform Feedback initialization fix Critical fix for FarMultiMesh batching indexing was incorrect Fix osdutil CL implementation protect includes on systems with no OpenCL SDK installed Fix face-varying interpolation on adaptive patches FarPatchTables fix IsFeatureAdaptive to return the correct answer Fix Far factories to handle the absence of face-varying data correctly. Many GLSL shader code style fixes which should help with ATI OSX shader compiling Release 1.2.2 New Features Introducing the EvalLimit API the Eval module aims at providing support for computational tasks that are not related to drawing the surfaces. The EvalLimit sub-module provides an API that enables client code to evaluate primitive variables on the limit surface. OsdxxxComputeController minor optimization. Added early exit to Refine method to avoid unnecessary interop. Changes OsdGLDawContext minor API change. Protecting some member variables and adding const accessors OsdError minor API refactor, added Warning functions. Bug Fixes Fix Ptex bug prevent corner texel guttering code to from going into infinite loops Adding the ability for a FarMeshFactory to construct patchTables starting from firstLevel in uniform subdivision mode Consolidating the color coding of bicubic patch types through all our our code examples this is used mostly as a debugging tool Fixing some MSVC build warnings Update to the outdated README.md Release 1.2.1 New Features Added CUDA runtime error checking Release 1.2.0 Changes Major Far refactor around patchTables to introduce the draw batching API Renaming osd_util to osdutil Bug Fixes Fix GLSL transform feedback initialization bug in ptexViewer Minor bug typo fixes Release 1.1.0 New Features release initiated because of the switch to Git Flow Release 1.0.0 Oringal release Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "Overview of Release 3.2", │ │ │ │ │ + "text": "Overview of Release 3.2 Overview of Release 3.2 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Face-Varying Stencil Evaluation 1st and 2nd Derivative Evaluation Smooth Corner Patch API Additions OsdCpuEvaluator, GLComputeEvaluator, etc OsdMesh OsdMeshBits FarPatchTableFactoryOptions FarStencilTableFactory FarStencilTableFactoryOptions Other Changes Improvements Bug Fixes New Features Face-Varying Stencil Evaluation Face-Varying primvar values may now be refined using stencil tables. The stencil table for a face-varying channel is created by specifying the desired fvarChannel and setting the FarStencilTableFactoryOption interpolationMode to INTERPOLATE_FACE_VARYING when creating the stencil table. 1st and 2nd Derivative Evaluation The Osd Evaluator API has been extended to support 1st derivative and 2nd partial derivative evaluation for stencils and patches. 1st Derivative Surface Normal 2nd Derivative Surface Curvature On the left is an example of computing a surface normal at each point using the evaluated 1st derivatives, while on the right is an example of computing surface curvature at each point using the evaluated 2nd partial derivatives. Smooth Corner Patch An option has been added to disable the legacy behavior of generating a sharp-corner patch at a smooth corner. Corners which are actually sharp will continue to generate sharp-corner patches. The differences between the two methods is most apparent at low-levels of feature isolation. This feature is controlled by the generateLegacySharpCornerPatches option added to FarPatchTableFactoryOptions. Sharp Corner Patch legacy behavior Smooth Corner Patch On the left is the legacy behavior of generating sharp corner patches at smooth corners. The image on the right shows the correct smooth corner patches generated when this legacy behavior is disabled. API Additions See associated Doxygen for full details. OsdCpuEvaluator, GLComputeEvaluator, etc Create EvalStencils EvalPatches EvalPatchesVarying EvalPatchesFaceVarying OsdMesh Create OsdMeshBits member MeshUseSmoothCornerPatch FarPatchTableFactoryOptions member generateLegacySharpCornerPatches FarStencilTableFactory enumeration ModeINTERPOLATE_FACE_VARYING AppendLocalPointStencilTableFaceVarying FarStencilTableFactoryOptions member fvarChannel Other Changes Improvements Corrected numerous spelling errors in doxygen comments Updated glFVarViewer with improved error detection and command line parsing Added option to build using MSVC with static CRT Bug Fixes Fixed a double delete of GL program in OsdGLComputeEvaluator Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "release_notes_2x.html" │ │ │ │ │ + "loc": "release_32.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "Overview of Release 3.4", │ │ │ │ │ "text": "Overview of Release 3.4 Overview of Release 3.4 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Triangular Patches for Loop Subdivision Major Improvements to Introductory Documentation Sparse Patch Tables Support for Double Precision in Far API Additions Far extensions for triangular patches Construction and refinement of topology Construction and interface of FarPatchTable Construction and use of Far stencil tables Far class templates for double precision Far member functions converted to templates for double precision OsdMeshBits OsdPatchArray Osd extensions for patch evaluation common to all shaders Osd extensions for patch tessellation common to all shaders Other Changes Improvements Bug Fixes New Features Triangular Patches for Loop Subdivision Support for the drawing and evaluation of Loop subdivision meshes with triangular patches was added. This includes the full set of Far and Osd interfaces for both evaluation and drawing. The feature set supported for Loop subdivision now matches that of Catmark, including creases, face-varying patches, non-manifold topology, etc. The long standing requirement that Loop meshes be purely triangular remains, as Loop subdivision is not defined for non-triangular faces. And as is the case with the use of the Catmark scheme, application of Loop subdivision to dense, poorly modeled meshes may lead to unexpectedly poor performance andor surface quality. The patch representation used for Loop subdivision is intended to exactly match the underlying limit surface where regular, and so uses quartic triangular Box-splines. This is in contrast to approaches that use simpler patches to approximate the Loop limit surface everywhere. As with Catmark, Gregory patches are used to approximate irregular areas. Though other choices are available that compromise surface quality in favor of improved performance, they may be less effective with Loop than they are with Catmark. Major Improvements to Introductory Documentation A significant rewrite of the Subdivision Surfaces page is included in this release. The new documentation emphasizes the piecewise parametric surface nature of subdivision surfaces and the implications of supporting arbitary topology . As a true surface primitive, the distinction between the control points and the limit surface and the corresponding operations of subdivision and tessellation that are applied to them is made clear. Sparse Patch Tables Interfaces in Far for the construction of PatchTables and the required adaptive refinement have been extended to apply to an arbitrary subset of faces. This allows patches for either large meshes or meshes that may otherwise benefit from some kind of partioning e.g. areas of static and dynamic topology to be managed in an arbitrary number of groups. In the extreme, a PatchTable forming the tree of patches for a single base face can be constructed. Client data buffers for the base mesh do not need to be partitioned and base mesh topology can be shared by multiple instances of FarTopologyRefiner used to create corresponding instances of FarPatchTables. See the new Far tutorial 5.2 for a simple example. Support for Double Precision in Far Classes and interfaces in Far have been adapted to allow support for double precision via templates parameterized for float or double. Class templates for major classes such as FarStencilTable have been introduced and the original classes preserved for compatibility. Other classes such as FarPatchTable have had methods overloaded or replaced with template functions to support both single and double precision. Internally, all use of floating point constants and math library functions has been adapted to maximize accuracy appropriate to the precision of the template instance. Interfaces in Osd have not been extended. The extensions in Far provide the basis for extensions in Osd, but demand is limited. For those benefiting from such Osd extensions, contributions are welcomed. See the revised Far tutorial 5.1 that constructs a FarPatchTable for a simple example. API Additions See associated Doxygen for full details. Far extensions for triangular patches enum PatchDescriptorTypeGREGORY_TRIANGLE PatchParamNormalizeTriangle PatchParamUnnormalizeTriangle PatchParamIsTriangleRotated Construction and refinement of topology overloaded TopologyRefinerFactoryCreate extensions to TopologyRefinerRefineAdaptive Construction and interface of FarPatchTable overloaded PatchTableFactoryCreate PatchTableFactoryGetRefineAdaptiveOptions member PatchTableFactoryOptionsincludeBaseLevelIndices member PatchTableFactoryOptionsincludeFVarBaseLevelIndices member PatchTableFactoryOptionsgenerateVaryingTables member PatchTableFactoryOptionsgenerateVaryingLocalPoints member PatchTableFactoryOptionssetPatchPrecisionDouble member PatchTableFactoryOptionssetFVarPatchPrecisionDouble PatchTableGetFVarPatchDescriptorRegular PatchTableGetFVarPatchDescriptorIrregular PatchTableGetFVarValueStride Construction and use of Far stencil tables overloaded StencilTableUpdateValues enum LimitStencilTableFactoryMode member LimitStencilTableFactoryOptionsinterpolationMode member LimitStencilTableFactoryOptionsfvarChannel Far class templates for double precision class StencilReal class StencilTableReal class StencilTableFactoryReal class LimitStencilReal class LimitStencilTableReal class LimitStencilTableFactoryReal class PrimvarRefinerReal Far member functions converted to templates for double precision PatchParamNormalize PatchParamUnnormalize PatchTableEvaluateBasis PatchTableEvaluateBasisVarying PatchTableEvaluateBasisFaceVarying PatchTableGetLocalPointStencilTable PatchTableGetLocalPointVaryingStencilTable PatchTableGetLocalPointFaceVaryingStencilTable PatchMapFindPatch OsdMeshBits enumeration MeshEndCapBilinearBasis OsdPatchArray GetDescriptorRegular GetDescriptorIrregular GetPatchTyperRegular GetPatchTyperIrregular GetStride Osd extensions for patch evaluation common to all shaders struct OsdPatchArray and OsdPatchArrayInit struct OsdPatchCoord and OsdPatchCoordInit struct OsdPatchParam and OsdPatchParamInit OsdPatchParamGetFaceId OsdPatchParamGetU OsdPatchParamGetV OsdPatchParamGetTransition OsdPatchParamGetBoundary OsdPatchParamGetNonQuadRoot OsdPatchParamGetDepth OsdPatchParamGetParamFraction OsdPatchParamIsRegular OsdPatchParamIsTriangleRotated OsdPatchParamNormalize OsdPatchParamUnnormalize OsdPatchParamNormalizeTriangle OsdPatchParamUnnormalizeTriangle OsdEvaluatePatchBasisNormalized OsdEvaluatePatchBasis Osd extensions for patch tessellation common to all shaders OsdInterpolatePatchCoordTriangle OsdComputePerPatchVertexBoxSplineTriangle OsdEvalPatchBezierTriangle OsdEvalPatchGregoryTriangle OsdGetTessLevelsUniformTriangle OsdEvalPatchBezierTessLevels OsdEvalPatchBezierTriangleTessLevels OsdGetTessParameterizationTriangle Other Changes Improvements Added new build script GitHub 1068 Added support for newer DirectX SDKs GitHub 1066 Patch arrays extended to support combined regular and irregular types GitHub 995 FarPatchTables and adaptive refinement supported for Bilinear scheme GitHub 1035 New FarPatchTableFactory method to determine adaptive refinement options GitHub 1047 New FarPatchTableFactory options to align primvar buffers of uniform tables GitHub 986 FarStencilTableUpdateValues overloaded to support separate base buffer GitHub 1011 FarLimitStencilTableFactory updated to create face-varying tables GitHub 1012 Regular patches on boundaries no longer require additional isolation GitHub 1025 Inclusion of OpenSubdiv header files in source code now consistent GitHub 767 Re-organization of and additions to Far tutorials GitHub 1083 Examples now use common command-line conventions and parsing GitHub 1056 Bug Fixes Fixed FarPrimvarRefiner internal limitFVar prototype GitHub 979 Fixed FarStencilTable append when base StencilTable empty GitHub 982 Patches around non-manifold vertices now free of cracks GitHub 1013 Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "release_34.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Overview of Release 3.5", │ │ │ │ │ - "text": "Overview of Release 3.5 Overview of Release 3.5 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Simplified Surface Evaluation Tessellation Patterns API Additions New classes in namespace Bfr Additions to FarTopologyLevel Additions to nested Options classes in Far Other Changes Deprecation Announcements Improvements Bug Fixes New Features Simplified Surface Evaluation The new Bfr interface provides an alternative to Far and Osd for evaluating the limit surface -- treating a subdivision mesh as a piecewise parameteric surface primitive . The Bfr interface is named for Base Face Representation as all concepts and classes relate to the individual faces of the original unrefined mesh, i.e. its base faces. Each base face has a piece of limit surface associated with it BfrSurface that is parameterized BfrParameterization and so can be evaluated and tessellated The limit surface for each face can be identified and evaluated independently of any other faces without any global pre-processing of a connected mesh. The resulting evaluation interface is much simpler, more flexible and more scalable than those assembled with the table-based class in Far -- providing a preferable alternative for many CPU-based use cases though not all. See the Bfr Overview documentation for more details. Tessellation Patterns In addition to evaluation, the Bfr interface includes a Tessellation class that provides tessellation patterns for all faces of a base mesh. A Tessellation does not encapsulate the entire tessellation process but simply provides topological patterns to assemble such a process. All faces of a mesh have a Parameterization which can be used to define a Tessellation with the specification of one or more tessellation rates. A single tessellation rate defines simple uniform tessellations while tessellation rates for each edge provide more complex non-uniform patterns A small set of options is also available to define the resulting patterns e.g. the preservation of quad faces with quad-based subdivision schemes above left and center and to generate its output in a more favorable form. Tessellation patterns do not support the full flexibility of typical hardware tessellation e.g. no fractional tessellation but do provide some useful alternatives to hardware tessellation e.g. the quad preservation previously noted, and more uniform triangles for triangular patches above right . The Tessellation class is also completely independent of evaluation in Bfr , and so can be used with any other evaluation interface. See the Tessellation subsection of the Bfr Overview for more details. API Additions See associated Doxygen for full details. New classes in namespace Bfr class Parameterization class Surface class SurfaceFactory class SurfaceFactoryCache class SurfaceFactoryMeshAdapter class RefinerSurfaceFactory class Tessellation Additions to FarTopologyLevel TopologyLevelIsVertexCorner TopologyLevelIsVertexRegular TopologyLevelIsVertexInfSharp TopologyLevelIsVertexSemiSharp TopologyLevelIsEdgeInfSharp TopologyLevelIsEdgeSemiSharp Additions to nested Options classes in Far PatchTableFactoryOptionsSetMaxIsolationLevel TopologyRefinerUniformOptionsSetRefinementLevel TopologyRefinerAdaptiveOptionsSetMaxIsolationLevel TopologyRefinerAdaptiveOptionsSetMaxSecondaryLevel Other Changes Deprecation Announcements Hbr is deprecated and will be removed from subsequent releases Improvements Suppression of GCC compiler warnings GitHub 1253, 1254, 1270 Additional methods for FarTopologyLevel GitHub 1227, 1255 Improved mixed partial derivative at Gregory patch corners GitHub 1252 Minor improvements to Far tutorials GitHub 1226, 1241 Added CMake config GitHub 1242 Updated CMake minimum version to 3.12 GitHub 1237, 1261 Updated documentation build scripts for Python 3 1265, 1266 Updated stringify build tool for improved cross compilation support GitHub 1267 Added NO_MACOS_FRAMEWORKS build option GitHub 1238 Updated Azure pipelines agents for Unbuntu and macOS GitHub 1247, 1256 Removed obsolete AppVeyor and Travis CI scripts GitHub 1259 Bug Fixes Cache active program for OsdGLComputeEvaluator GitHub 1244 Fixed member initialization warnings in OsdD3D11ComputeEvaluator GitHub 1239 Fixed GLSL shader source to remove storage qualifiers from struct members GitHub 1271 Fixed use of CMake variables for Apple builds GitHub 1235 Fixed build errors when using OpenGL without GLFW GitHub 1257 Fixed links to embedded videos GitHub 1231 Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "Overview of Release 3.1", │ │ │ │ │ + "text": "Overview of Release 3.1 Overview of Release 3.1 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Bicubic Face-Varying Patches Varying and Face-Varying Evaluation Second Order Derivative Evaluation Separate Levels of Feature Isolation Sharp Patches for Infinitely Sharp Features API Additions OsdCpuEvaluator, GLComputeEvaluator, etc OsdCpuPatchTable, GLPatchTable, etc OsdMeshBits OsdPatchParam OsdGLSLPatchShaderSource, HLSLPatchShaderSource FarLimitStencil FarLimitStencilTable FarLimitStencilTableFactoryOptions FarPatchParam FarPatchTable FarPatchTableFactoryOptions FarTopologyLevel FarTopologyRefinerAdaptiveOptions Other Changes Improvements Bug Fixes New Features Bicubic Face-Varying Patches The motivation for this feature is to improve drawing and evaluation of face-varying primvar values for all face-varying interpolation options . A common use of non-linear face-varying data is to capture a UV projection on the surface. The following example shows a simple shape with the face-varying interpolation option assigned to a non-linear choice to achieve the desired projection in this case FVAR_LINEAR_NONE Linear Face-Varying Patches Bicubic Face-Varying Patches The result on the left shows the old linearly interpolated patches, which ignores any non-linear settings. The result on the right shows the new use of bicubic face-varying patches to accurately interpolate the desired projection. Generation of a full face-varying patch representation can be enabled using a new option in FarPatchTableFactoryOptions. Additionally, topological refinement can be improved to consider fvar channel topology using a new option in FarTopologyRefinerAdaptiveOptions. See the API additions below and their associated Doxygen text for more details. Evaluation of patch basis weights for all patch types as been added to the GPU shader source provided by OsdGLSLPatchShaderSource, and OsdHLSLPatchShaderSource. Use of non-linear face-varying patches increases the storage size of the patch table and may also require additional data access and computation while drawing. Varying and Face-Varying Evaluation This feature extends existing evaluation methods to support evaluation of varying and face-varying primvar data at arbitrary limit surface locations. Varying Primvar Evaluation Face-Varying Primvar Evaluation The image on the left shows evaluation of varying primvar values and the image on the right shows evaluation of face-varying primvar values. The EvaluateBasis API of FarPatchTable has been extended as well as the OSD Evaluator API. Second Order Derivative Evaluation This feature extends the FarLimitStencilTable and FarPatchTable interfaces to support evaluation of 2nd order partial derivatives. The generation of derivative values for FarLimitStencilTable is controlled by new options that can be specified when creating the stencil table. Additionally, the implementation exposes a more accurate method to compute derivatives for Gregory basis patches. This can be enabled using the CMake configuration and compile time definition OPENSUBDIV_GREGORY_EVAL_TRUE_DERIVATIVES. Separate Levels of Feature Isolation The primary motivation for this feature is to reduce the number of patches generated by adaptive refinement when they can be adequately represented at a lower level. A single level of isolation must be as high as the greatest semi-sharp feature to properly resolve the shape of that feature. That high isolation level generates many unnecessary patches for smooth extra-ordinary vertices. In the following example, a single semi-sharp vertex is refined to level 5 Single Isolation Level 5 Primary Level 5, Secondary Level 2 Single isolation to level 5 on the left results in 312 patches. The right shows the semi-sharp feature isolated to 5, but with the new secondary level set to 2, the number of patches is reduced to 123. The second specified level of adaptive refinement is used to halt isolation for features that typically do not require the specified maximum. These include interior and boundary extra-ordinary vertices and those infinitely sharp patches that correspond to boundary extra-ordinary patches. The secondary level is available as a new option in FarTopologyRefinerAdaptiveOptions. Sharp Patches for Infinitely Sharp Features The motivation for sharp patches is to accurately represent the limit surface of infinitely sharp features, which otherwise can only be approximated by very high levels of adaptive refinement, resulting in many unnecessary patches. The true limit surface for regular faces along an infinitely sharp crease is a regular B-Spline patch -- the same as regular faces along a boundary. Similarly, the limit surface for faces around an extra-ordinary vertex on an infinitely sharp crease is the same as that of faces around an extra-ordinary vertex on a boundary. So these patches are identified and isolated to the same degree -- the regular patches as soon as possible, and the irregular patches to the depth specified. Consider the following regressionshapecatmark_cube_creases2 Level 5 without Sharp Patches Level 5 with Sharp Patches Level 2 with Sharp Patches Without use of sharp patches on the left, isolating to level 5 generates 1764 patches and does still not capture the sharp edges. With sharp patches in the center, isolating to the same degree level 5 reduces the number of patches to 96 and captures the sharp edges. The sharp features can be captured at a lower degree with comparable accuracy as illustrated on the right where isolation to level 2 further reduces the number of patches to 42. The use of infinitely sharp patches can be enabled both at a high level as an new option to OsdMesh, or more directly when adaptively refining or construction the patch tables in FarTopologyRefinerAdaptiveOptions and FarPatchTableFactoryOptions. Given the improved accuracy and reduced patches by the use of simple regular patches, we would prefer that this be the default behavior, but it was made an explicit option in order to avoid disrupting existing usage. In a future major release this feature will hopefully be the norm. API Additions See associated Doxygen for full details. OsdCpuEvaluator, GLComputeEvaluator, etc EvalPatchesVarying EvalPatchesFaceVarying OsdCpuPatchTable, GLPatchTable, etc GetFVarPatchArrayBuffer GetFVarPatchIndexBuffer GetFVarPatchIndexSize GetFVarPatchParamBuffer GetFVarPatchParamSize GetNumFVarChannels GetVaryingPatchArrayBuffer GetVaryingPatchIndexBuffer GetVaryingPatchIndexSize OsdMeshBits member MeshFVarAdaptive member MeshUseInfSharpPatch OsdPatchParam IsRegular Unnormalize extensions to Set OsdGLSLPatchShaderSource, HLSLPatchShaderSource GetPatchBasisShaderSource FarLimitStencil GetDuuWeights GetDuvWeights GetDvvWeights extensions to LimitStencil FarLimitStencilTable GetDuuWeights GetDuvWeights GetDvvWeights Update2ndDerivs extensions to LimitStencilTable FarLimitStencilTableFactoryOptions member generate1stDerivatives member generate1stDerivatives extensions to LimitTableStencilFactoryCreate FarPatchParam IsRegular Unnormalize extensions to Set FarPatchTable ComputeLocalPointValuesFaceVarying ComputeLocalPointValuesVarying GetFVarPatchDescriptor GetFVarPatchParam GetNumLocalPointsFaceVarying GetNumLocalPointsVarying GetPatchArrayVaryingVertices GetPatchArrayFVarPatchParam GetPatchArrayFVarValues GetPatchFVarPatchParam GetPatchVaryingVertices GetVaryingPatchDescriptor GetVaryingVertices EvaluateBasisFaceVarying EvaluateBasisVarying extensions to EvaluateBasis FarPatchTableFactoryOptions member useInfSharpPatch member genenerateFVarLegacyLinearPatches FarTopologyLevel DoesEdgeFVarTopologyMatch DoesFaceFVarTopologyMatch DoesVertexFVarTopologyMatch IsEdgeBoundary IsEdgeNonManifold IsVertexBoundary IsVertexNonManifold FarTopologyRefinerAdaptiveOptions member secondaryLevel member useInfSharpPatch member considerFVarChannels Other Changes Improvements Enabled the use of CMakes folder feature Removed the use of iso646 alternative keywords and, or, not, etc. to improve portability Added numerical valued preprocessor directives OPENSUBDIV_VERSION_MAJOR, etc. to opensubdivversion.h Improved documentation for FarPatchParam and added Unnormalize to complement Normalize Added additional topology queries to FarTopologyLevel Updated glFVarViewer and glEvalLimit viewer to make use of bicubic face-varying patches Updated glViewer and dxViewer to add a toggle for InfSharpPatch Updated dxPtexViewer for improved feature parity with glPtexViewer Improved far_regression to exercise shapes independent of Hbr compatibility Added support for Appveyor continuous integration testing Removed cmakeFindIlmBase Removed mayaPolySmooth example Bug Fixes Fixed Ptex version parsing and compatibility issues Fixed compatibility issues with VS2015 Fixed bug interpolating face-varying data with Bilinear scheme Fixed bug with refinement using Chaikin creasing Fixed bugs with HUD sliders in the example viewers Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "release_35.html" │ │ │ │ │ + "loc": "release_31.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "Overview of Release 3.3", │ │ │ │ │ "text": "Overview of Release 3.3 Overview of Release 3.3 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Metal Compute and Tessellation API Additions OsdMTLContext OsdMTLComputeEvaluator OsdMTLStencilTable OsdMTLMeshInterface OsdMTLPatchTable OsdMTLLegacyGregoryPatchTable OsdPatchShaderSource OsdCPUMTLVertexBuffer Other Changes Improvements New Features Metal Compute and Tessellation Added support for drawing and evaluation using Apples Metal API for high performance and low-overhead GPU access. This includes the full set of Osd interfaces needed to draw using Metal graphics rendering including tessellation shaders and evaluate stencils and patch tables using Metal compute processing. Also includes an example mtlViewer that can be built to run on either macOS or iOS. Metal Graphics Rendering with Tessellation Metal Patch Evaluation using Compute Processing API Additions See associated Doxygen for full details. OsdMTLContext device and commandQueue member data OsdMTLComputeEvaluator Create EvalStencils EvalPatches EvalPatchesVarying EvalPatchesFaceVarying Compile Synchronize OsdMTLStencilTable Create GetSizesBuffer GetIndicesBuffer GetDuWeightsBuffer GetDvWeightsBuffer GetDuuWeightsBuffer GetDuvWeightsBuffer GetDvvWeightsBuffer GetNumStencils OsdMTLMeshInterface GetNumVertices GetMaxValence UpdateVertexBuffer UpdateVaryingBuffer Refine Synchronize GetPatchTable GetFarPatchTable BindVertexBuffer BindVaryingBuffer OsdMTLPatchTable Create GetPatchArrays GetPatchIndexBuffer GetPatchParamBuffer GetVaryingPatchArrays GetVaryingPatchIndexBuffer GetNumFVarChannels GetFVarPatchArrays GetFVarPatchIndexBuffer GetFVarPatchParamBuffer OsdMTLLegacyGregoryPatchTable UpdateVertexBuffer GetVertexBuffer GetVertexValenceBuffer GetQuadOffsetsBuffer OsdPatchShaderSource GetCommonShaderSource GetPatchBasisShaderSource GetVertexShaderSource GetHullShaderSource GetDomainShaderSource OsdCPUMTLVertexBuffer Create UpdateData GetNumElements GetNumVertices BindCpuBuffer BindMTLBuffer BindVBO Other Changes Improvements Fixed several instances of local variable shadowing that could cause build warnings Updated continuous-integration build scripts and added testing on macOS Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "release_33.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Overview of Release 3.2", │ │ │ │ │ - "text": "Overview of Release 3.2 Overview of Release 3.2 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Face-Varying Stencil Evaluation 1st and 2nd Derivative Evaluation Smooth Corner Patch API Additions OsdCpuEvaluator, GLComputeEvaluator, etc OsdMesh OsdMeshBits FarPatchTableFactoryOptions FarStencilTableFactory FarStencilTableFactoryOptions Other Changes Improvements Bug Fixes New Features Face-Varying Stencil Evaluation Face-Varying primvar values may now be refined using stencil tables. The stencil table for a face-varying channel is created by specifying the desired fvarChannel and setting the FarStencilTableFactoryOption interpolationMode to INTERPOLATE_FACE_VARYING when creating the stencil table. 1st and 2nd Derivative Evaluation The Osd Evaluator API has been extended to support 1st derivative and 2nd partial derivative evaluation for stencils and patches. 1st Derivative Surface Normal 2nd Derivative Surface Curvature On the left is an example of computing a surface normal at each point using the evaluated 1st derivatives, while on the right is an example of computing surface curvature at each point using the evaluated 2nd partial derivatives. Smooth Corner Patch An option has been added to disable the legacy behavior of generating a sharp-corner patch at a smooth corner. Corners which are actually sharp will continue to generate sharp-corner patches. The differences between the two methods is most apparent at low-levels of feature isolation. This feature is controlled by the generateLegacySharpCornerPatches option added to FarPatchTableFactoryOptions. Sharp Corner Patch legacy behavior Smooth Corner Patch On the left is the legacy behavior of generating sharp corner patches at smooth corners. The image on the right shows the correct smooth corner patches generated when this legacy behavior is disabled. API Additions See associated Doxygen for full details. OsdCpuEvaluator, GLComputeEvaluator, etc Create EvalStencils EvalPatches EvalPatchesVarying EvalPatchesFaceVarying OsdMesh Create OsdMeshBits member MeshUseSmoothCornerPatch FarPatchTableFactoryOptions member generateLegacySharpCornerPatches FarStencilTableFactory enumeration ModeINTERPOLATE_FACE_VARYING AppendLocalPointStencilTableFaceVarying FarStencilTableFactoryOptions member fvarChannel Other Changes Improvements Corrected numerous spelling errors in doxygen comments Updated glFVarViewer with improved error detection and command line parsing Added option to build using MSVC with static CRT Bug Fixes Fixed a double delete of GL program in OsdGLComputeEvaluator Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "Overview of Release 3.0", │ │ │ │ │ + "text": "Overview of Release 3.0 Overview of Release 3.0 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Release 3.0 Subdivision Core Sdc Topology and Refinement Limit Properties and Patches Faster Evaluation and Display Updated Source-Code Style Documentation and Tutorials Additional Resources Porting Guide Subdivision Compatibility Release 3.0 OpenSubdiv 3.0 represents a landmark release, with profound changes to the core algorithms, simplified APIs, and streamlined GPU execution. Providing faster, more efficient, and more flexible subdivision code remains our principal goal. To achieve this, OpenSubdiv 3.0 introduces many improvements that constitute a fairly radical departure from previous versions. This document highlights some of the major changes that have gone in to the 3.0 release. Subdivision Core Sdc In consideration of past, present and future topological representations, all low-level details fundamental to subdivision and the specific subdivision schemes have been factored into a new low-level layer called Sdc SubDivision Core. This layer encapsulates the full set of applicable options, the formulae required to support semi-sharp creasing, the formulae for the refinement masks of each subdivision scheme, etc. As initially conceived, its goal was often expressed as separating the math from the mesh. Sdc provides the low-level nuts and bolts to provide a subdivision implementation consistent with OpenSubdiv. It is used by OpenSubdivs libraries and may also be useful in providing an existing clients implementation with the details necessary to make that implementation consistent with OpenSubdiv. Topology and Refinement OpenSubdiv 3.0 introduces a new intermediate internal topological representation named Vtr Vectorized Topology Representation. Compared to the Hbr library used in previous versions, Vtr is much more efficient for the kinds of topological analysis required by Far and is more flexible. While Hbr is no longer used by OpenSubdiv, it will remain in the source distribution for legacy and regression purposes. Faster Subdivision A major focus of the 3.0 release is performance, and the improvement to the initial refinement of a mesh required for topological analysis is close to an order magnitude often much more for uniform, but less for adaptive. Supporting for Non-manifold Topology With topology conversion no longer constrained by Hbr, OpenSubdiv is no longer restricted to meshes of manifold topology. With one exception non-triangles with Loop subdivision, any set of faces and vertices that can be represented in common container formats such as Obj or Alembic can be represented and subdivided. With future efforts to bring the functionality for the Loop scheme up to par with Catmark, that last remaining topological restriction will be removed. Simpler Conversion of Topology Several entry-points are now available for client topology, rather than the single incremental assembly of an HbrMesh that previously existed. The new topological relationships can be populated using either a high-level interface where simplicity has been emphasized, or a more complex lower-level interface for enhanced efficiency. Face Varying Topology Previously, face-varying data was assigned by value to the vertex for each face, and whether or not the set of values around a vertex was continuous was determined by comparing these values later. In some cases this could result in two values that were not meant to be shared being welded together. Face-varying data is now specified topologically just as the vertex topology is defined from a set of vertices and integer references indices to these vertices for the corner of each face, face-varying topology is defined from a set of values and integer references indices to these values for the corner of each face. So if values are to be considered distinct around a vertex, they are given distinct indices and no comparison of any data is ever performed. Note that the number of vertices and values will typically differ, but since indices are assigned to the corners of all faces for both, the total number of indices assigned to all faces will be the same. This ensures that OpenSubdivs face-varying topology matches what is often specified in common geometry container formats like Obj, Alembic and USD. Multiple channels of face-varying data can be defined and each is topologically independent of the others. Limit Properties and Patches A fundamental goal of OpenSubdiv is to provide an accurate and reliable representation of the limit surface. Improvements have been made both to the properties positions and tangents at discrete points in the subdivision hierarchy, as well as to the representations of patches used for the continuous limit surface between them. Removed Fixed Valence Tables Limit properties of extra-ordinary vertices are computed for arbitrary valence and new patch types no longer rely on small table sizes. All tables that restricted the valence of a vertex to some relatively small table size have now been removed. The only restriction on valence that exists is within the new topology representation, which restricts it to the size of an unsigned 16-bit integer 65,535. This limit could also be removed, by recompiling with a certain size changed from 16- to 32-bits, but doing so would increase the memory cost for all common cases. We feel the 16-bit limit is a reasonable compromise. Single Crease Patch OpenSubdiv 3.0 newly implements efficient evaluation of semi-smooth creases using single crease patches. With this optimization, high-order edge sharpness tags can be handled very efficiently for both computation time and memory consumption. Niessner et al., Efficient Evaluation of Semi-Smooth Creases in Catmull-Clark Subdivision Surfaces. Eurographics Short Papers. 2012. httpresearch.microsoft.comen-usumpeoplecloopEG2012.pdf New Irregular Patch Approximations While legacy Gregory patch support is still available, we have introduced several new options for representing irregular patches Legacy Gregory, fast Gregory Basis stencils, and BSpline patches. Gregory basis stencils provide the same high quality approximation of Legacy Gregory patches, but execute considerably faster with a simpler GPU representation. While BSpline patches are not as close an approximation as Gregory patches, they enable an entire adaptively refined mesh to be drawn with screen space tessellation via a single global shader configuration Gregory Basis patches require one additional global shader configuration. The new implementations of the GregoryBasis and BSpline approximations relax the previous max valence limit. Legacy Gregory patch still has a limitation of max valence typically 24, depending on the hardware capability of GL_MAX_VARYING_VECTORS. Users are still encouraged to use models with vertices of low valence for both improved model quality and performance. Faster Evaluation and Display OpenSubdiv 3.0 also introduces new data structures and algorithms that greatly enhance performance for the common case of repeated evaluation both on the CPU and GPU. Introducing Stencil Tables OpenSubdiv 3.0 replaces the serialized subdivision tables with factorized stencil tables. The SubdivisionTables class of earlier releases contained a large number of data inter-dependencies, which incurred penalties from fences or force additional kernel launches. Most of these dependencies have now been factorized away in the pre-computation stage, yielding stencil tables FarStencilTable instead. Stencils remove all data dependencies and simplify all the computations into a single trivial kernel. This simplification results in a faster pre-computation stage, faster execution on GPU, with less driver overhead. The new stencil tables Compute back-end is supported on all the same platforms as previous releases except GCD. Faster, Simpler GPU Kernels On the GPU side, the replacement of subdivision tables with stencils greatly reduces bottlenecks in compute, yielding as much as a 4x interpolation speed-up. At the same time, stencils reduce the complexity of interpolation to a single kernel launch per primitive, a critical improvement for mobile platforms. As a result of these changes, compute batching is now trivial, which in turn enabled API simplifications in the Osd layer. Unified Adaptive Shaders Adaptive tessellation shader configurations have been greatly simplified. The number of shader configurations has been reduced from a combinatorial per-patch explosion down to a constant two global configurations. This massive improvement over the 2.x code base results in significantly faster load times and a reduced per-frame cost for adaptive drawing. Similar to compute kernel simplification, this shader simplification has resulted in additional simplifications in the Osd layer. Updated Source-Code Style OpenSubdiv 3.0 replaces naming prefixes with C namespaces for all API layers, bringing the source style more in line with contemporary specifications mostly inspired from the Google C Style Guide . The large-scale changes introduced in this release generally break compatibility with existing client-code. However, this gives us the opportunity to effect some much needed updates to our code-style guidelines and general conventions, throughout the entire OpenSubdiv code-base. We are hoping to drastically improve the quality, consistency and readability of the source code. Documentation and Tutorials The documentation has been reorganized and fleshed out. This release introduces a number of new tutorials . The tutorials provide an easier entry point for learning the API than do the programs provided in examples. The examples provide more fleshed out solutions and are a good next step after the tutorials are mastered. Additional Resources Porting Guide Please see the Porting Guide for help on how to port existing code written for OpenSubdiv 2.x to the new 3.0 release. Subdivision Compatibility The 3.0 release has made some minor changes to the subdivision specification and rules. See Subdivision Compatibility for a complete list. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "release_32.html" │ │ │ │ │ + "loc": "release_30.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "References", │ │ │ │ │ "text": "References References 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE References References Analytic Displacement Mapping using Hardware Tessellation Matthias Niessner, Charles Loop ACM Transactions on Graphics, Vol. 32 No. 3 Article 26 June 2013 httpresearch.microsoft.comen-usumpeoplecloopTOG2013.pdf httpdoi.org10.11452487228.2487234 Feature Adaptive GPU Rendering of Catmull-Clark Subdivision Surfaces Matthias Niessner, Charles Loop, Mark Meyer, and Tony DeRose ACM Transactions on Graphics, Vol. 31 No. 1 Article 6 January 2012 httpresearch.microsoft.comen-usumpeopleclooptog2012.pdf httpdoi.org10.11452077341.2077347 Efficient Evaluation of Semi-Smooth Creases in Catmull-Clark Subdivision Surfaces Matthias Niessner, Charles Loop, and Guenter Greiner. Eurographics Proceedings, Cagliari, 2012 httpresearch.microsoft.comen-usumpeoplecloopEG2012.pdf httpdoi.org10.2312confEG2012short041-044 Approximating Subdivision Surfaces with Gregory Patches for Hardware Tessellation Charles Loop, Scott Schaefer, Tianyun Ni, Ignacio Castano SIGGRAPH Asia Conference Proceedings 2009 httpwww.dgp.toronto.edupeoplestamrealityResearchpdfsig98.pdf httpdoi.org10.11451661412.1618497 GPU Smoothing of Quad Meshes T. L. Ni, Y. Yeo, A. Myles, V. Goel and J. Peters Proc. IEEE SMI 2008 httpwww.cise.ufl.eduresearchSurfLabpaperssmi08.pdf httpdoi.org10.1109SMI.2008.4547938 Fast Parallel Construction of Smooth Surfaces from Meshes with TriQuadPent Facets A. Myles and T. Ni and J. Peters Eurographics Symposium on Geometry Processing 2008 httpswww.cise.ufl.eduresearchSurfLabpapers08poly.pdf httpdoi.org10.1111j.1467-8659.2008.01276.x Approximating Catmull-Clark Subdivision Surfaces with Bicubic Patches Charles Loop, Scott Schaefer ACM Transactions on Graphics, Vol. 27 No. 1 Article 8 March 2008 httpresearch.microsoft.comen-usumpeoplecloopacctog.pdf httpdoi.org10.11451330511.1330519 Rapid Evaluation of Catmull-Clark Subdivision Surfaces Jeffrey Bolz and Peter Schroder Web3D Proceedings 2002 httpwww.multires.caltech.edupubsfastsubd.pdf httpdoi.org10.1145504502.504505 Piecewise Smooth Subdivision Surfaces with Normal Control Henning Biermann, Adi Levin and Denis Zorin SIGGRAPH 2000 Conference Proceedings httpmrl.nyu.edudzorinpapersbiermann2000pss.pdf httpdoi.org10.1145344779.344841 Subdivision for Modeling and Animation Denis Zorin, Peter Schroder Course Notes of SIGGRAPH 1999 httpwww.multires.caltech.edupubssig99notes.pdf Exact Evaluation of Catmull-Clark Subdivision Surfaces at Arbitrary Parameter Values Jos Stam SIGGRAPH 98 Conference Proceedings, Annual Conference Series, July 1998 httpwww.dgp.toronto.edupeoplestamrealityResearchpdfsig98.pdf httpdoi.org10.1145280814.280945 Subdivision Surfaces in Character Animation Tony DeRose, Michael Kass, Tien Truong Proceedings of SIGGRAPH 1998 httpgraphics.pixar.comlibraryGeripaper.pdf httpdoi.org10.1145280814.280826 Efficient, Fair Interpolation Using Catmull-Clark Surfaces Mark Halstead, Michael Kass, Tony DeRose SIGGRAPH 93 Conference Proceedings httpgraphics.pixar.comlibraryFairSubdivisionpaper.pdf httpdoi.org10.1145166117.166121 Recursively generated B-spline surfaces on arbitrary topological meshes Catmull, E. Clark, J. Computer-Aided Design 10 6 1978 httpdoi.org10.10160010-448528782990110-0 Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "references.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Overview of Release 3.0", │ │ │ │ │ - "text": "Overview of Release 3.0 Overview of Release 3.0 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Release 3.0 Subdivision Core Sdc Topology and Refinement Limit Properties and Patches Faster Evaluation and Display Updated Source-Code Style Documentation and Tutorials Additional Resources Porting Guide Subdivision Compatibility Release 3.0 OpenSubdiv 3.0 represents a landmark release, with profound changes to the core algorithms, simplified APIs, and streamlined GPU execution. Providing faster, more efficient, and more flexible subdivision code remains our principal goal. To achieve this, OpenSubdiv 3.0 introduces many improvements that constitute a fairly radical departure from previous versions. This document highlights some of the major changes that have gone in to the 3.0 release. Subdivision Core Sdc In consideration of past, present and future topological representations, all low-level details fundamental to subdivision and the specific subdivision schemes have been factored into a new low-level layer called Sdc SubDivision Core. This layer encapsulates the full set of applicable options, the formulae required to support semi-sharp creasing, the formulae for the refinement masks of each subdivision scheme, etc. As initially conceived, its goal was often expressed as separating the math from the mesh. Sdc provides the low-level nuts and bolts to provide a subdivision implementation consistent with OpenSubdiv. It is used by OpenSubdivs libraries and may also be useful in providing an existing clients implementation with the details necessary to make that implementation consistent with OpenSubdiv. Topology and Refinement OpenSubdiv 3.0 introduces a new intermediate internal topological representation named Vtr Vectorized Topology Representation. Compared to the Hbr library used in previous versions, Vtr is much more efficient for the kinds of topological analysis required by Far and is more flexible. While Hbr is no longer used by OpenSubdiv, it will remain in the source distribution for legacy and regression purposes. Faster Subdivision A major focus of the 3.0 release is performance, and the improvement to the initial refinement of a mesh required for topological analysis is close to an order magnitude often much more for uniform, but less for adaptive. Supporting for Non-manifold Topology With topology conversion no longer constrained by Hbr, OpenSubdiv is no longer restricted to meshes of manifold topology. With one exception non-triangles with Loop subdivision, any set of faces and vertices that can be represented in common container formats such as Obj or Alembic can be represented and subdivided. With future efforts to bring the functionality for the Loop scheme up to par with Catmark, that last remaining topological restriction will be removed. Simpler Conversion of Topology Several entry-points are now available for client topology, rather than the single incremental assembly of an HbrMesh that previously existed. The new topological relationships can be populated using either a high-level interface where simplicity has been emphasized, or a more complex lower-level interface for enhanced efficiency. Face Varying Topology Previously, face-varying data was assigned by value to the vertex for each face, and whether or not the set of values around a vertex was continuous was determined by comparing these values later. In some cases this could result in two values that were not meant to be shared being welded together. Face-varying data is now specified topologically just as the vertex topology is defined from a set of vertices and integer references indices to these vertices for the corner of each face, face-varying topology is defined from a set of values and integer references indices to these values for the corner of each face. So if values are to be considered distinct around a vertex, they are given distinct indices and no comparison of any data is ever performed. Note that the number of vertices and values will typically differ, but since indices are assigned to the corners of all faces for both, the total number of indices assigned to all faces will be the same. This ensures that OpenSubdivs face-varying topology matches what is often specified in common geometry container formats like Obj, Alembic and USD. Multiple channels of face-varying data can be defined and each is topologically independent of the others. Limit Properties and Patches A fundamental goal of OpenSubdiv is to provide an accurate and reliable representation of the limit surface. Improvements have been made both to the properties positions and tangents at discrete points in the subdivision hierarchy, as well as to the representations of patches used for the continuous limit surface between them. Removed Fixed Valence Tables Limit properties of extra-ordinary vertices are computed for arbitrary valence and new patch types no longer rely on small table sizes. All tables that restricted the valence of a vertex to some relatively small table size have now been removed. The only restriction on valence that exists is within the new topology representation, which restricts it to the size of an unsigned 16-bit integer 65,535. This limit could also be removed, by recompiling with a certain size changed from 16- to 32-bits, but doing so would increase the memory cost for all common cases. We feel the 16-bit limit is a reasonable compromise. Single Crease Patch OpenSubdiv 3.0 newly implements efficient evaluation of semi-smooth creases using single crease patches. With this optimization, high-order edge sharpness tags can be handled very efficiently for both computation time and memory consumption. Niessner et al., Efficient Evaluation of Semi-Smooth Creases in Catmull-Clark Subdivision Surfaces. Eurographics Short Papers. 2012. httpresearch.microsoft.comen-usumpeoplecloopEG2012.pdf New Irregular Patch Approximations While legacy Gregory patch support is still available, we have introduced several new options for representing irregular patches Legacy Gregory, fast Gregory Basis stencils, and BSpline patches. Gregory basis stencils provide the same high quality approximation of Legacy Gregory patches, but execute considerably faster with a simpler GPU representation. While BSpline patches are not as close an approximation as Gregory patches, they enable an entire adaptively refined mesh to be drawn with screen space tessellation via a single global shader configuration Gregory Basis patches require one additional global shader configuration. The new implementations of the GregoryBasis and BSpline approximations relax the previous max valence limit. Legacy Gregory patch still has a limitation of max valence typically 24, depending on the hardware capability of GL_MAX_VARYING_VECTORS. Users are still encouraged to use models with vertices of low valence for both improved model quality and performance. Faster Evaluation and Display OpenSubdiv 3.0 also introduces new data structures and algorithms that greatly enhance performance for the common case of repeated evaluation both on the CPU and GPU. Introducing Stencil Tables OpenSubdiv 3.0 replaces the serialized subdivision tables with factorized stencil tables. The SubdivisionTables class of earlier releases contained a large number of data inter-dependencies, which incurred penalties from fences or force additional kernel launches. Most of these dependencies have now been factorized away in the pre-computation stage, yielding stencil tables FarStencilTable instead. Stencils remove all data dependencies and simplify all the computations into a single trivial kernel. This simplification results in a faster pre-computation stage, faster execution on GPU, with less driver overhead. The new stencil tables Compute back-end is supported on all the same platforms as previous releases except GCD. Faster, Simpler GPU Kernels On the GPU side, the replacement of subdivision tables with stencils greatly reduces bottlenecks in compute, yielding as much as a 4x interpolation speed-up. At the same time, stencils reduce the complexity of interpolation to a single kernel launch per primitive, a critical improvement for mobile platforms. As a result of these changes, compute batching is now trivial, which in turn enabled API simplifications in the Osd layer. Unified Adaptive Shaders Adaptive tessellation shader configurations have been greatly simplified. The number of shader configurations has been reduced from a combinatorial per-patch explosion down to a constant two global configurations. This massive improvement over the 2.x code base results in significantly faster load times and a reduced per-frame cost for adaptive drawing. Similar to compute kernel simplification, this shader simplification has resulted in additional simplifications in the Osd layer. Updated Source-Code Style OpenSubdiv 3.0 replaces naming prefixes with C namespaces for all API layers, bringing the source style more in line with contemporary specifications mostly inspired from the Google C Style Guide . The large-scale changes introduced in this release generally break compatibility with existing client-code. However, this gives us the opportunity to effect some much needed updates to our code-style guidelines and general conventions, throughout the entire OpenSubdiv code-base. We are hoping to drastically improve the quality, consistency and readability of the source code. Documentation and Tutorials The documentation has been reorganized and fleshed out. This release introduces a number of new tutorials . The tutorials provide an easier entry point for learning the API than do the programs provided in examples. The examples provide more fleshed out solutions and are a good next step after the tutorials are mastered. Additional Resources Porting Guide Please see the Porting Guide for help on how to port existing code written for OpenSubdiv 2.x to the new 3.0 release. Subdivision Compatibility The 3.0 release has made some minor changes to the subdivision specification and rules. See Subdivision Compatibility for a complete list. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "Porting Guide 2.x to 3.0", │ │ │ │ │ + "text": "Porting Guide 2.x to 3.0 Porting Guide 2.x to 3.0 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Porting Guide 2.x to 3.0 Source Code Organization Hbr Layer Translation Subdivision Schemes and Options in Sdc Specifying Face Varying Topology and Options Far Layer Translation Ordering of Refined Vertices Osd Layer Translation Controller Objects ComputeContext, DrawContext EvalLimitContext OsdMesh OsdKernelBatch OsdVertex Feature Adaptive Shader Changes End Cap Strategies Changes to Subdivision Build Support for Combining 2.x and 3.0 Porting Guide 2.x to 3.0 This document is a high-level description of how to port exiting OpenSubdiv 2.x code to use OpenSubdiv 3.0. NOTE If your questions are not answered here, please contact us on the OpenSubdiv forum and we will be happy to help Source Code Organization Given the scale of functional changes that were being made to the public interface, we took the opportunity in 3.0 to update the coding style and organization -- most notably making use of namespaces for each library. Subdirectory Namespace Relevance hbr NA Historical, no longer used sdc Sdc New, low-level, public options, constants, etc. vtr Vtr New, internal use, topology representation far Far Revised, similar functionality with new API osd Osd Revised, similar functionality with new API Hbr Layer Translation Client mesh topology is now translated into an instance of FarTopologyRefiner instead of HbrMesh. OpenSubdiv 2.x OpenSubdiv 3.0 HbrMeshVTX_TYPE FarTopologyRefiner The FarTopologyRefiner is now the core representation of topology from which all other major classes in Far and Osd are constructed. It was designed to support efficient refinement uniform or sparse of a base mesh of arbitrary topology no manifold restrictions. Once constructed it can be directly refined to meet some need, or passed to other contexts that will refine it to meet their needs. In contrast to directly assembling an HbrMesh, the TopologyRefiner, like other classes in Far, requires a Factory class for its construction. One of the early goals of these factories was to allow a client to convert their existing boundary representation -- with its full topological traversal abilities -- directly into the TopologyRefiners representation. While this is now possible, this also represents the most complex construction process and is only recommended for usage where this conversion process is critical. Details on how to construct a TopologyRefiner can be found in the Far overview documentation. Additionally, documentation for FarTopologyRefinerFactoryMESH outlines the requirements, and Far tutorial 3.1 tutorialsfartutorial_3_1 provides an example of a factory for directly converting HbrMeshes to TopologyRefiners. Its worth a reminder here that FarTopologyRefiner contains only topological information which does include sharpness, since that is considered relating to subdivision topology and not the positions or other data associated with a mesh. While HbrMeshT required some definition of a vertex type T and dimensions of face-varying data, TopologyRefiner is more clearly separated from the data. So the construction of the TopologyRefiner does not involve data specification at all. Subdivision Schemes and Options in Sdc The creation of a new TopologyRefiner requires specification of a subdivision scheme and a set of options that are applicable to all schemes. With HbrMesh, the scheme was specified by declaring a static instance of a specific subclass of a subdivision object, and the options were specified with a number of methods on the different classes. Such general information about the schemes has now been encapsulated in the Sdc layer for use throughout OpenSubdiv. The subdivision scheme is now a simple enumerated type SdcSchemeType and the entire set of options that can be applied to a scheme is encapsulated in a single simple struct of flags and enumerated types SdcOptions. OpenSubdiv 2.x OpenSubdiv 3.0 HbrMeshTSetInterpolateBoundaryMethod SdcOptionsSetVtxBoundaryInterpolation HbrMeshTSetFVarInterpolateBoundaryMethod SdcOptionsSetFVarLinearInterpolation HbrSubdivisionTSetCreaseSubdivisionMethod SdcOptionsSetCreasingMethod Specifying Face Varying Topology and Options Both the way in which face varying data is associated with a mesh and the options used to control its interpolation have changed. The documentation on Compatibility with OpenSubdiv 2.x details the equivalence of interpolation options between Hbr and the new SdcOptionsFVarLinearInterpolation enum, while the section on Face Varying Interpolation illustrates their effects. Face varying data is now specified by index rather than by value, or as often stated, it is specified topologically. Just as vertices for faces are specified by indices into a potential buffer of positions, face varying values are specified by indices into a potential buffer of values. Both vertices and face varying values frequently referred to as FVarValues in the API are assigned and associated with the corners of all faces. In many cases this will simplify representation as many common geometry container formats such as Obj or Alembic specify texture coordinates the same way. For other cases, where a value per face-corner is provided with no indication of which values incident each vertex should be considered shared, it will be necessary to determine shared indices for values at each vertex if any non-linear interpolation is desired. Far Layer Translation While TopologyRefiner was introduced into Far as the new intermediate topology representation, several other changes were made to classes in Far to provide more modular building blocks for use by the Osd layer or directly. OpenSubdiv 2.x OpenSubdiv 3.0 FarMeshU NA, no longer needed FarSubdivisionTables FarStencilTable FarPatchTables FarPatchTable Ordering of Refined Vertices The FarMesh was previously responsible for refining an HbrMesh -- generating new vertices and faces in successive levels of refinement in the FarSubdivisionTables. Vertices were grouped and reordered from the native ordering of HbrMesh so that vertices requiring similar processing were consecutive. Such grouping alleviated most of the idiosyncrasies of HbrMeshs native ordering but not all. FarToplogyRefiner is inherently a collection of refinement levels, and within each refined level so excluding the base level, all components are still grouped for the same reasons. There are two issues here though the ordering of these groups has changed though an option exists to preserve it the ordering of components within these groups is not guaranteed to have been preserved Vertices in a refined level are grouped according to the type of component in the parent level from which they originated, i.e. some vertices originate from the center of a face face-vertices, some from an edge edge-vertices and some from a vertex vertex-vertices. Note that there is a conflict in terminology here -- face-vertices and edge-vertices most often refer to vertices incident a face or edge -- but for the sake of this discussion, we use them to refer to the component from which a child vertex originates. The following table shows the ordering of these groups in 2.x and the two choices available in 3.0. The option is the orderVerticesFromFacesFirst flag that can be set in the Option structs passed to the uniform and adaptive refinement methods of TopologyRefiner Version and option Vertex group ordering 2.x face-vertices, edge-vertices, vertex-vertices 3.0 default vertex-vertices, face-vertices, edge-vertices 3.0 orderVerticesFromFacesFirst true face-vertices, edge-vertices, vertex-vertices The decision to change the default ordering was based on common feedback the rationale was to allow a trivial mapping from vertices in the cage to their descendants at all refinement levels. While the grouping is fundamental to the refinement process, the ordering of the groups is internally flexible, and the full set of possible orderings can be made publicly available in future if there is demand for such flexibility. The ordering of vertices within these groups was never clearly defined given the way that HbrMesh applied its refinement. For example, for the face-vertices in a level, it was never clear which face-vertices would be first as it depended on the order in which HbrMesh traversed the parent faces and generated them. Given one face, HbrMesh would often visit neighboring faces first before moving to the next intended face. The ordering with FarTopologyRefiner is much clearer and predictable. Using the face-vertices as an example, the order of the face-vertices in level N1 is identical to the order of the parent faces in level N from which they originated. So if we have face-vertices Vi , Vj and Vk at some level, originating from faces Fi , Fj and Fk in the previous level, they will be ordered in increasing order of i , j and k . For uniform refinement the ordering of face vertices Vi will therefore exactly match the ordering of the parent faces Fi . For adaptive or otherwise sparse refinement, the subset of Vi will be ordered similarly, just with components missing from those not refined. The same is true of all vertices, i.e. edge-vertices and vertex-vertices, and also for other components in refined levels, i.e. the child faces and edges. For child faces and edges, more than one will originate from the same parent face or edge. In addition to the overall ordering based on the parent faces or edges, another ordering is imposed on multiple children originating from the same face or edge. They will be ordered based on the corner or end-vertex with which they are associated. In the case of refined faces, another way to view the ordering is to consider the way that faces are originally defined -- by specifying the set of vertices for the corners of each face, often aggregated into a single large array. The ordering of the set of refined faces for each level will correspond directly to such an array of vertices per face in the previous level. Osd Layer Translation Two big changes in the 3.0 API have allowed the Osd layer to be significantly simpler, the first is the move to stencil tables from subdivision tables and the second is shader simplification. With this refactoring, the focus has been to use more meaningful names and to make the data contained within an object more apparent. Controller Objects The API-specific ComputeController has been replaced with the Evaluator . It reflects the fact that stencil compute batches are significantly simpler than subdivision table compute batches. The name Evaluator was chosen with the hope that is more meaningful than the generic ComputeController moniker the Evaluator evaluates stencil and patch tables. In the 2.x code base, subdiv level buffers were always required to be allocated contiguously, however in 3.0 with the shift to stencil tables, this strict allocation scheme is no longer required. As a result, the EvalStencils and EvalPatches methods now accept both a source and a destination descriptor. OpenSubdiv 2.x OpenSubdiv 3.0 ComputeControllerRefine Osd...EvaluatorEvalStencils ComputeControllerSynchronize Osd...EvaluatorSynchronize EvalStencilsControllerUpdateValues Osd...EvaluatorEvalStencils EvalStencilsControllerUpdateDerivs Osd...EvaluatorEvalStencils EvalLimitControllerEvalLimitSample Osd...EvaluatorEvalPatches Also note that OsdVertexDescriptor has been renamed, however its data members and semantic purpose remains the same OpenSubdiv 2.x OpenSubdiv 3.0 OsdVertexBufferDescriptor OsdBufferDescriptor ComputeContext, DrawContext ComputeContext and DrawContext have been replaced with API-specific StencilTable and PatchTable objects, for example OsdGLStencilTableSSBO. OpenSubdiv 2.x OpenSubdiv 3.0 ComputeContext Osd...StencilTable e.g. GLStencilTableTBO EvalStencilsContext Osd...StencilTable DrawContext Osd...PatchTable e.g. GLPatchTable EvalLimitContext The data stored in EvalLimitContext has been merged into the Evaluator class as well. EvalCoords have been moved into their own type, OsdPatchCoords. The primary change here is that the PTex face ID is no longer part of the data structure, rather the client can use a FarPatchMap to convert from PTex face ID to a FarPatchTablePatchHandle. OpenSubdiv 2.x OpenSubdiv 3.0 EvalLimitContext PatchTable EvalLimitContextEvalCoords OsdPatchCoords types.h OsdMesh While not strictly required, OsdMesh is still supported in 3.0 as convenience API for allocating buffers. OsdMesh serves as a simple way to allocate all required data, in the location required by the API for example, GPU buffers for OpenGL. OsdKernelBatch No translation, it is no longer part of the API. OsdVertex No translation, it is no longer part of the API. Feature Adaptive Shader Changes In 3.0, the feature adaptive screen-space tessellation shaders have been dramatically simplified, and the client-facing API has changed dramatically as well. The primary shift is to reduce the total number of shader combinations, and as a result, some of the complexity management mechanisms are no longer necessary. In the discussion below, some key changes are highlighted, but deep integrations may require additional discussion please feel free to send follow up questions to the OpenSubdiv google group. The number of feature adaptive shaders has been reduced from N to exactly 1 or 2, depending on how end-caps are handled. Osd layer no longer compiles shaders, rather it returns shader source for the client to compile. This source is obtained via OsdGLSLHLSLPatchShaderSource. The API exposed in shaders to access patch-based data has been consolidated and formalized, see osdglslPatchCommon.glsl and osdhlslPatchCommon.hlsl for details. Patches are no longer rotated and transition patches have been eliminated, simplifying PatchDescriptor to a 4 bits. Additionally, FarPatchTablesDescriptor has been moved into its own class in the Far namespace. The following table outlines the API translation between 2.x and 3.0 OpenSubdiv 2.x OpenSubdiv 3.0 OsdDrawContextPatchDescriptor NA, no longer needed. OsdDrawContextPatchArray OSdPatchArray types.h FarPatchTablesPatchDescriptor FarPatchDescriptor patchDescriptor.h FarPatchTablesPatchArray made private. End Cap Strategies By default, OpenSubdiv uses Gregory patches to approximate the patches around extraordinary vertices at the maximum isolation level, this process is referred to as end-capping. If ENDCAP_BSPLINE_BASIS is specified to PatchTableFactoryOptions, BSpline patches are used, which gives less accuracy, but it makes possible to render an entire mesh in a single draw call. Both patches require additional control points that are not part of the mesh, we refer to these as local points. In 3.0, the local points of those patches are computed by applying a stencil table to refined vertices to construct a new stencil table for the local points. Since this new stencil table is topologically compatible with the primary stencil table for refinement, it is convenient and efficient to splice those stencil tables together. This splicing can be done in the following way FarStencilTable const refineStencils FarStencilTableFactoryCreatetopologyRefiner FarPatchTable cosnt patchTable FarPatchTableFactoryCreatetopologyRefiner FarStencilTable const localPointStencils patchTable-GetLocalPointStencilTable FarStencilTable const splicedStencils FarStencilTableFactoryAppendLocalPointStencilTablestopologyRefiner, refineStencils, localPointStencils NOTE Once the spliced stencil table is created, the refined stencils can be released, but the local point stencils are owned by patchTable, it should not be released. OpenSubdiv 3.0 also supports 2.x style Gregory patches, if ENDCAP_LEGACY_GREGORY is specified to PatchTableFactoryOptions. In this case, such an extra stencil splicing isnt needed, however clients must still bind additional buffers VertexValence buffer and QuadOffsets buffer. See OsdGLLegacyGregoryPatchTable for additional details. Changes to Subdivision The refactoring of OpenSubdiv 3.0 data representations presented a unique opportunity to revisit some corners of the subdivision specification and remove or update some legacy features -- none of which was taken lightly. More details are provided in Subdivision Compatibility , while the following offers a quick overview All face-varying interpolation options have been combined into a single enum. Vertex interpolation options have been renamed or removed The naming of the standard creasing method has changed from Normal to Uniform . Unused legacy modes of the smoothtriangle option have been removed. The averaging of Chaikin creasing with infinitely sharp edges has changed. Support for Hierarchical Edits has been removed. Build Support for Combining 2.x and 3.0 Running OpenSubdiv 2.0 and 3.0 in a single process is supported, however some special care must be taken to avoid namespace collisions, both in terms of run-time symbols avoid using OpenSubdivOsd, for example and in terms of build-time search paths. To support both OpenSubdiv 2.0 and 3.0 in your build environment, you can prefix the header install directory of OpenSubdiv 3.0. Do this using the build flag CMAKE_INCDIR_BASE when configuring cmake i.e. -DCMAKE_INCDIR_BASEincludeopensubdiv3 and then including files from opensubdiv3... in client code. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "release_30.html" │ │ │ │ │ + "loc": "porting.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Overview of Release 3.1", │ │ │ │ │ - "text": "Overview of Release 3.1 Overview of Release 3.1 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE New Features Bicubic Face-Varying Patches Varying and Face-Varying Evaluation Second Order Derivative Evaluation Separate Levels of Feature Isolation Sharp Patches for Infinitely Sharp Features API Additions OsdCpuEvaluator, GLComputeEvaluator, etc OsdCpuPatchTable, GLPatchTable, etc OsdMeshBits OsdPatchParam OsdGLSLPatchShaderSource, HLSLPatchShaderSource FarLimitStencil FarLimitStencilTable FarLimitStencilTableFactoryOptions FarPatchParam FarPatchTable FarPatchTableFactoryOptions FarTopologyLevel FarTopologyRefinerAdaptiveOptions Other Changes Improvements Bug Fixes New Features Bicubic Face-Varying Patches The motivation for this feature is to improve drawing and evaluation of face-varying primvar values for all face-varying interpolation options . A common use of non-linear face-varying data is to capture a UV projection on the surface. The following example shows a simple shape with the face-varying interpolation option assigned to a non-linear choice to achieve the desired projection in this case FVAR_LINEAR_NONE Linear Face-Varying Patches Bicubic Face-Varying Patches The result on the left shows the old linearly interpolated patches, which ignores any non-linear settings. The result on the right shows the new use of bicubic face-varying patches to accurately interpolate the desired projection. Generation of a full face-varying patch representation can be enabled using a new option in FarPatchTableFactoryOptions. Additionally, topological refinement can be improved to consider fvar channel topology using a new option in FarTopologyRefinerAdaptiveOptions. See the API additions below and their associated Doxygen text for more details. Evaluation of patch basis weights for all patch types as been added to the GPU shader source provided by OsdGLSLPatchShaderSource, and OsdHLSLPatchShaderSource. Use of non-linear face-varying patches increases the storage size of the patch table and may also require additional data access and computation while drawing. Varying and Face-Varying Evaluation This feature extends existing evaluation methods to support evaluation of varying and face-varying primvar data at arbitrary limit surface locations. Varying Primvar Evaluation Face-Varying Primvar Evaluation The image on the left shows evaluation of varying primvar values and the image on the right shows evaluation of face-varying primvar values. The EvaluateBasis API of FarPatchTable has been extended as well as the OSD Evaluator API. Second Order Derivative Evaluation This feature extends the FarLimitStencilTable and FarPatchTable interfaces to support evaluation of 2nd order partial derivatives. The generation of derivative values for FarLimitStencilTable is controlled by new options that can be specified when creating the stencil table. Additionally, the implementation exposes a more accurate method to compute derivatives for Gregory basis patches. This can be enabled using the CMake configuration and compile time definition OPENSUBDIV_GREGORY_EVAL_TRUE_DERIVATIVES. Separate Levels of Feature Isolation The primary motivation for this feature is to reduce the number of patches generated by adaptive refinement when they can be adequately represented at a lower level. A single level of isolation must be as high as the greatest semi-sharp feature to properly resolve the shape of that feature. That high isolation level generates many unnecessary patches for smooth extra-ordinary vertices. In the following example, a single semi-sharp vertex is refined to level 5 Single Isolation Level 5 Primary Level 5, Secondary Level 2 Single isolation to level 5 on the left results in 312 patches. The right shows the semi-sharp feature isolated to 5, but with the new secondary level set to 2, the number of patches is reduced to 123. The second specified level of adaptive refinement is used to halt isolation for features that typically do not require the specified maximum. These include interior and boundary extra-ordinary vertices and those infinitely sharp patches that correspond to boundary extra-ordinary patches. The secondary level is available as a new option in FarTopologyRefinerAdaptiveOptions. Sharp Patches for Infinitely Sharp Features The motivation for sharp patches is to accurately represent the limit surface of infinitely sharp features, which otherwise can only be approximated by very high levels of adaptive refinement, resulting in many unnecessary patches. The true limit surface for regular faces along an infinitely sharp crease is a regular B-Spline patch -- the same as regular faces along a boundary. Similarly, the limit surface for faces around an extra-ordinary vertex on an infinitely sharp crease is the same as that of faces around an extra-ordinary vertex on a boundary. So these patches are identified and isolated to the same degree -- the regular patches as soon as possible, and the irregular patches to the depth specified. Consider the following regressionshapecatmark_cube_creases2 Level 5 without Sharp Patches Level 5 with Sharp Patches Level 2 with Sharp Patches Without use of sharp patches on the left, isolating to level 5 generates 1764 patches and does still not capture the sharp edges. With sharp patches in the center, isolating to the same degree level 5 reduces the number of patches to 96 and captures the sharp edges. The sharp features can be captured at a lower degree with comparable accuracy as illustrated on the right where isolation to level 2 further reduces the number of patches to 42. The use of infinitely sharp patches can be enabled both at a high level as an new option to OsdMesh, or more directly when adaptively refining or construction the patch tables in FarTopologyRefinerAdaptiveOptions and FarPatchTableFactoryOptions. Given the improved accuracy and reduced patches by the use of simple regular patches, we would prefer that this be the default behavior, but it was made an explicit option in order to avoid disrupting existing usage. In a future major release this feature will hopefully be the norm. API Additions See associated Doxygen for full details. OsdCpuEvaluator, GLComputeEvaluator, etc EvalPatchesVarying EvalPatchesFaceVarying OsdCpuPatchTable, GLPatchTable, etc GetFVarPatchArrayBuffer GetFVarPatchIndexBuffer GetFVarPatchIndexSize GetFVarPatchParamBuffer GetFVarPatchParamSize GetNumFVarChannels GetVaryingPatchArrayBuffer GetVaryingPatchIndexBuffer GetVaryingPatchIndexSize OsdMeshBits member MeshFVarAdaptive member MeshUseInfSharpPatch OsdPatchParam IsRegular Unnormalize extensions to Set OsdGLSLPatchShaderSource, HLSLPatchShaderSource GetPatchBasisShaderSource FarLimitStencil GetDuuWeights GetDuvWeights GetDvvWeights extensions to LimitStencil FarLimitStencilTable GetDuuWeights GetDuvWeights GetDvvWeights Update2ndDerivs extensions to LimitStencilTable FarLimitStencilTableFactoryOptions member generate1stDerivatives member generate1stDerivatives extensions to LimitTableStencilFactoryCreate FarPatchParam IsRegular Unnormalize extensions to Set FarPatchTable ComputeLocalPointValuesFaceVarying ComputeLocalPointValuesVarying GetFVarPatchDescriptor GetFVarPatchParam GetNumLocalPointsFaceVarying GetNumLocalPointsVarying GetPatchArrayVaryingVertices GetPatchArrayFVarPatchParam GetPatchArrayFVarValues GetPatchFVarPatchParam GetPatchVaryingVertices GetVaryingPatchDescriptor GetVaryingVertices EvaluateBasisFaceVarying EvaluateBasisVarying extensions to EvaluateBasis FarPatchTableFactoryOptions member useInfSharpPatch member genenerateFVarLegacyLinearPatches FarTopologyLevel DoesEdgeFVarTopologyMatch DoesFaceFVarTopologyMatch DoesVertexFVarTopologyMatch IsEdgeBoundary IsEdgeNonManifold IsVertexBoundary IsVertexNonManifold FarTopologyRefinerAdaptiveOptions member secondaryLevel member useInfSharpPatch member considerFVarChannels Other Changes Improvements Enabled the use of CMakes folder feature Removed the use of iso646 alternative keywords and, or, not, etc. to improve portability Added numerical valued preprocessor directives OPENSUBDIV_VERSION_MAJOR, etc. to opensubdivversion.h Improved documentation for FarPatchParam and added Unnormalize to complement Normalize Added additional topology queries to FarTopologyLevel Updated glFVarViewer and glEvalLimit viewer to make use of bicubic face-varying patches Updated glViewer and dxViewer to add a toggle for InfSharpPatch Updated dxPtexViewer for improved feature parity with glPtexViewer Improved far_regression to exercise shapes independent of Hbr compatibility Added support for Appveyor continuous integration testing Removed cmakeFindIlmBase Removed mayaPolySmooth example Bug Fixes Fixed Ptex version parsing and compatibility issues Fixed compatibility issues with VS2015 Fixed bug interpolating face-varying data with Bilinear scheme Fixed bug with refinement using Chaikin creasing Fixed bugs with HUD sliders in the example viewers Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "OSD Overview", │ │ │ │ │ + "text": "OSD Overview OSD Overview 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE OpenSubdiv Osd Refinement Limit Stencil Evaluation Limit Evaluation with PatchTable OpenGLDX11Metal Drawing with Hardware Tessellation InterleavedBatched Buffer Configuration Cross-Platform Implementation OpenSubdiv Osd Osd contains device dependent code that makes Far structures available on various backends such as TBB, CUDA, OpenCL, GLSL, etc. The main roles of Osd are Refinement Compute stencil-based uniformadaptive subdivision on CPUGPU backends Limit Stencil Evaluation Compute limit surfaces by limit stencils on CPUGPU backends Limit Evaluation with PatchTable Compute limit surfaces by patch evaluation on CPUGPU backends OpenGLDX11Metal Drawing with hardware tessellation Provide GLSLHLSLMetal tessellation functions for patch table InterleavedBatched buffer configuration Provide consistent buffer descriptor to deal with arbitrary buffer layout. Cross-Platform Implementation Provide convenient classes to interop between compute and draw APIs These are independently used by clients. For example, a client can use only the limit stencil evaluation, or a client can refine subdivision surfaces and draw them with the PatchTable and Osd tessellation shaders. All device specific evaluation kernels are implemented in the Evaluator classes. Since Evaluators dont own vertex buffers, clients should provide their own buffers as a source and destination. There are some interop classes defined in Osd for convenience. OpenSubdiv utilizes a series of regression tests to compare and enforce identical results across different computational devices. Refinement Osd supports both uniform and feature adaptive subdivision. Once clients create a FarStencilTable for the topology, they can convert it into device-specific stencil tables if necessary. The following table shows which evaluator classes and stencil table interfaces can be used together. Note that while Osd provides these stencil table classes which can be easily constructed from FarStencilTable, clients arent required to use these table classes. Clients may have their own entities as a stencil tables as long as EvaluatorEvalStencils can access the necessary interfaces. Backend Evaluator class compatible stencil table CPU CPU single-threaded CpuEvaluator FarStencilTable TBB CPU multi-threaded TbbEvaluator FarStencilTable OpenMP CPU multi-threaded OmpEvaluator FarStencilTable CUDA GPU CudaEvaluator CudaStencilTable OpenCL CPUGPU CLEvaluator CLStencilTable GL ComputeShader GPU GLComputeEvaluator GLStencilTableSSBO GL Transform Feedback GPU GLXFBEvaluator GLStencilTableTBO DX11 ComputeShader GPU D3D11ComputeEvaluator D3D11StencilTable Metal GPU MTLComputeEvaluator MTLStencilTable Limit Stencil Evaluation Limit stencil evaluation is quite similar to refinement in Osd . At first clients create FarLimitStencilTable for the locations to evaluate the limit surfaces, then convert it into an evaluator compatible stencil table and call EvaluatorEvalStencils. Limit Evaluation with PatchTable Another way to evaluate the limit surfaces is to use the PatchTable. Once all control vertices and local points are resolved by the stencil evaluation, Osd can evaluate the limit surfaces through the PatchTable. Backend Evaluator class compatible patch table CPU CPU single-threaded CpuEvaluator CpuPatchTable TBB CPU multi-threaded TbbEvaluator CpuPatchTable OpenMP CPU multi-threaded OmpEvaluator CpuPatchTable CUDA GPU CudaEvaluator CudaPatchTable OpenCL CPUGPU CLEvaluator CLPatchTable GL ComputeShader GPU GLComputeEvaluator GLPatchTable GL Transform Feedback GPU GLXFBEvaluator GLPatchTable DX11 ComputeShader GPU D3D11ComputeEvaluator not yet supported D3D11PatchTable Metal ComputeShader GPU MTLComputeEvaluator MTLPatchTable Release Notes 3.x Osd evaluation backends EvaluatorEvalPatches do not support evaluation of single-crease or Legacy Gregory patch types. OpenGLDX11Metal Drawing with Hardware Tessellation One of the most interesting use cases of the Osd layer is realtime drawing of subdivision surfaces using hardware tessellation. This is somewhat similar to limit evaluation with PatchTable described above. Drawing differs from limit evaluation in that Osd provides shader snippets for patch evaluation and clients will inject them into their own shader source. See shader interface for a more detailed discussion of the shader interface. InterleavedBatched Buffer Configuration All Osd layer APIs assume that each primitive variables to be computed points, colors, uvs ... are contiguous arrays of 32bit floating point values. The Osd API refers to such an array as a buffer. A buffer can exist on CPU memory or GPU memory. Osd Evaluators typically take one source buffer and one destination buffer, or three destination buffers if derivatives are being computed. Osd Evaluators also take BufferDescriptors, that are used to specify the layout of the source and destination buffers. A BufferDescriptor is a struct of 3 integers which specify an offset, length and stride. For example Vertex 0 Vertex 1 ... X Y Z X Y Z ... The layout of this buffer can be described as Osd BufferDescriptor desc offset 0 , length 3 , stride 3 BufferDescriptor can be used for an interleaved buffer too. Vertex 0 Vertex 1 ... X Y Z R G B A X Y Z R G B A ... Osd BufferDescriptor xyzDesc 0 , 3 , 7 Osd BufferDescriptor rgbaDesc 3 , 4 , 7 Although the source and destination buffers dont need to be the same buffer for EvalStencils, adaptive patch tables are constructed to first index the coarse vertices and the refined vertices immediately afterward. In this case, the BufferDescriptor for the destination should include the offset as the number of coarse vertices to be skipped. Coarse vertices n Src Refined vertices Dst Vertex 0 Vertex 1 ... Vertex n Vertex n1 X Y Z X Y Z ... X Y Z X Y Z ... Osd BufferDescriptor srcDesc 0 , 3 , 3 Osd BufferDescriptor dstDesc n 3 , 3 , 3 Also note that the source descriptor doesnt have to start with offset 0. This is useful when a client has a big buffer with multiple objects batched together. Cross-Platform Implementation One of the key goals of OpenSubdiv is to achieve as much cross-platform flexibility as possible and leverage all optimized hardware paths where available. This can be very challenging as there is a very large variety of plaftorms and APIs available, with very distinct capabilities. In Osd , Evaluators dont care about interops between those APIs. All Evaluators have two kinds of APIs for both EvalStencils and EvalPatches. Explicit signatures which directly take device-specific buffer representation e.g., pointer for CpuEvaluator, GLuint buffer for GLComputeEvaluator, etc. Generic signatures which take arbitrary buffer classes. The buffer class is required to have a certain method to return the device-specific buffer representation. The later interface is useful if the client supports multiple backends at the same time. The methods that need to be implemented for the Evaluators are Evaluator class object method CpuEvaluator TbbEvaluator OmpEvaluator pointer to cpu memory BindCpuBuffer CudaEvaluator pointer to cuda memory BindCudaBuffer CLEvaluator cl_mem BindCLBuffer GLComputeEvaluator GLXFBEvaluator GL buffer object BindVBO D3D11ComputeEvaluator D3D11 UAV BindD3D11UAV MTLComputeEvaluator MTLBuffer BindMTLBuffer The buffers can use these methods as a trigger of interop. Osd provides a default implementation of interop buffer for most of the backend combinations. For example, if the client wants to use CUDA as a computation backend and use OpenGL as the drawing API, OsdCudaGLVertexBuffer fits the case since it implements BindCudaBuffer and BindVBO. Again, clients can implement their own buffer class and pass it to the Evaluators. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "release_31.html" │ │ │ │ │ + "loc": "osd_overview.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "OSD Tessellation shader Interface", │ │ │ │ │ "text": "OSD Tessellation shader Interface OSD Tessellation shader Interface 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Basic Tessellation Control Shader Example for B-Spline patches Tessellation Evaluation Shader Example for B-Spline patches Basis Conversion B-spline Patch Gregory Basis Patch Box-spline Triangle Patch Gregory Triangle Patch Legacy Gregory Patch 2.x compatibility Tessellation levels Tessellation levels at each tessellated vertex Tessellation levels computed at each patch Uniform Screenspace Basic Starting with 3.0, Osd tessellation shaders can be used as a set of functions from client shader code. In order to tessellate Osd patches, client shader code should perform the following steps regular B-spline patch case In a tessellation control shader fetch a PatchParam for the current patch call OsdComputePerPatchVertexBSpline to compute OsdPerPatchVertexBezier. compute tessellation level. To prevent cracks on transition patches, two vec4 parameters tessOuterHi, tessOuterLo will be needed in addition to built-in gl_TessLevelInnerOuters. In a tessellation evaluation shader call OsdGetTessParameterization to remap gl_TessCoord to a patch parameter at which to evaluate. call OsdEvalPatchBezierOsdEvalPatchGregory to evaluate the current patch. The following is a minimal example of GLSL code explaining how client shader code uses OpenSubdiv shader functions to tessellate patches of a patch table. Tessellation Control Shader Example for B-Spline patches layout vertices 16 out in vec3 position patch out vec4 tessOuterLo , tessOuterHi out OsdPerPatchVertexBezier v void main Get a patch param from texture buffer. ivec3 patchParam OsdGetPatchParam gl_PrimitiveID Compute per-patch vertices. OsdComputePerPatchVertexBSpline patchParam , gl_InvocationID , position , v Compute tessellation factors. if gl_InvocationID 0 vec4 tessLevelOuter vec4 0 vec2 tessLevelInner vec2 0 OsdGetTessLevelsUniform patchParam , tessLevelOuter , tessLevelInner , tessOuterLo , tessOuterHi gl_TessLevelOuter 0 tessLevelOuter 0 gl_TessLevelOuter 1 tessLevelOuter 1 gl_TessLevelOuter 2 tessLevelOuter 2 gl_TessLevelOuter 3 tessLevelOuter 3 gl_TessLevelInner 0 tessLevelInner 0 gl_TessLevelInner 1 tessLevelInner 1 Tessellation Evaluation Shader Example for B-Spline patches layout quads in patch in vec4 tessOuterLo , tessOuterHi in OsdPerPatchVertexBezier v uniform mat4 mvpMatrix void main Compute tesscoord. vec2 UV OsdGetTessParameterization gl_TessCoord . xy , tessOuterLo , tessOuterHi vec3 P vec3 0 , dPu vec3 0 , dPv vec3 0 vec3 N vec3 0 , dNu vec3 0 , dNv vec3 0 ivec3 patchParam inpt 0 . v . patchParam Evaluate patch at the tess coord UV OsdEvalPatchBezier patchParam , UV , v , P , dPu , dPv , N , dNu , dNv Apply model-view-projection matrix. gl_Position mvpMatrix vec4 P , 1 Basis Conversion B-spline Patch The following diagram shows how the Osd shaders process b-spline patches. While regular patches are expressed as b-spline patches in FarPatchTable, the Osd shader converts them into Bezier basis patches for simplicity and efficiency. This conversion is performed in the tessellation control stage. The boundary edge evaluation and single crease matrix evaluation are also resolved during this conversion. OsdComputePerPatchVertexBSpline can be used for this process. The resulting Bezier control vertices are stored in OsdPerPatchVertexBezier struct. void OsdComputePerPatchVertexBSpline ivec3 patchParam , int ID , vec3 cv 16 , out OsdPerPatchVertexBezier result The tessellation evaluation shader takes an array of OsdPerPatchVertexBezier struct, and then evaluates the patch using the OsdEvalPatchBezier function. void OsdEvalPatchBezier ivec3 patchParam , vec2 UV , OsdPerPatchVertexBezier cv 16 , out vec3 P , out vec3 dPu , out vec3 dPv , out vec3 N , out vec3 dNu , out vec3 dNv Gregory Basis Patch In a similar way, Gregory basis patches are processed as follows OsdComputePerPatchVertexGregoryBasis can be used for the Gregory patches although no basis conversion involved for the Gregory patches and the resulting vertices are stored in a OsdPerPatchVertexGreogryBasis struct. void OsdComputePerPatchVertexGregoryBasis ivec3 patchParam , int ID , vec3 cv , out OsdPerPatchVertexGregoryBasis result The tessellation evaluation shader takes an array of OsdPerPatchVertexGregoryBasis struct, and then evaluates the patch using the OsdEvalPatchGregory function. void OsdEvalPatchGregory ivec3 patchParam , vec2 UV , vec3 cv 20 , out vec3 P , out vec3 dPu , out vec3 dPv , out vec3 N , out vec3 dNu , out vec3 dNv Box-spline Triangle Patch While regular triangle patches are expressed as triangular box-spline patches in FarPatchTable, the Osd shader converts them into triangular Bezier patches for consistency. This conversion is performed in the tessellation control stage. The boundary edge evaluation is resolved during this conversion. OsdComputePerPatchVertexBoxSplineTriangle can be used for this process. The resulting Bezier control vertices are stored in OsdPerPatchVertexBezier struct. void OsdComputePerPatchVertexBoxSplineTriangle ivec3 patchParam , int ID , vec3 cv 12 , out OsdPerPatchVertexBezier result The tessellation evaluation shader takes an array of OsdPerPatchVertexBezier struct, and then evaluates the patch using the OsdEvalPatchBezierTriangle function. void OsdEvalPatchBezierTriangle ivec3 patchParam , vec2 UV , OsdPerPatchVertexBezier cv 15 , out vec3 P , out vec3 dPu , out vec3 dPv , out vec3 N , out vec3 dNu , out vec3 dNv Gregory Triangle Patch OsdComputePerPatchVertexGregoryBasis can be used for the quartic triangular Gregory patches although no basis conversion involved for the Gregory triangle patches and the resulting vertices are stored in a OsdPerPatchVertexGreogryBasis struct. void OsdComputePerPatchVertexGregoryBasis ivec3 patchParam , int ID , vec3 cv , out OsdPerPatchVertexGregoryBasis result The tessellation evaluation shader takes an array of OsdPerPatchVertexGregoryBasis struct, and then evaluates the patch using the OsdEvalPatchGregoryTriangle function. void OsdEvalPatchGregoryTriangle ivec3 patchParam , vec2 UV , vec3 cv 18 , out vec3 P , out vec3 dPu , out vec3 dPv , out vec3 N , out vec3 dNu , out vec3 dNv Legacy Gregory Patch 2.x compatibility OpenSubdiv 3.0 also supports 2.x style Gregory patch evaluation see far_overview. In order to evaluate a legacy Gregory patch, client needs to bind extra buffers and to perform extra steps in the vertex shader as shown in the following diagram Tessellation levels Osd provides both uniform and screen-space adaptive tessellation level computation. Because of the nature of feature adaptive subdivision , we need to pay extra attention for a patchs outer tessellation level for the screen-space adaptive case so that cracks dont appear. An edge of the patch marked as a transition edge is split into two segments Hi and Lo. The Osd shaders uses these two segments to ensure the same tessellation along the edge between different levels of subdivision. In the following example, suppose the left hand side patch has determined the tessellation level of its right edge to be 5. gl_TessLevelOuter is set to 5 for the edge, and at the same time we also pass 2 and 3 to the tessellation evaluation shader as separate levels for the two segments of the edge split at the middle. Tessellation levels at each tessellated vertex The tessellation evaluation shader takes gl_TessCoord and those two values, and remaps gl_TessCoord using OsdGetTessParameterization or OsdGetTessLevelParameterizationTriangle to ensure the parameters are consistent across adjacent patches. vec2 OsdGetTessParameterization vec2 uv , vec4 tessOuterLo , vec4 tessOuterHi vec2 OsdGetTessParameterizationTriangle vec3 uvw , vec4 tessOuterLo , vec4 tessOuterHi Tessellation levels computed at each patch These tessellation levels can be computed the corresponding method in the tesselation control shader. Note that these functions potentially requires all bezier control points, you need to call barrier to ensure the conversion is done for all invocations. See osdglslPatchBSpline.glsl for more details. Uniform void OsdGetTessLevelsUniform ivec3 patchParam , out vec4 tessLevelOuter , out vec2 tessLevelInner , out vec4 tessOuterLo , out vec4 tessOuterHi void OsdGetTessLevelsUniformTriangle ivec3 patchParam , out vec4 tessLevelOuter , out vec2 tessLevelInner , out vec4 tessOuterLo , out vec4 tessOuterHi Screenspace void OsdEvalPatchBezierTessLevels OsdPerPatchVertexBezier cpBezier 16 , ivec3 patchParam , out vec4 tessLevelOuter , out vec2 tessLevelInner , out vec4 tessOuterLo , out vec4 tessOuterHi void OsdEvalPatchBezierTriangleTessLevels vec3 cv 15 , ivec3 patchParam , out vec4 tessLevelOuter , out vec2 tessLevelInner , out vec4 tessOuterLo , out vec4 tessOuterHi Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "osd_shader_interface.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Porting Guide 2.x to 3.0", │ │ │ │ │ - "text": "Porting Guide 2.x to 3.0 Porting Guide 2.x to 3.0 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Porting Guide 2.x to 3.0 Source Code Organization Hbr Layer Translation Subdivision Schemes and Options in Sdc Specifying Face Varying Topology and Options Far Layer Translation Ordering of Refined Vertices Osd Layer Translation Controller Objects ComputeContext, DrawContext EvalLimitContext OsdMesh OsdKernelBatch OsdVertex Feature Adaptive Shader Changes End Cap Strategies Changes to Subdivision Build Support for Combining 2.x and 3.0 Porting Guide 2.x to 3.0 This document is a high-level description of how to port exiting OpenSubdiv 2.x code to use OpenSubdiv 3.0. NOTE If your questions are not answered here, please contact us on the OpenSubdiv forum and we will be happy to help Source Code Organization Given the scale of functional changes that were being made to the public interface, we took the opportunity in 3.0 to update the coding style and organization -- most notably making use of namespaces for each library. Subdirectory Namespace Relevance hbr NA Historical, no longer used sdc Sdc New, low-level, public options, constants, etc. vtr Vtr New, internal use, topology representation far Far Revised, similar functionality with new API osd Osd Revised, similar functionality with new API Hbr Layer Translation Client mesh topology is now translated into an instance of FarTopologyRefiner instead of HbrMesh. OpenSubdiv 2.x OpenSubdiv 3.0 HbrMeshVTX_TYPE FarTopologyRefiner The FarTopologyRefiner is now the core representation of topology from which all other major classes in Far and Osd are constructed. It was designed to support efficient refinement uniform or sparse of a base mesh of arbitrary topology no manifold restrictions. Once constructed it can be directly refined to meet some need, or passed to other contexts that will refine it to meet their needs. In contrast to directly assembling an HbrMesh, the TopologyRefiner, like other classes in Far, requires a Factory class for its construction. One of the early goals of these factories was to allow a client to convert their existing boundary representation -- with its full topological traversal abilities -- directly into the TopologyRefiners representation. While this is now possible, this also represents the most complex construction process and is only recommended for usage where this conversion process is critical. Details on how to construct a TopologyRefiner can be found in the Far overview documentation. Additionally, documentation for FarTopologyRefinerFactoryMESH outlines the requirements, and Far tutorial 3.1 tutorialsfartutorial_3_1 provides an example of a factory for directly converting HbrMeshes to TopologyRefiners. Its worth a reminder here that FarTopologyRefiner contains only topological information which does include sharpness, since that is considered relating to subdivision topology and not the positions or other data associated with a mesh. While HbrMeshT required some definition of a vertex type T and dimensions of face-varying data, TopologyRefiner is more clearly separated from the data. So the construction of the TopologyRefiner does not involve data specification at all. Subdivision Schemes and Options in Sdc The creation of a new TopologyRefiner requires specification of a subdivision scheme and a set of options that are applicable to all schemes. With HbrMesh, the scheme was specified by declaring a static instance of a specific subclass of a subdivision object, and the options were specified with a number of methods on the different classes. Such general information about the schemes has now been encapsulated in the Sdc layer for use throughout OpenSubdiv. The subdivision scheme is now a simple enumerated type SdcSchemeType and the entire set of options that can be applied to a scheme is encapsulated in a single simple struct of flags and enumerated types SdcOptions. OpenSubdiv 2.x OpenSubdiv 3.0 HbrMeshTSetInterpolateBoundaryMethod SdcOptionsSetVtxBoundaryInterpolation HbrMeshTSetFVarInterpolateBoundaryMethod SdcOptionsSetFVarLinearInterpolation HbrSubdivisionTSetCreaseSubdivisionMethod SdcOptionsSetCreasingMethod Specifying Face Varying Topology and Options Both the way in which face varying data is associated with a mesh and the options used to control its interpolation have changed. The documentation on Compatibility with OpenSubdiv 2.x details the equivalence of interpolation options between Hbr and the new SdcOptionsFVarLinearInterpolation enum, while the section on Face Varying Interpolation illustrates their effects. Face varying data is now specified by index rather than by value, or as often stated, it is specified topologically. Just as vertices for faces are specified by indices into a potential buffer of positions, face varying values are specified by indices into a potential buffer of values. Both vertices and face varying values frequently referred to as FVarValues in the API are assigned and associated with the corners of all faces. In many cases this will simplify representation as many common geometry container formats such as Obj or Alembic specify texture coordinates the same way. For other cases, where a value per face-corner is provided with no indication of which values incident each vertex should be considered shared, it will be necessary to determine shared indices for values at each vertex if any non-linear interpolation is desired. Far Layer Translation While TopologyRefiner was introduced into Far as the new intermediate topology representation, several other changes were made to classes in Far to provide more modular building blocks for use by the Osd layer or directly. OpenSubdiv 2.x OpenSubdiv 3.0 FarMeshU NA, no longer needed FarSubdivisionTables FarStencilTable FarPatchTables FarPatchTable Ordering of Refined Vertices The FarMesh was previously responsible for refining an HbrMesh -- generating new vertices and faces in successive levels of refinement in the FarSubdivisionTables. Vertices were grouped and reordered from the native ordering of HbrMesh so that vertices requiring similar processing were consecutive. Such grouping alleviated most of the idiosyncrasies of HbrMeshs native ordering but not all. FarToplogyRefiner is inherently a collection of refinement levels, and within each refined level so excluding the base level, all components are still grouped for the same reasons. There are two issues here though the ordering of these groups has changed though an option exists to preserve it the ordering of components within these groups is not guaranteed to have been preserved Vertices in a refined level are grouped according to the type of component in the parent level from which they originated, i.e. some vertices originate from the center of a face face-vertices, some from an edge edge-vertices and some from a vertex vertex-vertices. Note that there is a conflict in terminology here -- face-vertices and edge-vertices most often refer to vertices incident a face or edge -- but for the sake of this discussion, we use them to refer to the component from which a child vertex originates. The following table shows the ordering of these groups in 2.x and the two choices available in 3.0. The option is the orderVerticesFromFacesFirst flag that can be set in the Option structs passed to the uniform and adaptive refinement methods of TopologyRefiner Version and option Vertex group ordering 2.x face-vertices, edge-vertices, vertex-vertices 3.0 default vertex-vertices, face-vertices, edge-vertices 3.0 orderVerticesFromFacesFirst true face-vertices, edge-vertices, vertex-vertices The decision to change the default ordering was based on common feedback the rationale was to allow a trivial mapping from vertices in the cage to their descendants at all refinement levels. While the grouping is fundamental to the refinement process, the ordering of the groups is internally flexible, and the full set of possible orderings can be made publicly available in future if there is demand for such flexibility. The ordering of vertices within these groups was never clearly defined given the way that HbrMesh applied its refinement. For example, for the face-vertices in a level, it was never clear which face-vertices would be first as it depended on the order in which HbrMesh traversed the parent faces and generated them. Given one face, HbrMesh would often visit neighboring faces first before moving to the next intended face. The ordering with FarTopologyRefiner is much clearer and predictable. Using the face-vertices as an example, the order of the face-vertices in level N1 is identical to the order of the parent faces in level N from which they originated. So if we have face-vertices Vi , Vj and Vk at some level, originating from faces Fi , Fj and Fk in the previous level, they will be ordered in increasing order of i , j and k . For uniform refinement the ordering of face vertices Vi will therefore exactly match the ordering of the parent faces Fi . For adaptive or otherwise sparse refinement, the subset of Vi will be ordered similarly, just with components missing from those not refined. The same is true of all vertices, i.e. edge-vertices and vertex-vertices, and also for other components in refined levels, i.e. the child faces and edges. For child faces and edges, more than one will originate from the same parent face or edge. In addition to the overall ordering based on the parent faces or edges, another ordering is imposed on multiple children originating from the same face or edge. They will be ordered based on the corner or end-vertex with which they are associated. In the case of refined faces, another way to view the ordering is to consider the way that faces are originally defined -- by specifying the set of vertices for the corners of each face, often aggregated into a single large array. The ordering of the set of refined faces for each level will correspond directly to such an array of vertices per face in the previous level. Osd Layer Translation Two big changes in the 3.0 API have allowed the Osd layer to be significantly simpler, the first is the move to stencil tables from subdivision tables and the second is shader simplification. With this refactoring, the focus has been to use more meaningful names and to make the data contained within an object more apparent. Controller Objects The API-specific ComputeController has been replaced with the Evaluator . It reflects the fact that stencil compute batches are significantly simpler than subdivision table compute batches. The name Evaluator was chosen with the hope that is more meaningful than the generic ComputeController moniker the Evaluator evaluates stencil and patch tables. In the 2.x code base, subdiv level buffers were always required to be allocated contiguously, however in 3.0 with the shift to stencil tables, this strict allocation scheme is no longer required. As a result, the EvalStencils and EvalPatches methods now accept both a source and a destination descriptor. OpenSubdiv 2.x OpenSubdiv 3.0 ComputeControllerRefine Osd...EvaluatorEvalStencils ComputeControllerSynchronize Osd...EvaluatorSynchronize EvalStencilsControllerUpdateValues Osd...EvaluatorEvalStencils EvalStencilsControllerUpdateDerivs Osd...EvaluatorEvalStencils EvalLimitControllerEvalLimitSample Osd...EvaluatorEvalPatches Also note that OsdVertexDescriptor has been renamed, however its data members and semantic purpose remains the same OpenSubdiv 2.x OpenSubdiv 3.0 OsdVertexBufferDescriptor OsdBufferDescriptor ComputeContext, DrawContext ComputeContext and DrawContext have been replaced with API-specific StencilTable and PatchTable objects, for example OsdGLStencilTableSSBO. OpenSubdiv 2.x OpenSubdiv 3.0 ComputeContext Osd...StencilTable e.g. GLStencilTableTBO EvalStencilsContext Osd...StencilTable DrawContext Osd...PatchTable e.g. GLPatchTable EvalLimitContext The data stored in EvalLimitContext has been merged into the Evaluator class as well. EvalCoords have been moved into their own type, OsdPatchCoords. The primary change here is that the PTex face ID is no longer part of the data structure, rather the client can use a FarPatchMap to convert from PTex face ID to a FarPatchTablePatchHandle. OpenSubdiv 2.x OpenSubdiv 3.0 EvalLimitContext PatchTable EvalLimitContextEvalCoords OsdPatchCoords types.h OsdMesh While not strictly required, OsdMesh is still supported in 3.0 as convenience API for allocating buffers. OsdMesh serves as a simple way to allocate all required data, in the location required by the API for example, GPU buffers for OpenGL. OsdKernelBatch No translation, it is no longer part of the API. OsdVertex No translation, it is no longer part of the API. Feature Adaptive Shader Changes In 3.0, the feature adaptive screen-space tessellation shaders have been dramatically simplified, and the client-facing API has changed dramatically as well. The primary shift is to reduce the total number of shader combinations, and as a result, some of the complexity management mechanisms are no longer necessary. In the discussion below, some key changes are highlighted, but deep integrations may require additional discussion please feel free to send follow up questions to the OpenSubdiv google group. The number of feature adaptive shaders has been reduced from N to exactly 1 or 2, depending on how end-caps are handled. Osd layer no longer compiles shaders, rather it returns shader source for the client to compile. This source is obtained via OsdGLSLHLSLPatchShaderSource. The API exposed in shaders to access patch-based data has been consolidated and formalized, see osdglslPatchCommon.glsl and osdhlslPatchCommon.hlsl for details. Patches are no longer rotated and transition patches have been eliminated, simplifying PatchDescriptor to a 4 bits. Additionally, FarPatchTablesDescriptor has been moved into its own class in the Far namespace. The following table outlines the API translation between 2.x and 3.0 OpenSubdiv 2.x OpenSubdiv 3.0 OsdDrawContextPatchDescriptor NA, no longer needed. OsdDrawContextPatchArray OSdPatchArray types.h FarPatchTablesPatchDescriptor FarPatchDescriptor patchDescriptor.h FarPatchTablesPatchArray made private. End Cap Strategies By default, OpenSubdiv uses Gregory patches to approximate the patches around extraordinary vertices at the maximum isolation level, this process is referred to as end-capping. If ENDCAP_BSPLINE_BASIS is specified to PatchTableFactoryOptions, BSpline patches are used, which gives less accuracy, but it makes possible to render an entire mesh in a single draw call. Both patches require additional control points that are not part of the mesh, we refer to these as local points. In 3.0, the local points of those patches are computed by applying a stencil table to refined vertices to construct a new stencil table for the local points. Since this new stencil table is topologically compatible with the primary stencil table for refinement, it is convenient and efficient to splice those stencil tables together. This splicing can be done in the following way FarStencilTable const refineStencils FarStencilTableFactoryCreatetopologyRefiner FarPatchTable cosnt patchTable FarPatchTableFactoryCreatetopologyRefiner FarStencilTable const localPointStencils patchTable-GetLocalPointStencilTable FarStencilTable const splicedStencils FarStencilTableFactoryAppendLocalPointStencilTablestopologyRefiner, refineStencils, localPointStencils NOTE Once the spliced stencil table is created, the refined stencils can be released, but the local point stencils are owned by patchTable, it should not be released. OpenSubdiv 3.0 also supports 2.x style Gregory patches, if ENDCAP_LEGACY_GREGORY is specified to PatchTableFactoryOptions. In this case, such an extra stencil splicing isnt needed, however clients must still bind additional buffers VertexValence buffer and QuadOffsets buffer. See OsdGLLegacyGregoryPatchTable for additional details. Changes to Subdivision The refactoring of OpenSubdiv 3.0 data representations presented a unique opportunity to revisit some corners of the subdivision specification and remove or update some legacy features -- none of which was taken lightly. More details are provided in Subdivision Compatibility , while the following offers a quick overview All face-varying interpolation options have been combined into a single enum. Vertex interpolation options have been renamed or removed The naming of the standard creasing method has changed from Normal to Uniform . Unused legacy modes of the smoothtriangle option have been removed. The averaging of Chaikin creasing with infinitely sharp edges has changed. Support for Hierarchical Edits has been removed. Build Support for Combining 2.x and 3.0 Running OpenSubdiv 2.0 and 3.0 in a single process is supported, however some special care must be taken to avoid namespace collisions, both in terms of run-time symbols avoid using OpenSubdivOsd, for example and in terms of build-time search paths. To support both OpenSubdiv 2.0 and 3.0 in your build environment, you can prefix the header install directory of OpenSubdiv 3.0. Do this using the build flag CMAKE_INCDIR_BASE when configuring cmake i.e. -DCMAKE_INCDIR_BASEincludeopensubdiv3 and then including files from opensubdiv3... in client code. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "Modeling Tips", │ │ │ │ │ + "text": "Modeling Tips Modeling Tips 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Topology Use Fewer Spans Avoid High Valence vertices Edge-Loop Transitions Practical Topology Primer Triangles and N-Gons Semi-Sharp Creases Use crease sets Additional Resources The following sections describe common techniques specific to modeling with subdivision surfaces. Note The following information contains techniques specific to the Catmull-Clark subdivision scheme. Some elements need to be adjusted for Loop surfaces. Topology Well-constructed subdivision meshes have several important properties They consist primarily of regular faces quads for Catmull-Clark, tris for Loop They contain few extraordinary vertices They efficiently describe the intended shape They are topologically manifold Use Fewer Spans While polygon models need to use a large number of spans to approximate smooth curved surfaces, subdivision models require significantly fewer control points. In most situations, 6 spans are enough to create accurate circular shapes, and 4 is often enough to approximate background objects. Avoid High Valence vertices A high valence vertex is a vertex connected to more than 4 adjacent edges. High valence vertices cause several problems when subdivided The Catmull-Clark scheme can produce wavy surfaces when a revolution vertex is surrounded by triangles see here High valence vertices incur fairly large performance hits Currently, OpenSubdiv has a hard constraint imposed by GPU shaders on the maximum valence of a vertex 27 on current hardware Instead, here are some topological strategies to cap revolution shapes Note that all these cylinders use only quad faces, and all the vertices in the caps have a valence of 4 except the bottom left example Edge-Loop Transitions It is often necessary to vary the density of control vertices over the surface mesh areas around the fingers of a hand require more CVs than the comparatively simpler region around the palm. It is important to handle the topology around these transitions efficiently. One strategy is to use extraordinary vertices, such as this example, using a valence 5 vertex to expand 3 edge loops into 5. Practical Topology Primer Some real-world examples showing how to produce detailed shapes with sparse topology, few extraordinary vertices, and no high-valence revolution poles. Triangles and N-Gons Used sparsely, non-quads can be very useful to gather 3 or more diverging edge-loops. These are often encountered in highly deforming areas with curvature saddle-points ex arm-torso connection. The strategic placement of a pentagon in one of these critical spots ensures that the surface remains smooth, while allowing for complex topology to flow around. Semi-Sharp Creases Semi-sharp creases can be a very powerful tool for hard-surface modeling. Both edges and vertices can be tagged with a sharpness value. Crease sharpness values range from 0 smooth to 10 infinitely sharp It is generally cheaper to use creases whenever possible, instead of adding extra edgesedge-loops. However... Creases introduce extra computation costs that are proportional to the sharpness value. So... Sharpness values above 5 should rarely be needed. The following sections introduce some techniques to best leverage them. Use crease sets Complex hard-surface models giant robots, vehicles, buildings... are likely to tag large number of edges it is extremely useful to organize these edgesedge loops into logical sets with descriptive names. Edges or vertices in a crease set group all share the same sharpness value. If you are modeling with Maya, the CreaseSetEditor implements this type of workflow. Additionally, for debugging purposes, it is often very helpful if the name of a set contains the sharpness value ex topDeck_2. Besides authoring convenience, one of the benefits of having many edge-loops share identical sharpness values is that it enables very powerful performance optimizations within the feature adaptive algorithm faster renders less memory. Additional Resources An excellent short tutorial from the Guerrilla CG Project that illustrates many of the common pitfalls of subdivision modeling, and the strategies to overcome them Ivo Kos, Modelling Technical Director at Pixar Animation Studios, shows some of the modeling techniques he uses when modeling props and architecture sets for feature films. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "porting.html" │ │ │ │ │ + "loc": "mod_notes.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "mtlPtexViewer", │ │ │ │ │ "text": "mtlPtexViewer mtlPtexViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION KEYBOARD CONTROLS SEE ALSO SYNOPSIS open mtlPtexViewer.app --args -yup -u -a -l isolation level ptex color file ptex displacement file DESCRIPTION mtlPtexViewer is a stand-alone application demonstrating shading with color and displacement ptex maps. Multiple controls are available to experiment with the algorithms. KEYBOARD CONTROLS q quit f fit frame - increase decrease tessellation rate SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "mtlptexviewer.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "OSD Overview", │ │ │ │ │ - "text": "OSD Overview OSD Overview 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE OpenSubdiv Osd Refinement Limit Stencil Evaluation Limit Evaluation with PatchTable OpenGLDX11Metal Drawing with Hardware Tessellation InterleavedBatched Buffer Configuration Cross-Platform Implementation OpenSubdiv Osd Osd contains device dependent code that makes Far structures available on various backends such as TBB, CUDA, OpenCL, GLSL, etc. The main roles of Osd are Refinement Compute stencil-based uniformadaptive subdivision on CPUGPU backends Limit Stencil Evaluation Compute limit surfaces by limit stencils on CPUGPU backends Limit Evaluation with PatchTable Compute limit surfaces by patch evaluation on CPUGPU backends OpenGLDX11Metal Drawing with hardware tessellation Provide GLSLHLSLMetal tessellation functions for patch table InterleavedBatched buffer configuration Provide consistent buffer descriptor to deal with arbitrary buffer layout. Cross-Platform Implementation Provide convenient classes to interop between compute and draw APIs These are independently used by clients. For example, a client can use only the limit stencil evaluation, or a client can refine subdivision surfaces and draw them with the PatchTable and Osd tessellation shaders. All device specific evaluation kernels are implemented in the Evaluator classes. Since Evaluators dont own vertex buffers, clients should provide their own buffers as a source and destination. There are some interop classes defined in Osd for convenience. OpenSubdiv utilizes a series of regression tests to compare and enforce identical results across different computational devices. Refinement Osd supports both uniform and feature adaptive subdivision. Once clients create a FarStencilTable for the topology, they can convert it into device-specific stencil tables if necessary. The following table shows which evaluator classes and stencil table interfaces can be used together. Note that while Osd provides these stencil table classes which can be easily constructed from FarStencilTable, clients arent required to use these table classes. Clients may have their own entities as a stencil tables as long as EvaluatorEvalStencils can access the necessary interfaces. Backend Evaluator class compatible stencil table CPU CPU single-threaded CpuEvaluator FarStencilTable TBB CPU multi-threaded TbbEvaluator FarStencilTable OpenMP CPU multi-threaded OmpEvaluator FarStencilTable CUDA GPU CudaEvaluator CudaStencilTable OpenCL CPUGPU CLEvaluator CLStencilTable GL ComputeShader GPU GLComputeEvaluator GLStencilTableSSBO GL Transform Feedback GPU GLXFBEvaluator GLStencilTableTBO DX11 ComputeShader GPU D3D11ComputeEvaluator D3D11StencilTable Metal GPU MTLComputeEvaluator MTLStencilTable Limit Stencil Evaluation Limit stencil evaluation is quite similar to refinement in Osd . At first clients create FarLimitStencilTable for the locations to evaluate the limit surfaces, then convert it into an evaluator compatible stencil table and call EvaluatorEvalStencils. Limit Evaluation with PatchTable Another way to evaluate the limit surfaces is to use the PatchTable. Once all control vertices and local points are resolved by the stencil evaluation, Osd can evaluate the limit surfaces through the PatchTable. Backend Evaluator class compatible patch table CPU CPU single-threaded CpuEvaluator CpuPatchTable TBB CPU multi-threaded TbbEvaluator CpuPatchTable OpenMP CPU multi-threaded OmpEvaluator CpuPatchTable CUDA GPU CudaEvaluator CudaPatchTable OpenCL CPUGPU CLEvaluator CLPatchTable GL ComputeShader GPU GLComputeEvaluator GLPatchTable GL Transform Feedback GPU GLXFBEvaluator GLPatchTable DX11 ComputeShader GPU D3D11ComputeEvaluator not yet supported D3D11PatchTable Metal ComputeShader GPU MTLComputeEvaluator MTLPatchTable Release Notes 3.x Osd evaluation backends EvaluatorEvalPatches do not support evaluation of single-crease or Legacy Gregory patch types. OpenGLDX11Metal Drawing with Hardware Tessellation One of the most interesting use cases of the Osd layer is realtime drawing of subdivision surfaces using hardware tessellation. This is somewhat similar to limit evaluation with PatchTable described above. Drawing differs from limit evaluation in that Osd provides shader snippets for patch evaluation and clients will inject them into their own shader source. See shader interface for a more detailed discussion of the shader interface. InterleavedBatched Buffer Configuration All Osd layer APIs assume that each primitive variables to be computed points, colors, uvs ... are contiguous arrays of 32bit floating point values. The Osd API refers to such an array as a buffer. A buffer can exist on CPU memory or GPU memory. Osd Evaluators typically take one source buffer and one destination buffer, or three destination buffers if derivatives are being computed. Osd Evaluators also take BufferDescriptors, that are used to specify the layout of the source and destination buffers. A BufferDescriptor is a struct of 3 integers which specify an offset, length and stride. For example Vertex 0 Vertex 1 ... X Y Z X Y Z ... The layout of this buffer can be described as Osd BufferDescriptor desc offset 0 , length 3 , stride 3 BufferDescriptor can be used for an interleaved buffer too. Vertex 0 Vertex 1 ... X Y Z R G B A X Y Z R G B A ... Osd BufferDescriptor xyzDesc 0 , 3 , 7 Osd BufferDescriptor rgbaDesc 3 , 4 , 7 Although the source and destination buffers dont need to be the same buffer for EvalStencils, adaptive patch tables are constructed to first index the coarse vertices and the refined vertices immediately afterward. In this case, the BufferDescriptor for the destination should include the offset as the number of coarse vertices to be skipped. Coarse vertices n Src Refined vertices Dst Vertex 0 Vertex 1 ... Vertex n Vertex n1 X Y Z X Y Z ... X Y Z X Y Z ... Osd BufferDescriptor srcDesc 0 , 3 , 3 Osd BufferDescriptor dstDesc n 3 , 3 , 3 Also note that the source descriptor doesnt have to start with offset 0. This is useful when a client has a big buffer with multiple objects batched together. Cross-Platform Implementation One of the key goals of OpenSubdiv is to achieve as much cross-platform flexibility as possible and leverage all optimized hardware paths where available. This can be very challenging as there is a very large variety of plaftorms and APIs available, with very distinct capabilities. In Osd , Evaluators dont care about interops between those APIs. All Evaluators have two kinds of APIs for both EvalStencils and EvalPatches. Explicit signatures which directly take device-specific buffer representation e.g., pointer for CpuEvaluator, GLuint buffer for GLComputeEvaluator, etc. Generic signatures which take arbitrary buffer classes. The buffer class is required to have a certain method to return the device-specific buffer representation. The later interface is useful if the client supports multiple backends at the same time. The methods that need to be implemented for the Evaluators are Evaluator class object method CpuEvaluator TbbEvaluator OmpEvaluator pointer to cpu memory BindCpuBuffer CudaEvaluator pointer to cuda memory BindCudaBuffer CLEvaluator cl_mem BindCLBuffer GLComputeEvaluator GLXFBEvaluator GL buffer object BindVBO D3D11ComputeEvaluator D3D11 UAV BindD3D11UAV MTLComputeEvaluator MTLBuffer BindMTLBuffer The buffers can use these methods as a trigger of interop. Osd provides a default implementation of interop buffer for most of the backend combinations. For example, if the client wants to use CUDA as a computation backend and use OpenGL as the drawing API, OsdCudaGLVertexBuffer fits the case since it implements BindCudaBuffer and BindVBO. Again, clients can implement their own buffer class and pass it to the Evaluators. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "title": "License", │ │ │ │ │ + "text": "License License 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Open Source License OpenSubdiv is covered by a modified Apache 2.0 license included below, and is free to use for commercial or non-commercial use. All Pixar patents in the area of subdivision surface algorithms have also been released for public use. We welcome any involvement in the development or extension of this code in fact, we would love it. Please contact us if you are interested. For information on Apache licenses, see httpwww.apache.orglicenses The following license text describes the open source policy adopted by Pixar and is included in every source file. Copyright 2013 Pixar Licensed under the Apache License, Version 2.0 the Apache License with the following modification you may not use this file except in compliance with the Apache License and the following modification to it Section 6. Trademarks. is deleted and replaced with 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor and its affiliates, except as required to comply with Section 4c of the License and to reproduce the content of the NOTICE file. You may obtain a copy of the Apache License at httpwww.apache.orglicensesLICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the Apache License with the above modification is distributed on an AS IS BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the Apache License for the specific language governing permissions and limitations under the Apache License. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ - "loc": "osd_overview.html" │ │ │ │ │ + "loc": "license.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "mtlViewer", │ │ │ │ │ "text": "mtlViewer mtlViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION KEYBOARD CONTROLS SEE ALSO SYNOPSIS open mtlViewer.app --args -yup -u -a -l refinement level objfiles -catmark -loop -bilinear DESCRIPTION mtlViewer is a stand-alone application that showcases the application of uniform and feature adaptive subdivision schemes to a collection of geometric shapes. Multiple controls are available to experiment with the algorithms. mtlViewer running on macOS mtlViewer running on iOS KEYBOARD CONTROLS q quit f fit frame - increase decrease tessellation rate SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "mtlviewer.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "License", │ │ │ │ │ - "text": "License License 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Open Source License OpenSubdiv is covered by a modified Apache 2.0 license included below, and is free to use for commercial or non-commercial use. All Pixar patents in the area of subdivision surface algorithms have also been released for public use. We welcome any involvement in the development or extension of this code in fact, we would love it. Please contact us if you are interested. For information on Apache licenses, see httpwww.apache.orglicenses The following license text describes the open source policy adopted by Pixar and is included in every source file. Copyright 2013 Pixar Licensed under the Apache License, Version 2.0 the Apache License with the following modification you may not use this file except in compliance with the Apache License and the following modification to it Section 6. Trademarks. is deleted and replaced with 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor and its affiliates, except as required to comply with Section 4c of the License and to reproduce the content of the NOTICE file. You may obtain a copy of the Apache License at httpwww.apache.orglicensesLICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the Apache License with the above modification is distributed on an AS IS BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the Apache License for the specific language governing permissions and limitations under the Apache License. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "license.html" │ │ │ │ │ - }, { │ │ │ │ │ "title": "Introduction", │ │ │ │ │ "text": "Introduction Introduction 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Introduction Why Fast Subdivision Research Heritage Licensing Contributing External Resources Introduction OpenSubdiv is a set of open source libraries that implement high performance subdivision surface subdiv evaluation on massively parallel CPU and GPU architectures. This code path is optimized for drawing deforming surfaces with static topology at interactive framerates. OpenSubdiv is an API ready to be integrated into 3rd party digital content creation tools. It is not an application, nor a tool that can be used directly to create digital assets. Why Fast Subdivision Subdivision surfaces are commonly used for final rendering of character shapes for a smooth and controllable limit surfaces. However, subdivision surfaces in interactive apps are typically drawn as their polygonal control hulls because of performance. The polygonal control hull is an approximation that is offset from the true limit surface. Looking at an approximation in the interactive app makes it difficult to see exact contact, like fingers touching a potion bottle or hands touching a cheek. It also makes it difficult to see poke-throughs in cloth simulation if the skin and cloth are both approximations. This problem is particularly bad when one character is much larger than another and unequal subdiv face sizes cause approximation errors to be magnified. Maya and Pixars proprietary Presto animation system can take 100ms to subdivide a character of 30,000 polygons to the second level of subdivision 500,000 polygons. Being able to perform the same operation in less than 3ms allows the user to interact with the smooth, accurate limit surface at all times. Research The new GPU technology behind OpenSubdiv is the result of a joint research effort between Pixar and Microsoft. Feature Adaptive GPU Rendering of Catmull-Clark Subdivision Surfaces Matthias Niessner, Charles Loop, Mark Meyer, and Tony DeRose ACM Transactions on Graphics, Vol. 31 No. 1 Article 6 January 2012 httpgraphics.pixar.comlibraryGPUSubdivRenderingApaper.pdf Efficient Evaluation of Semi-Smooth Creases in Catmull-Clark Subdivision Surfaces Matthias Niessner, Charles Loop, and Guenter Greiner. Eurographics Proceedings, Cagliari, 2012 httpsniessnerlab.orgpapers20121semismoothniessner2012efficient.pdf Analytic Displacement Mapping using Hardware Tessellation Matthias Niessner, Charles Loop ACM Transactions on Graphics, Vol. 32 No. 3 Article 26 June 2013 httpsniessnerlab.orgpapers20133analyticniessner2013analytic.pdf Heritage This is the fifth-generation subdiv library in use by Pixars proprietary animation system in a lineage that started with code written by Tony DeRose and Tien Truong for Geris Game in 1996. Each generation has been a from-scratch rewrite that has built upon our experience using subdivision surfaces to make animated films. This code is live, so Pixars changes to OpenSubdiv for current and future films will be released as open source at the same time they are rolled out to Pixar animation production. Subdivision for Modeling and Animation Denis Zorin, Peter Schroder Course Notes of SIGGRAPH 1999 httpwww.multires.caltech.edupubssig99notes.pdf Subdivision Surfaces in Character Animation Tony DeRose, Michael Kass, Tien Truong Proceedings of SIGGRAPH 1998 httpgraphics.pixar.comlibraryGeripaper.pdf Recursively generated B-spline surfaces on arbitrary topological meshes Catmull, E. Clark, J. Computer-Aided Design 10 6 1978 Licensing OpenSubdiv is covered by the Apache License, and is free to use for commercial or non-commercial use. This is the same code that Pixar uses internally for animated film production. Our intent is to encourage a geometry standard for subdivision surfaces, by providing consistent i.e. yielding the same limit surface, high performance implementations on a variety of platforms. Why Apache We were looking for a commercial-friendly license that would convey our patents to the end users. This quickly narrowed the field to Microsoft Public License or Apache. Initially we chose MSPL because it handled trademarks better. But at the request of several companies we gave Apache another look, and decided to go with Apache with a very slight modification that simply says you cannot use any contributors trademarks. In other words, you can use OpenSubdiv to make a product, but you cannot use a Luxo Lamp or other character, etc. when marketing your product. License Header Contributing For details on how to contribute to OpenSubdiv, see the page on Contributing External Resources Pixar Research Pixar RD Portal Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "intro.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Modeling Tips", │ │ │ │ │ - "text": "Modeling Tips Modeling Tips 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Topology Use Fewer Spans Avoid High Valence vertices Edge-Loop Transitions Practical Topology Primer Triangles and N-Gons Semi-Sharp Creases Use crease sets Additional Resources The following sections describe common techniques specific to modeling with subdivision surfaces. Note The following information contains techniques specific to the Catmull-Clark subdivision scheme. Some elements need to be adjusted for Loop surfaces. Topology Well-constructed subdivision meshes have several important properties They consist primarily of regular faces quads for Catmull-Clark, tris for Loop They contain few extraordinary vertices They efficiently describe the intended shape They are topologically manifold Use Fewer Spans While polygon models need to use a large number of spans to approximate smooth curved surfaces, subdivision models require significantly fewer control points. In most situations, 6 spans are enough to create accurate circular shapes, and 4 is often enough to approximate background objects. Avoid High Valence vertices A high valence vertex is a vertex connected to more than 4 adjacent edges. High valence vertices cause several problems when subdivided The Catmull-Clark scheme can produce wavy surfaces when a revolution vertex is surrounded by triangles see here High valence vertices incur fairly large performance hits Currently, OpenSubdiv has a hard constraint imposed by GPU shaders on the maximum valence of a vertex 27 on current hardware Instead, here are some topological strategies to cap revolution shapes Note that all these cylinders use only quad faces, and all the vertices in the caps have a valence of 4 except the bottom left example Edge-Loop Transitions It is often necessary to vary the density of control vertices over the surface mesh areas around the fingers of a hand require more CVs than the comparatively simpler region around the palm. It is important to handle the topology around these transitions efficiently. One strategy is to use extraordinary vertices, such as this example, using a valence 5 vertex to expand 3 edge loops into 5. Practical Topology Primer Some real-world examples showing how to produce detailed shapes with sparse topology, few extraordinary vertices, and no high-valence revolution poles. Triangles and N-Gons Used sparsely, non-quads can be very useful to gather 3 or more diverging edge-loops. These are often encountered in highly deforming areas with curvature saddle-points ex arm-torso connection. The strategic placement of a pentagon in one of these critical spots ensures that the surface remains smooth, while allowing for complex topology to flow around. Semi-Sharp Creases Semi-sharp creases can be a very powerful tool for hard-surface modeling. Both edges and vertices can be tagged with a sharpness value. Crease sharpness values range from 0 smooth to 10 infinitely sharp It is generally cheaper to use creases whenever possible, instead of adding extra edgesedge-loops. However... Creases introduce extra computation costs that are proportional to the sharpness value. So... Sharpness values above 5 should rarely be needed. The following sections introduce some techniques to best leverage them. Use crease sets Complex hard-surface models giant robots, vehicles, buildings... are likely to tag large number of edges it is extremely useful to organize these edgesedge loops into logical sets with descriptive names. Edges or vertices in a crease set group all share the same sharpness value. If you are modeling with Maya, the CreaseSetEditor implements this type of workflow. Additionally, for debugging purposes, it is often very helpful if the name of a set contains the sharpness value ex topDeck_2. Besides authoring convenience, one of the benefits of having many edge-loops share identical sharpness values is that it enables very powerful performance optimizations within the feature adaptive algorithm faster renders less memory. Additional Resources An excellent short tutorial from the Guerrilla CG Project that illustrates many of the common pitfalls of subdivision modeling, and the strategies to overcome them Ivo Kos, Modelling Technical Director at Pixar Animation Studios, shows some of the modeling techniques he uses when modeling props and architecture sets for feature films. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "mod_notes.html" │ │ │ │ │ - }, { │ │ │ │ │ "title": "HBR Overview", │ │ │ │ │ "text": "HBR Overview HBR Overview 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Hierarchical Boundary Representation Hbr Half-edge Data Structure Half-edge cycles and Manifold Topology Templated Vertex Class Boundary Interpolation Rules Hierarchical Boundary Representation Hbr Hbr is an interconnected topological data representation. The high level of vertex connectivity information makes this representation well suited for creation and editing purposes. It is however inefficient for interactive refinement operations Separate objects are allocated for each vertex and edge with pointers to neighboring vertices and edges. Hbr is also the lowest-level subdivision library in Pixars Photorealistic RenderMan . Note As of OpenSubdiv 3.0, all Hbr dependencies have been removed from the core APIs Sdc , Vtr , Far , Osd . The legacy source code of Hbr is provided purely for regression and legacy purposes. If your code is currently depending on Hbr functionality, we recommend migrating to the newer APIs as we cannot guarantee that this code will be maintained in future releases. For more information see the 3.0 release notes Half-edge Data Structure The current implementation is based on a half-edge data structure. Half-edge cycles and Manifold Topology Because half-edges only carry a reference to their opposite half-edge, a given edge can only access a single neighboring edge cycle. This is a fundamental limitation of the half-edge data structure, in that it cannot represent non-manifold geometry, in particular fan-type topologies. A different approach to topology will probably be necessary in order to accommodate non-manifold geometry. Templated Vertex Class The vertex class has been abstracted into a set of templated function accesses. Providing Hbr with a template vertex class that does not implement these functions allows client-code to use Hbr as a pure topological analysis tool without having to pay any costs for data interpolation. It also allows client-code to remain in complete control of the layout of the vertex data interleaved or non-interleaved. Boundary Interpolation Rules Hbr recognizes 4 rule-sets of boundary interpolation Interpolation Rule-Sets k_InterpolateBoundaryNone k_InterpolateBoundaryEdgeOnly k_InterpolateBoundaryEdgeAndCorner k_InterpolateBoundaryAlwaysSharp This enum is shared for both vertex and face-varying interpolation, with the following distinctions vertex boundaries the BoundaryNone rule skips all boundary vertices results are undefined the AlwaysSharp rule does not apply face-varying boundaries the BoundaryNone rule selects bilinear face-varying interpolation Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "hbr_overview.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "glViewer", │ │ │ │ │ - "text": "glViewer glViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS SEE ALSO SYNOPSIS glViewer -f -yup -u -a -l refinement level -c animation loops objfiles -anim -catmark -loop -bilinear DESCRIPTION glViewer is a stand-alone application that showcases the application of uniform and feature adaptive subdivision schemes to a collection of geometric shapes. Multiple controls are available to experiment with the algorithms. OPTIONS See the description of the common comand line options for the subset of common options supported here. SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "glviewer.html" │ │ │ │ │ - }, { │ │ │ │ │ "title": "Hierarchical Edits", │ │ │ │ │ "text": "Hierarchical Edits Hierarchical Edits 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Hierarchical Edits Hierarchical Edits Paths Vertex Edits Edge Edits Face Edits Hierarchical Edits To understand the hierarchical aspect of subdivision, we realize that subdivision itself leads to a natural hierarchy after the first level of subdivision, each face in a subdivision mesh subdivides to four quads in the Catmull-Clark scheme, or four triangles in the Loop scheme. This creates a parent and child relationship between the original face and the resulting four subdivided faces, which in turn leads to a hierarchy of subdivision as each child in turn subdivides. A hierarchical edit is an edit made to any one of the faces, edges, or vertices that arise anywhere during subdivision. Normally these subdivision components inherit values from their parents based on a set of subdivision rules that depend on the subdivision scheme. A hierarchical edit overrides these values. This allows for a compact specification of localized detail on a subdivision surface, without having to express information about the rest of the subdivision surface at the same level of detail. Release Notes 3.0.0 Hierarchical Edits have been marked as extended specification and support for hierarchical features has been removed from the 3.0 release. This decision allows for great simplifications of many areas of the subdivision algorithms. If we can identify legitimate use-cases for hierarchical tags, we will consider re-implementing them in future releases, as time and resources allow. Hierarchical Edits Paths In order to perform a hierarchical edit, we need to be able to name the subdivision component we are interested in, no matter where it may occur in the subdivision hierarchy. This leads us to a hierarchical path specification for faces, since once we have a face we can navigate to an incident edge or vertex by association. We note that in a subdivision mesh, a face always has incident vertices, which are labelled in relation to the face with an integer index starting at zero and in consecutive order according to the usual winding rules for subdivision surfaces. Faces also have incident edges, and these are labelled according to the origin vertex of the edge. In this diagram, the indices of the vertices of the base face are marked in red so on the left we have an extraordinary Catmull-Clark face with five vertices labeled 0-4 and on the right we have a regular Catmull-Clark face with four vertices labelled 0-3 . The indices of the child faces are blue note that in both the extraordinary and regular cases, the child faces are indexed the same way, i.e. the sub-face labeled n has one incident vertex that is the result of the subdivision of the parent vertex also labeled n in the parent face. Specifically, we note that the sub-face 1 in both the regular and extraordinary face is nearest to the vertex labelled 1 in the parent. The indices of the vertices of the child faces are labeled green , and this is where the difference lies between the extraordinary and regular case in the extraordinary case, vertex to vertex subdivision always results in a vertex labeled 0 , while in the regular case, vertex to vertex subdivision assigns the same index to the child vertex. Again, specifically, we note that the parent vertex indexed 1 in the extraordinary case has a child vertex 0 , while in the regular case the parent vertex indexed 1 actually has a child vertex that is indexed 1 . Note that this indexing scheme was chosen to maintain the property that the vertex labeled 0 always has the lowest uv parametric value on the face. By appending a vertex index to a face index, we can create a vertex path specification. For example, 655 2 3 0 specifies the 1st. vertex of the 3 rd. child face of the 2 nd. child face of the of the 655 th. face of the subdivision mesh. Vertex Edits Vertex hierarchical edits can modify the value or the sharpness of primitive variables for vertices and sub-vertices anywhere in the subdivision hierarchy. The edits are performed using either an add or a set operator. set indicates the primitive variable value or sharpness is to be set directly to the values specified. add adds a value to the normal result computed via standard subdivision rules. In other words, this operation allows value offsets to be applied to the mesh at any level of the hierarchy. Edge Edits Edge hierarchical edits can only modify the sharpness of primitive variables for edges and sub-edges anywhere in the subdivision hierarchy. Face Edits Face hierarchical edits can modify several properties of faces and sub-faces anywhere in the subdivision hierarchy. Modifiable properties include The set or add operators modify the value of primitive variables associated with faces. The hole operation introduces holes missing faces into the subdivision mesh at any level in the subdivision hierarchy. The faces will be deleted, and none of their children will appear you cannot unhole a face if any ancestor is a hole. This operation takes no float or string arguments. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "hedits.html" │ │ │ │ │ }, { │ │ │ │ │ + "title": "glViewer", │ │ │ │ │ + "text": "glViewer glViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS SEE ALSO SYNOPSIS glViewer -f -yup -u -a -l refinement level -c animation loops objfiles -anim -catmark -loop -bilinear DESCRIPTION glViewer is a stand-alone application that showcases the application of uniform and feature adaptive subdivision schemes to a collection of geometric shapes. Multiple controls are available to experiment with the algorithms. OPTIONS See the description of the common comand line options for the subset of common options supported here. SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "glviewer.html" │ │ │ │ │ + }, { │ │ │ │ │ "title": "glStencilViewer", │ │ │ │ │ "text": "glStencilViewer glStencilViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS SEE ALSO SYNOPSIS glStencilViewer -f -yup -u -a -l refinement level objfiles -catmark -loop -bilinear DESCRIPTION glStencilViewer is a stand-alone application that showcases the application of pre-computed stencil tables to a collection of geometric test shapes. Multiple controls are available to experiment with the algorithms. OPTIONS See the description of the common comand line options for the subset of common options supported here. SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "glstencilviewer.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "glShareTopology", │ │ │ │ │ "text": "glShareTopology glShareTopology 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS SEE ALSO SYNOPSIS glShareTopology -u -a -l refinement level DESCRIPTION glShareTopology is a stand-alone application that showcases the implementation of topology instancing across Compute contexts. Multiple controls are available to experiment with the algorithms. OPTIONS See the description of the common comand line options for the subset of common options supported here. SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ @@ -266,14 +266,19 @@ │ │ │ │ │ "loc": "glsharetopology.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "glPtexViewer", │ │ │ │ │ "text": "glPtexViewer glPtexViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS KEYBOARD CONTROLS SEE ALSO SYNOPSIS glPtexViewer -f -yup -u -a -l isolation level -c animation loops -e environment map -d HDR diffuse map -s HDR specular map --disp displacement scale --bump bump scale ptex color file ptex displacement file ptex occlusion file ptex specular file objfiles DESCRIPTION glPtexViewer is a stand-alone application that showcases advanced HDR shading with color, displacement, occlusion and specular ptex maps. Multiple controls are available to experiment with the algorithms. OPTIONS See the description of the common comand line options for the subset of common options supported here. -e environment map A low dynamic range spherical environment map used as a background. Ideally, a color-normalized version of the HDR light probe. -d HDR diffuse map An HDR file containing a diffuse environment map typically they are low resolution blurry hemispherical convolutions of the environment light probe. -s environment map An HDR file containing a specular environment map. --disp displacement scale A scalar multiplier for the shader displacement values. --bump displacement scale A scalar multiplier for the shader bump values. ptex color file A ptex file containing RGB channels read as material albedo color. ptex displacement file A single-channel ptex file preferably float precision containing the displacement values. ptex occlusion file A single-channel ptex file preferably 8 bits precision containing a pre-computed ambient occlusion signal. ptex specular file A single-channel ptex file preferably 8 bits precision applied to modulate the specular reflectance of the material KEYBOARD CONTROLS q quit esc hide GUI x save screenshot f fit frame - increase decrease tessellation rate r reload and re - compile the shader files e draw normals SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "glptexviewer.html" │ │ │ │ │ }, { │ │ │ │ │ + "title": "glPaintTest", │ │ │ │ │ + "text": "glPaintTest glPaintTest 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS KEYBOARD CONTROLS SEE ALSO SYNOPSIS glPaintTest -f -yup -l adaptive refinement level objfiles -catmark -loop DESCRIPTION glPaintTest is a small stand-alone application showing the potential of using GPU limit tessellation for painting and sculpting applications. OPTIONS See the description of the common comand line options for the subset of common options supported here. KEYBOARD CONTROLS c use texture as color d use texture as displacement SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "glpainttest.html" │ │ │ │ │ + }, { │ │ │ │ │ "title": "glFVarViewer", │ │ │ │ │ "text": "glFVarViewer glFVarViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS SEE ALSO SYNOPSIS glFVarViewer -f -u -a -l refinement level -c animation loops objfiles -catmark -loop -bilinear DESCRIPTION glFVarViewer is a stand-alone application that allows the inspection of face-varying data interpolation. The window displays 2 views left side regular 3D view of the model, with a procedural u,v texture right side a 2D view of the face-varying u,v pair The HUD allows interactive manipulation of the various face-varying boundary interpolation rules and tags. OPTIONS See the description of the common comand line options for the subset of common options supported here. SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "glfvarviewer.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "glEvalLimit", │ │ │ │ │ "text": "glEvalLimit glEvalLimit 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS SEE ALSO SYNOPSIS glEvalLimit -f -yup -u -a -l refinement level objfiles -catmark -loop -bilinear DESCRIPTION glEvalLimit is a stand-alone application that showcases the limit surface Eval module. On the given shape, random samples are generated in local s,t space. Vertex, varying and face-varying data is then computed on the surface limit and displayed as colors. In order to emphasize the dynamic nature of the EvalLimit API, where the locations can be arbitrarily updated before each evaluation, the glEvalLimit example treats each sample as a ST particle. ST Particles are a simplified parametric-space particle dynamics simulation each particle is assigned a location on the subdivision surface limit that is composed of a unique ptex face index, with a local s,t parametric pair. The system also generates an array of parametric velocities ds, dt for each particle. An Update function then applies the velocities to the locations and moves the points along the parametric space. Face boundaries are managed using a ptex adjacency table obtained from the FarTopologyRefiner. Every time a particle moves outside of the 0.0f, 1.0f parametric range, a warp function moves it to the neighboring face, or bounces it, if the edge happens to be a boundary. Note currently the adjacency code does not handle diagonal crossings, nor crossings between quad and non-quad faces. Multiple controls are available to experiment with the algorithms. OPTIONS See the description of the common comand line options for the subset of common options supported here. SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ @@ -281,44 +286,39 @@ │ │ │ │ │ "loc": "glevallimit.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "Getting Started", │ │ │ │ │ "text": "Getting Started Getting Started 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Downloading the code Branches Git Flow Checking out branches API Versions Making Changes Code Overview Downloading the code The code is hosted on a Github public repository. Download and setup information for Git tools can be found here . You can access the OpenSubdiv Git repository at httpsgithub.comPixarAnimationStudiosOpenSubdiv From there, there are several ways of downloading the OpenSubdiv source code. Zip archive downloaded from here Using a GUI client you can find a list here Please refer to the documentation of your preferred application. From the GitShell, Cygwin or the CLI assuming that you have the Git tools installed, you can clone the OpenSubdiv repository directly with the following command git clone https github.comPixarAnimationStudiosOpenSubdiv.git These methods only pull static archives, which is are not under the version control system and therefore cannot pull updates or push changes back. If you intend on contributing features or fixes to the main trunk of the code, you will need to create a free Github account and clone a fork of the OpenSubdiv repository. Submissions to the main code trunk can be sent using Gits pull-request mechanisms. Please note that we are using the git flow tools so all changes should be made to our dev branch. Before we can accept submissions however, we will need a signed Contributors License Agreement . Branches Git Flow Since version 1.1.0, OpenSubdiv has adopted the Git Flow branching model . Our active development branch is named dev all new features and bug fixes should be submitted to this branch. The changes submitted to the dev branch are periodically patched to the release branch as new versions are released. Checking out branches The Git Flow tools are not a requisite for working with the OpenSubdiv code base, but new work should always be performed in the dev branch, or dedicated feature-branches. By default, a cloned repository will be pointing to the release branch. You can switch to the dev branch using the following command git checkout dev You can check that the branch has now been switched simply with git branch Which should return dev release API Versions OpenSubdiv maintains an internal API versioning system. The version number can be read from the file .opensubdivversion.h . Following the Git-Flow pattern, our releases are indexed using Gits tagging system. List of the existing tags git tag -- list Checking out version 1.2.0 git checkout v1_2_0 Making Changes Direct push access to the OpenSubdiv repository is currently limited to a small internal development team. External code should be submitted by sending Git pull-requests from forks of our dev branch. Code Overview The OpenSubdiv code base contains the following main areas Directory Contents .opensubdiv The main subdivision APIs Sdc, Vtr, Far and Osd. .examples A small collection of standalone applications that illustrate how to deploy the various features and optimizations of the OpenSubdiv APIs. The GL-based examples rely on the cross-platform GLFW API for interactive window management, while the DirectX ones are OS-native. .tutorials Tutorials showing how to manipulate the APIs of OpenSubdiv. .documentation The reStructuredText source files along with python scripts that generate the HTML documentation site. .regression Standalone regression tests and baseline data to help maintain the integrity of our APIs. If GPU SDKs are detected, some tests will attempt to run computations on those GPUs. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "getting_started.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "glPaintTest", │ │ │ │ │ - "text": "glPaintTest glPaintTest 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS KEYBOARD CONTROLS SEE ALSO SYNOPSIS glPaintTest -f -yup -l adaptive refinement level objfiles -catmark -loop DESCRIPTION glPaintTest is a small stand-alone application showing the potential of using GPU limit tessellation for painting and sculpting applications. OPTIONS See the description of the common comand line options for the subset of common options supported here. KEYBOARD CONTROLS c use texture as color d use texture as displacement SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "glpainttest.html" │ │ │ │ │ - }, { │ │ │ │ │ "title": "FAR Overview", │ │ │ │ │ "text": "FAR Overview FAR Overview 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Feature Adaptive Representation Far Topology Refinement Primvar Refinement FarTopologyRefiner FarTopologyRefinerFactory FarPrimvarRefiner FarPatchTable Patch Arrays Patch Types Patch Parameterization Single-Crease Patches Local Points Legacy Gregory Patches FarStencilTable Advantages Principles Cascading Stencils Limit Stencils Sample Location On Extraordinary Faces Code example Feature Adaptive Representation Far Far is the primary API layer for processing client-supplied mesh data into subdivided surfaces. The Far interface may be used directly and also may be used to prepare mesh data for further processing by Osd . The two main aspects of the subdivision process are Topology Refinement and Primvar Refinement . Topology Refinement Topology refinement is the process of splitting the mesh topology according to the specified subdivison rules to generate new topological vertices, edges, and faces. This process is purely topological and does not depend on the speciific values of any primvar data point positions, etc. Topology refinement can be either uniform or adaptive, where extraordinary features are automatically isolated see feature adaptive subdivision . The Far topology classes present a public interface for the refinement functionality provided in Vtr , The main classes in Far related to topology refinement are TopologyRefiner A class encapsulating mesh refinement. TopologyLevel A class representing one level of refinement within a TopologyRefiner. TopologyRefinerFactoryMESH A factory class template specialized in terms of the applications mesh representation used to construct TopologyRefiner instances. Primvar Refinement Primvar refinement is the process of computing values for primvar data points, colors, normals, texture coordinates, etc by applying weights determined by the specified subdivision rules. There are many advantages gained by distinguishing between topology refinement and primvar interpolation including the ability to apply a single static topological refinement to multiple primvar instances or to different animated primvar time samples. Far supports methods to refine primvar data at the locations of topological vertices and at arbitrary locations on the subdivision limit surface. The main classes in Far related to primvar refinement are PrimvarRefiner A class implementing refinement of primvar data at the locations of topological vertices. PatchTable A representation of the refined surface topology that can be used for efficient evaluation of primvar data at arbitrary locations. StencilTable A representation of refinement weights suitable for efficient parallel processing of primvar refinement. LimitStencilTable A representation of refinement weights suitable for efficient parallel processing of primvar refinement at arbitrary limit surface locations. FarTopologyRefiner TopologyRefiner is the building block for many other useful classes in Far . It performs refinement of an arbitrary mesh and provides access to the refined mesh topology. It can be used for primvar refinement directly using PrimvarRefiner or indirectly by being used to create a stencil table , or a patch table , etc. TopologyRefiner provides the public refinement methods RefineUniform and RefineAdapative which perform refinement operations using Vtr. TopologyRefiner provides access to the refined topology via TopologyLevel instances. FarTopologyRefinerFactory Consistent with other classes in Far, instances of TopologyRefiner are created by a factory class -- in this case FarTopologyRefinerFactory. Here we outline several approaches for converting mesh topology into the required FarTopologyRefiner. Additional documentation is provided with the FarTopologyRefinerFactoryMESH class template used by all, and each has a concrete example provided in one of the tutorials or in the Far code itself. There are three ways to create TopologyRefiners use the existing TopologyRefinerFactoryTopologyDescriptor with a populated instance of TopologyDescriptor specialize TopologyRefinerFactoryclass MESH for more efficient conversion, using only face-vertex information fully specialize TopologyRefinerFactorclass MESH for most control over conversion Use the FarTopologyDescriptor FarTopologyDescriptor is a simple struct that can be initialized to refer to raw mesh topology information -- primarily a face-vertex list -- and then passed to a provided factory class to create a TopologyRefiner from each. Topologically, the minimal requirement consists of the number of vertices and faces of the mesh an array containing the number of vertices per face an array containing the vertices assigned to each face These last two define one of the six topological relations that are needed internally by Vtr, but this one relation is sufficient to construct the rest. Additional members are available to assign sharpness values per edge andor vertex, hole tags to faces, or to define multiple sets channels of face-varying data. Almost all of the Far tutorials i.e. tutorialsfartutorial_ illustrate use of the TopologyDescriptor and its factory for creating TopologyRefiners, i.e. TopologyRefinerFactoryTopologyDescriptor. For situations when users have raw mesh data and have not yet constructed a boundary representation of their own, it is hoped that this will suffice. Options have even been provided to indicate that raw topology information has been defined in a left-hand winding order and the factory will handle the conversion to right-hand counter-clockwise winding on-the-fly to avoid unnecessary data duplication. Custom Factory for Face Vertices If the nature of the TopologyDescriptors data expectations is not helpful, and so conversion to large temporary arrays would be necessary to properly make use of it, it may be worth writing a custom factory. Specialization of TopologyRefinerFactoryclass MESH should be done with care as the goal here is to maximize the performance of the conversion and so minimize overhead due to runtime validation. The template provides the high-level construction of the required topology vectors of the underlying Vtr. There are two ways to write such a factory provide only the face-vertex information for topology and let the factory infer all edges and other relationships, or provide the complete edge list and all other topological relationships directly. The latter is considerably more involved and described in a following section. The definition of TopologyRefinerFactoryTopologyDescriptor provides a clear and complete example of constructing a TopologyRefiner with minimal topology information, i.e. the face-vertex list. The class template TopologyRefinerFactoryMESH documents the needs here and the TopologyDescriptor instantiation and specialization should illustrate that. Custom Factory for Direct Conversion Fully specializing a factory for direct conversion is needed only for those requiring ultimate control and is not generally recommended. It is recommended that one of the previous two methods initially be used to convert your mesh topology into a TopologyRefiner. If the conversion performance is critical, or significant enough to warrant improvement, then it is worth writing a factory for full topological conversion. Writing a custom factory requires the specificationspecialization of two methods with the following purpose specify the sizes of topological data so that vectors can be pre-allocated assign the topological data to the newly allocated vectors As noted above, the assumption here is that the clients boundary-rep knows best how to retrieve the data that we require most efficiently. After the factory class gathers sizing information and allocates appropriate memory, the factory provides the client with locations of the appropriate tables to be populated using the same Array classes and interface used to access the tables. The client is expected to load a complete topological description along with additional optional data, i.e. the six topological relations required by Vtr, oriented when manifold sharpness values for edges andor vertices optional additional tags related to the components, e.g. holes optional values-per-face for face-varying channels optional This approach requires dealing directly with edges, unlike the other two. In order to convert edges into a TopologyRefiners representation, the edges need to be expressed as a collection of known size N -- each of which is referred to directly by indices 0,N-1. This can be awkward for representations such as half-edge or quad-edge that do not treat the instance of an edge uniquely. Particular care is also necessary when representing non-manifold features. The previous two approaches will construct non-manifold features as required from the face-vertex list -- dealing with degenerate edges and other non-manifold features as encountered. When directly translating full topology it is necessary to tag non-manifold features, and also to ensure that certain edge relationships are satisfied in their presence. More details are available with the assembly methods of the factory class template. While there is plenty of opportunity for user error here, that is no different from any other conversion process. Given that Far controls the construction process through the Factory class, we do have ample opportunity to insert runtime validation, and to vary that level of validation at any time on an instance of the Factory. The factory does provide run-time validation on the topology constructed that can be used for debugging purposes. A common base class has been created for the factory class, i.e. template class MESH class TopologyRefinerFactory public TopologyRefinerFactoryBase both to provide common code independent of MESH and also potentially to protect core code from unwanted specialization. FarPrimvarRefiner PrimvarRefiner supports refinement of arbitrary primvar data at the locations of topological vertices. A PrimvarRefiner accesses topology data directly from a TopologyRefiner. Different methods are provided to support three different classes of primvar interpolation. These methods may be used to refine primvar data to a specified refinement level. Interpolate... Interpolate using vertex weights InterpolateVarying... Interpolate using linear weights InterpolateFaceVarying... Interpolate using face-varying weights Additional methods allow primvar data to be interpolated to the final limit surface including the calculation of first derivative tangents. Limitdst Interpolate to the limit surface using vertex weights Limitdst, dstTan1, dstTan2 Interpolate including first derivatives to the limit surface using vertex weights LimitFaceVarying... Interpolate to the limit surface using face-varying weights PrimarRefiner provides a straightforward interface for refining primvar data, but depending on the application use case, it can be more efficient to create and use a StencilTable , or PatchTable , to refine primvar data. FarPatchTable PatchTable is the collection of patches derived from the refined faces of a particular mesh topology. This collection is created using FarPatchTableFactory from an instance of FarTopologyRefiner after refinement has been applied. Patch Arrays The PatchTable is organized into patch arrays. All patches in each array have the same type except for face-varying patch arrays which may have a mix of regular and irregular patch types. The PatchDescriptor provides the fundamental description of a patch, including the number of control points per patch as well as the basis for patch evaluation. Each patch in the array is associated with a PatchParam which specifies additional information about the individual patch. Patch Types The following are the different patch types that can be represented in the PatchTable Patch Type CVs Description NON_PATCH na Undefined patch type POINTS 1 Points useful for cage drawing LINES 2 Lines useful for cage drawing QUADS 4 Bi-linear quadrilaterals TRIANGLES 3 Linear triangles LOOP 12 Quartic triangular Box-spline patches REGULAR 16 Bi-cubic B-spline patches GREGORY 4 Legacy Gregory patches GREGORY_BOUNDARY 4 Legacy Gregory Boundary patches GREGORY_BASIS 20 Bi-cubic quadrilateral Gregory patches GREGORY_TRIANGLE 18 Quartic triangular Gregory patches The type of a patch dictates the number of control vertices expected in the table as well as the method used to evaluate values. Patch Parameterization Here we describe the encoding of the patch parameterization for quadrilateral patches. The encoding for triangular patches is similar, please see the API documentation of FarPatchParam for details. Each patch represents a specific portion of the parametric space of the coarse topological face identified by the PatchParam FaceId. As topological refinement progresses through successive levels, each resulting patch corresponds to a smaller and smaller subdomain of the face. The PatchParam UV origin describes the mapping from the uv domain of the patch to the uv subdomain of the topological face. We encode this uv origin using log2 integer values for compactness and efficiency. It is important to note that this uv parameterization is the intrinsic parameterization within a given patch or coarse face and is distinct from any client specified face-varying channel data. Patches which result from irregular coarse faces non-quad faces in the Catmark scheme are offset by the one additional level needed to quadrangulate the irregular face. It is the indices of these offset faces that are stored in the PatchParam and used in other classes such as the FarPatchMap. These offset indices can be identified from the coarse face using the FarPtexIndices class when needed. A patch along an interpolated boundary edge is supported by an incomplete sets of control vertices. For consistency, patches in the PatchTable always have a full set of control vertex indices and the PatchParam Boundary bitmask identifies which control vertices are incomplete the incomplete control vertex indices are assigned values which duplicate the first valid index. Each bit in the boundary bitmask corresponds to one edge of the patch starting from the edge from the first vertex and continuing around the patch. With feature adaptive refinement, regular B-spline basis patches along interpolated boundaries will fall into one of the eight cases four boundary and four corner illustrated below Transition edges occur during feature adaptive refinement where a patch at one level of refinement is adjacent to pairs of patches at the next level of refinement. These T-junctions do not pose a problem when evaluating primvar data on patches, but they must be taken into consideration when tessellating patches e.g. while drawing in order to avoid cracks. The PatchParam Transition bitmask identifies the transition edges of a patch. Each bit in the bitmask corresponds to one edge of the patch just like the encoding of boundary edges. After refining an arbitrary mesh, any of the 16 possible transition edge configurations might occur. The method of handling transition edges is delegated to patch drawing code. Single-Crease Patches Using single-crease patches allows a mesh with creases to be represented with many fewer patches than would be needed otherwise. A single-crease patch is a variation of a regular BSpline patch with one additional crease sharpness parameter. Release Notes 3.x Evaluation of single-crease patches is currently only implemented for OSD patch drawing, but we expect to implement support in all of the evaluation code paths for future releases. Local Points The control vertices represented by a PatchTable are primarily refined points, i.e. points which result from applying the subdivision scheme uniformly or adaptively to the points of the coarse mesh. However, the final patches generated from irregular faces, e.g. patches incident on an extraordinary vertex might have a representation which requires additional local points. Legacy Gregory Patches Using Gregory patches to approximate the surface at the final patches generated from irregular faces is an alternative representation which does not require any additional local points to be computed. Instead, when Legacy Gregory patches are used, the PatchTable must also have an alternative representation of the mesh topology encoded as a vertex valence table and a quad offsets table. FarStencilTable The base container for stencil data is the StencilTable class. As with most other Far entities, it has an associated StencilTableFactory that requires a TopologyRefiner Advantages Stencils are used to factorize the interpolation calculations that subdivision schema apply to vertices of smooth surfaces. If the topology being subdivided remains constant, factorizing the subdivision weights into stencils during a pre-compute pass yields substantial amortizations at run-time when re-posing the control cage. Factorizing the subdivision weights also allows to express each subdivided vertex as a weighted sum of vertices from the control cage. This step effectively removes any data inter-dependency between subdivided vertices the computations of subdivision interpolation can be applied to each vertex in parallel without any barriers or constraint. The Osd classes leverage these properties by exploiting CPU and GPU parallelism. Principles Iterative subdivision algorithms converge towards the limit surface by successively refining the vertices of the coarse control cage. Each successive iteration interpolates the new vertices by applying polynomial weights to a basis of supporting vertices . The interpolation calculations for any given vertex can be broken down into sequences of multiply-add operations applied to the supporting vertices. Stencil table encodes a factorization of these weighted sums each stencils is created by combining the list of control vertices from the 1-ring. With iterative subdivision, each refinement step is dependent upon the previous subdivision step being completed, and a substantial number of steps may be required in order approximate the limit each subdivision step incurs an O4 n growing amount of computations. Instead, once the weights of the contributing coarse control vertices for a given refined vertex have been factorized, it is possible to apply the stencil and directly obtain the interpolated vertex data without having to process the data for the intermediate refinement levels. Cascading Stencils Client-code can control the amount of factorization of the stencils the tables can be generated with contributions all the way from a basis of coarse vertices, or reduced only to contributions from vertices from the previous level of refinement. The latter mode allows client-code to access and insert modifications to the vertex data at set refinement levels -- creating what are often referred to as hierarchical edits . Once the edits have been applied by the client-code, another set of stencils can be used to smooth the vertex data to a higher level of refinement. See implementation details, see the Far cascading stencil tutorial Limit Stencils Stencil tables can be trivially extended from discrete subdivided vertices to arbitrary locations on the limit surface. Aside from extraordinary points, every location on the limit surface can be expressed as a closed-form weighted average of a set of coarse control vertices from the 1-ring surrounding the face. The weight accumulation process is similar the control cage is adaptively subdivided around extraordinary locations. A stencil is then generated for each limit location simply by factorizing the bi-cubic Bspline patch weights over those of the contributing basis of control-vertices. The use of bi-cubic patches also allows the accumulation of analytical derivatives, so limit stencils carry a set of weights for tangent vectors. Once the stencil table has been generated, limit stencils are the most direct and efficient method of evaluation of specific locations on the limit of a subdivision surface, starting from the coarse vertices of the control cage. Also just as discrete stencils, limit stencils that are factorized from coarse control vertices do not have inter-dependencies and can be evaluated in parallel. For implementation details, see the glStencilViewer code example. Sample Location On Extraordinary Faces Each stencil is associated with a singular parametric location on the coarse mesh. The parametric location is defined as face location and local 0.0 - 1.0 u,v triplet In the case of face that are not quads, a parametric sub-face quadrant needs to be identified. This can be done either explicitly or implicitly by using the unique ptex face indices for instance. Code example When the control vertices controlPoints move in space, the limit locations can be very efficiently recomputed simply by applying the blending weights to the series of coarse control vertices class StencilType public void Clear memset x , 0 , sizeof StencilType void AddWithWeight StencilType const cv , float weight x cv . x weight y cv . y weight z cv . z weight float x , y , z std vector StencilType controlPoints , points , utan , vtan Update points by applying stencils controlStencils . UpdateValues StencilType controlPoints 0 , points 0 Update tangents by applying derivative stencils controlStencils . UpdateDerivs StencilType controlPoints 0 , utan 0 , vtan 0 Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "far_overview.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "dxPtexViewer", │ │ │ │ │ "text": "dxPtexViewer dxPtexViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS KEYBOARD CONTROLS SEE ALSO SYNOPSIS dxPtexViewer -f -yup -u -a -l isolation level -c animation loops -e environment map -d HDR diffuse map -s HDR specular map --disp displacement scale ptex color file ptex displacement file ptex occlusion file ptex specular file objfiles DESCRIPTION dxPtexViewer is a stand-alone application that showcases advanced HDR shading with color, displacement, occlusion and specular ptex maps. Multiple controls are available to experiment with the algorithms. OPTIONS See the description of the common comand line options for the subset of common options supported here. -y Swap Z-up geometry to Y-UP. -e environment map A low dynamic range spherical environment map used as a background. Ideally, a color-normalized version of the HDR light probe. -d HDR diffuse map An HDR file containing a diffuse environment map typically they are low resolution blurry hemispherical convolutions of the environment light probe. -s environment map An HDR file containing a specular environment map. --disp displacement scale A scalar multiplier for the shader displacement values. ptex color file A ptex file containing RGB channels read as material albedo color. ptex displacement file A single-channel ptex file preferrably float precision containing the displacement values. ptex occlusion file A single-channel ptex file preferrably 8 bits precision containing a pre-computed ambient occlusion signal. ptex specular file A single-channel ptex file preferrably 8 bits precision applied to modulate the specular reflectance of the material objfiles A sequence of obj files used as an animation loop the topology has to match the data contained in all the ptex files KEYBOARD CONTROLS q quit esc hide GUI f fit frame - increase decrese tessellation rate SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "dxptexviewer.html" │ │ │ │ │ }, { │ │ │ │ │ + "title": "Downloads", │ │ │ │ │ + "text": "Downloads Downloads 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Coupe Car Coupe Car Note we can use javascripts buttons to trigger download see button-download or we can just paste regular ReST hyperlinks to the files here. Direct links probably more reliable though. Coupe car maya Download Coupe car obj Download EULA OpenSubdiv is covered by a modified Apache 2.0 license included below, and is free to use for commercial or non-commercial use. All Pixar patents in the area of subdivision surface algorithms have also been released for public use. We welcome any involvement in the development or extension of this code in fact, we would love it. Please contact us if you are interested. Copyright 2013 Pixar Licensed under the Apache License, Version 2.0 the Apache License with the following modification you may not use this file except in compliance with the Apache License and the following modification to it Section 6. Trademarks. is deleted and replaced with 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor and its affiliates, except as required to comply with Section 4c of the License and to reproduce the content of the NOTICE file. You may obtain a copy of the Apache License at httpwww.apache.orglicensesLICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the Apache License with the above modification is distributed on an AS IS BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the Apache License for the specific language governing permissions and limitations under the Apache License. Accept Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ + "tags": "", │ │ │ │ │ + "loc": "downloads.html" │ │ │ │ │ + }, { │ │ │ │ │ "title": "dxViewer", │ │ │ │ │ "text": "dxViewer dxViewer 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE SYNOPSIS DESCRIPTION OPTIONS SEE ALSO SYNOPSIS dxViewer -f -yup -u -a -l refinement level -c animation loops objfiles -catmark -loop -bilinear DESCRIPTION dxViewer is a stand-alone application that showcases the application of uniform and feature adaptive subdivision schemes to a collection of geometric shapes. Multiple controls are available to experiment with the algorithms. OPTIONS See the description of the common comand line options for the subset of common options supported here. SEE ALSO Other examples glViewer , glFVarViewer , glEvalLimit , glStencilViewer , glPtexViewer , glPaintTest , glShareTopology , dxViewer , dxPtexViewer , Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "dxviewer.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "Contributing to OpenSubdiv", │ │ │ │ │ "text": "Contributing to OpenSubdiv Contributing to OpenSubdiv 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Contributor License Agreement Understand Git Recommended Git Workflow Sending a Pull Request Contributor License Agreement In order for us to accept code submissions merge git pull-requests, contributors need to sign the Contributor License Agreement CLA. There are two CLAs, one for individuals and one for corporations. As for the end-user license, both are based on Apache. They are found in the code repository individual form , corporate form . Please email the signed CLA to opensubdiv-clapixar.com . Understand Git First, you should familiarize yourself with the Git data model and commands. For small changes you may not need to understand Git deeply, but for larger changes or working with the codebase over a long period of time, it becomes critical to understand more of whats going on under the hood. There are many free resources on the internet, one which weve found useful is the following e-book httpsgithub.compluralsightgit-internals-pdfreleases Recommended Git Workflow Once you have a local development tree cloned and working, you can start making changes. You will need to integrate changes from the source tree as you work the following outlines the workflow used by core OpenSubdiv engineers at Pixar and DreamWorks Fork the repository into your own local copy. This can be done via the GitHub website using the fork button. Clone your fork locally git clone your_fork_url OpenSubdiv.your_name e.g. git clone httpsgithub.comyourusernameOpenSubdiv.git OpenSubdiv.yourusername Setup two remotes, origin and upstream . Origin will be setup as a result of cloning your remote repository, but upstream must be setup manually git remote add upstream httpsgithub.comPixarAnimationStudiosOpenSubdiv.git Verify your remotes are setup correctly git remote -v Which should look something like origin httpsgithub.comyourusernameOpenSubdiv.git fetch origin httpsgithub.comyourusernameOpenSubdiv.git push upstream httpsgithub.comPixarAnimationStudiosOpenSubdiv.git fetch upstream httpsgithub.comPixarAnimationStudiosOpenSubdiv.git push Finally, fetch the upstream content this is required for the next step git fetch upstream Setup a new branch for each change. Working with branches in Git is its greatest pleasure, we strongly suggest setting up a new branch for each change which you plan to pull-request. All work is done in the dev branch, so be sure to keep your change in sync with this upstream branch. To begin, start your new branch from the dev branch git checkout -b dev-feature upstreamdev As you are working on your feature, new changes will be merged into the upstream repository, to sync these changes down and preserve your local edits, you can continually rebase your local work git pull --rebase upstream dev Notice the --rebase option here. It updates the current branch to the upstreamdev branch and rebases all edits so they are at the head of your local feature branch. Alternatively, you can rebase all your work at once when your feature is complete. Sending a Pull Request First, rebase and squash your changes appropriately to produce a clean set of changes at the head of your tree. We require changes to be grouped locally to ensure that rolling back changes can be done easily. If youve followed the steps above, your pending change should already be queued up as required. If you have not, you may need to rebase and squash changes at this point. Once the change is clean, push your changes to origin and go to the GitHub website to submit your pull request. Be sure to submit your request against the dev branch. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "contributing.html" │ │ │ │ │ }, { │ │ │ │ │ - "title": "Downloads", │ │ │ │ │ - "text": "Downloads Downloads 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Coupe Car Coupe Car Note we can use javascripts buttons to trigger download see button-download or we can just paste regular ReST hyperlinks to the files here. Direct links probably more reliable though. Coupe car maya Download Coupe car obj Download EULA OpenSubdiv is covered by a modified Apache 2.0 license included below, and is free to use for commercial or non-commercial use. All Pixar patents in the area of subdivision surface algorithms have also been released for public use. We welcome any involvement in the development or extension of this code in fact, we would love it. Please contact us if you are interested. Copyright 2013 Pixar Licensed under the Apache License, Version 2.0 the Apache License with the following modification you may not use this file except in compliance with the Apache License and the following modification to it Section 6. Trademarks. is deleted and replaced with 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor and its affiliates, except as required to comply with Section 4c of the License and to reproduce the content of the NOTICE file. You may obtain a copy of the Apache License at httpwww.apache.orglicensesLICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the Apache License with the above modification is distributed on an AS IS BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the Apache License for the specific language governing permissions and limitations under the Apache License. Accept Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ - "tags": "", │ │ │ │ │ - "loc": "downloads.html" │ │ │ │ │ - }, { │ │ │ │ │ "title": "Subdivision Compatibility", │ │ │ │ │ "text": "Subdivision Compatibility Subdivision Compatibility 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Subdivision Compatibility Compatibility with OpenSubdiv 2.x Compatibility with RenderMan Incompatibilities Other Differences Subdivision Compatibility This document highlights areas of compatibility with other software that makes use of subdivision surfaces, including previous versions of OpenSubdiv. The compatibility here refers to the choice of subdivision rules that define the shape of the resulting surfaces. Different subdivision rules will lead to different shapes. Choices affecting shape include the types of subdivision schemes supported e.g. Catmull-Clark, Loop, etc. the basic rules applied for these schemes any extended rules to affect sharpness or creasing rules applied separately to face-varying data Ensuring all of these rules are consistent provides the basis for consistent shapes, but further approximations to the limit surface create the potential for subtle deviations. Even within OpenSubdiv, multiple approximations are possible and vary. For now we focus on the compatibility of subdivision rules and deal with the limit approximations only when noteworthy. Compatibility with OpenSubdiv 2.x The refactoring of OpenSubdiv 3.0 data representations presented a unique opportunity to revisit some corners of the subdivision specification and remove or update some legacy features. Face-varying Interpolation Options Face-varying interpolation options have been consolidated into a single enum with one additional choice new to 3.0. No functionality from 2.x has been removed -- just re-expressed in a simpler and more comprehensible form. Face-varying interpolation was previously defined by a boundary interpolation enum with four modes and an additional boolean propagate corners option, which was little understood, i.e. void HbrMeshSetFVarInterpolateBoundarMethodInterpolateBoundaryMethod const void HbrMeshSetFVarPropagateCornersbool const The latter was only used in conjunction with one of the four modes edge and corner, so it was effectively a unique fifth choice. Closer inspection of all of these modes also revealed some unexpected and undesirable behavior in some common cases -- to an extent that could not simply be changed -- and so an additional mode was added to avoid such behavior. All choices are now provided through a single linear interpolation enum, described and illustrated in more detail in the overview of Face-Varying Interpolation . The use of boundary in the name of the enum was intentionally removed as the choice also affects interior interpolation. The new use of linear is now intended to reflect the fact that interpolation is constrained to be linear where specified by the choice applied. All five of Hbrs original modes of face-varying interpolation are supported with minor modifications where Hbr was found to be incorrect in the presence of semi-sharp creasing. An additional mode corners only has also been added to avoid some of the undesired side-effects of some existing modes illustrated below. The new values for the SdcOptionsFVarLinearInterpolation enum and its equivalents for HbrMeshs InterpolateBoundaryMethod and PropagateCorners flag are as follows ordered such that the set of linear constraints applied is always increasing -- from completely smooth to completely linear Sdc FVarLinearInterpolation Hbr FVarInterpolateBoundaryMethod Hbr FVarPropogateCorners FVAR_LINEAR_NONE k_InterpolateBoundaryEdgeOnly NA ignored FVAR_LINEAR_CORNERS_ONLY NA NA FVAR_LINEAR_CORNERS_PLUS1 k_InterpolateBoundaryEdgeAndCorner false FVAR_LINEAR_CORNERS_PLUS2 k_InterpolateBoundaryEdgeAndCorner true FVAR_LINEAR_BOUNDARIES k_InterpolateBoundaryAlwaysSharp NA ignored FVAR_LINEAR_ALL k_InterpolateBoundaryNone NA ignored Aside from the two corners plus modes that preserve Hbr behavior, all other modes are designed so that the interpolation of a disjoint face-varying region is not affected by changes to other regions that may share the same vertex. So the behavior of a disjoint region should be well understood and predictable when looking at it in isolation e.g. with corners only one would expect to see linear constraints applied where there are topological corners or infinitely sharp creasing applied within the region, and nowhere else. This is not true of the plus modes, and they are named to reflect the fact that more is taken into account where disjoint regions meet. The following example illustrates some undesired effects of the plus modes, which in part motivated the addition of the new corners only mode. The example uses the catmark_fvar_bound0 and catmark_fvar_bound1 shapes from the suite of regression shapes. Both shapes are a simple regular 4x4 grid of quads with face-varying UV data partitioned into multiple disjoint regions. The bound0 shape has two disjoint UV regions -- an upper and lower region -- while the bound1 shape further splits the lower region in two. This first figure illustrates the effect of the original plus1 mode which is also the same for plus2 Note that the effect of splitting the lower UV region in two has the undesired side effect of sharpening the boundary of the upper region. This is the result of the plus1 mode making collective decisions about the sharpness of all face-varying boundaries at the vertex rather than decisions local to each region. In both the plus1 and plus2 cases, all face-varying boundaries sharing a vertex will be sharpened if there are more than two regions meeting at that vertex. The second figure illustrates the effect of the new corners only mode As expected, the splitting of the lower region does not impact the upper region. In this case the decision to sharpen a face-varying boundary is made based on the local topology of each region. Vertex Interpolation Options Since the various options are now presented through a new API Sdc rather than Hbr, based on the history of some of these options and input from interested parties, the following changes have been implemented The naming of the standard creasing method has been changed from Normal to Uniform . Values for SdcOptionsCreasingMethod are now CREASE_UNIFORM standard integer subtraction per level default CREASE_CHAIKIN Chaikin non-uniform averaging around vertices Legacy modes of the smoothtriangle rule have been removed as they were never actually enabled in the code. Values for SdcOptionsTriangleSubdivision are now TRI_SUB_CATMARK Catmull-Clark weights default TRI_SUB_SMOOTH smooth triangle weights These should have little impact since one is a simple change in terminology as part of a new API while the other was removal of an option that was never used. Change to Chaikin creasing method In the process of re-implementing the Chaikin creasing method, observations lead to a conscious choice to change the behavior of Chaikin creasing in the presence of infinitely sharp edges most noticeable at boundaries. Previously, the inclusion of infinite sharpness values in the Chaikin methods computation of edge sharpness around a vertex would prevent a semi-sharp edge from decaying to zero. Infinitely sharp edges are now excluded from the Chaikin non-uniform averaging yielding a much more predictable and desirable result. For example, where the sharpness assignment is actually uniform at such a vertex, the result will now behave the same as the Uniform method. Since this feature has received little use only recently activated in RenderMan, now seemed the best time to make the change before more widespread adoption. Hierarchical Edits While extremely powerful, Hierarchical Edits come with additional maintenance and implementation complexity. Support for them in popular interchange formats and major DCC applications has either been dropped or was never implemented. As a result, the need for Hierarchical Edits is too limited to justify the cost and support for them, and they have therefore been removed from the 3.0 release of OpenSubdiv. Dropping support for Hierarchical Edits allows for significant simplifications of many areas of the subdivision algorithms. While the 3.0 release does not offer direct support for Hierarchical Edits, the architectural changes and direction of 3.0 still facilitate the application of the most common value edits for those wishing to use them -- though not always in the same optimized context. Of course, support for Hierarchical Edits in the future will be considered based on demand and resources. Non-Manifold Topology OpenSubdiv 2.x and earlier was limited to dealing with meshes whose topology was manifold -- a limitation imposed by the use of Hbr. With 3.0 no longer using Hbr, the manifold restriction has also been removed. OpenSubdiv 3.0, therefore, supports a superset of the meshes supported by 2.x and earlier versions with one known exception noted below. Non-manifold meshes that are acceptable to 3.0 however will likely not work with 2.x or earlier. The one known case that 3.0 will not represent the same as 2.x is ironically a case that is non-manifold, and for which Hbr did make special accommodation. That case occurs at a non-manifold vertex where two or more faces meet at a common vertex, but do not share a common edge, and when the boundary interpolation mode is set for smooth corners i.e. edge only, as illustrated below The cage is on the left and is refined to level 2 on the right. On the immediate right, boundary interpolation is set to sharp corners and the results appear the same for 2.x and 3.0. The center and far right illustrate the affects of setting boundary interpolation to smooth corners with 2.x and 3.0 respectively. Note that the 2.x result allows the refined mesh and so the limit surface to split into two while the 3.0 result keeps it connected. When Hbr encounters such vertices, regardless of the boundary mode it splits the vertex -- creating a separate instance of it for each face. So when building an HbrMesh, after finalizing the mesh, it will result in having more vertices than were originally defined termed split vertices. OpenSubdiv 2.x and earlier successfully hid the presence of these extra vertices from users. This case behaves in such a way that violates certain properties of the surface that 3.0 has attempted to emphasize. One of these relates to the nature of the limit surface and becomes more significant in the context of face varying if the cage is connected then so too is its limit surface, or similarly, if the cage consists of N connected regions then the limit surface similarly consists of N connected regions. Another undesirable property here is that the vertex V at which these faces meet must have more than one child vertex V . This makes it difficult to hide split vertices -- OpenSubdiv 2.x tables had an extra level of indirection that made it possible to do this relatively easily, but 3.0 has dispensed with such indirection where possible to streamline performance. Compatibility with RenderMan Since RenderMan and OpenSubdiv versions prior to 3.0 share a common library Hbr, most differences between RenderMan and OpenSubdiv 3.0 are covered in the preceding section of compatibility with OpenSubdiv 2.x. In addition to some features between RenderMan and OpenSubdiv that are not compatible, there are also other differences that may be present due to differences in the implementations of similar features. For most use cases, OpenSubdiv 3.0 is largely compatible with RenderMan. There are however some cases where some differences can be expected. These are highlighted below for completeness. Incompatibilities OpenSubdiv and RenderMan will be incompatible when certain features are used that are not common to both. They are fully described in the 2.x compatibility section and are listed briefly here. OpenSubdiv 3.0 Features Not Supported by RenderMan Non-manifold meshes Choice of the corners only face varying interpolation option RenderMan Features Not Supported by OpenSubdiv 3.0 Hierarchical Edits Other Differences Some differences can occur due to the differing implementations of the feature sets. Additionally, OpenSubdiv 3.0s implementation fixes some issues discovered in Hbr. Smooth Face-Varying Interpolation with Creasing There have been two discrepancies noted in the way that face-varying data is interpolated smoothly in the presence of creases. Smooth face-varying interpolation is expected to match vertex interpolation in the interior and only differ along the boundaries or discontinuities where the face-varying topology is intentionally made to differ from the vertex topology. A simple and effective way to identify discrepancies is to use the X and Y coordinates of vertex positions as the U and V of texture coordinates. If these U and V coordinates are assigned to a face-varying channel, smooth interpolation of U and V is expected to exactly match interpolation of X and Y, regardless of the presence of any sharpness and creasing. Two discrepancies can be seen with Hbr when superimposing the XY vertex interpolation with the projected UV face-varying interpolation. The first discrepancy occurs with interpolation around dart vertices This example shows a simple regular XY grid on the left with an interior sharp edge creating a dart vertex in the center. With no asymmetry in the vertices, the sharpness has no asymmetric affect and the XY vertex interpolation on the immediate right shows the regular grid expected from refinement. On the far right is the UV interpolation from Hbr, which exhibits distortion around the center dart vertex. The second discrepancy occurs with interpolation involving any fractional sharpness values. Hbr effectively ignores any fractional sharpness value in its face-varying interpolation. So edges of vertices with sharpness of say 2.5, will be treated as though their sharpness is 2.0 when face-varying values are interpolated. Similarly, any non-zero sharpness value less than 1.0 is treated as zero by truncation and so is essentially ignored. This example shows an asymmetric 2x2 grid of quads on the left with the center vertex progressively sharpened from 0.5 to 1.0. The three cases of the vertex smooth and sharpened are superimposed on the immediate right to display the three distinct interpolation results. On the far right the interpolation from Hbr displays the same three cases, but only two are visibly distinct -- the sharpness of 0.5 being treated the same as if it were 0.0. Both of these cases are corrected in OpenSubdiv 3.0. Smooth face-varying interpolation in the presence of creasing should match the expected behavior of the vertex interpolation, except where the face-varying topology is explicitly made to differ. The Chaikin Creasing Method At least two discrepancies are know to exist between the implementations of Hbr in RenderMan and OpenSubdiv 3.0 Use of Chaikin creasing with boundaries or infinitely sharp edges Subtle shape differences due to Hbrs use of predictive sharpness Fortunately, this feature was only recently added to Hbr and RenderMan and is little used, so it is expected these differences will have little impact. The first discrepancy is mentioned briefly in the previous section on compatibility between OpenSubdiv 2.x and 3.0. A conscious decision was made to change the averaging of sharpness values involving infinitely sharp edges in order to make results more predictable and favorable. The effects can be seen comparing the regression shape catmark_chaikin2. The second is more subtle and results from an oversight within Hbrs implementation that is not easily corrected. When determining what subdivision rule to apply from one level to the next, the sharpness values at the next level must be known in order to determine whether or not a transition between differing rules is required. If the rule at the next level differs from the previous, a combination of the two is applied. Such a change results from the sharpness values of one or more edges or the vertex itself decaying to zero. Rather than compute the sharpness values at the next level accurately, Hbr predicts it by simply subtracting 1.0 from it, as is done with the uniform creasing method, and it bases decisions on that predicted result. This does not work for Chaikin though. A sharpness value less than 1.0 may not decay to 0 if it is averaged with neighboring sharpness values greater than 1.0, so this sharpness prediction can result in the wrong rule being chosen for the next level. A typical case would have the subdivision rules for Chaikin creasing transition from Corner to Crease at one level, then from Crease to Smooth at the next. Hbrs predictive creasing might mistakenly detect the transition as Corner to Smooth at one level, then after properly computing the sharpness values for the next level later, from Crease to Smooth for the next. One of the regression shapes catmark_chakin1 was disabled from the regression suite because of this effect. The differences in shape that trigger its regression failure were investigated and determined to be the result of this issue. From observations thus far these differences are subtle but can be noticeable. Numerical Precision Since its inception, OpenSubdiv has sought to produce results that were numerically consistent to RenderMan. A regression suite to ensure a certain level of accuracy was provided to detect any substantial deviation. At some point in the development of OpenSubdiv, the point was made that numerical accuracy of Hbr could be improved by changing the order of operations and combining the vertex with the lowest coefficient first in one of the subdivision rules. This was applied more thoroughly in the independent implementation of 3.0 there seemed no reason not to. In most cases the relative magnitudes of the coefficients of subdivision and limit masks is clear so no overhead was necessary to detect them. At a certain point though, this greater accuracy came in conflict with the regression suite. It turned out that high-valence vertices could not be computed to within the desired tolerances set within the suite. The summation of many small coefficients for the adjacent vertices first, before the addition of the much larger coefficient for the primary vertex, allowed for the accumulation of precision that was being truncated by adding the much larger coefficient first in the Hbr implementation. With extremely high valence vertices, a difference in magnitude between the most and least significant coefficients of several orders of magnitude is likely, and that has a significant impact on the single-precision floating point computations. The improved accuracy of OpenSubdiv 3.0 can reach a magnitude that will not go undetected. Whether or not this can lead to visual artifacts is unclear. Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use", │ │ │ │ │ "tags": "", │ │ │ │ │ "loc": "compatibility.html" │ │ │ │ │ }, { │ │ │ │ │ "title": "Code Examples", │ │ │ │ │ "text": "Code Examples Code Examples 3.6.0 User Docs API Docs Release Notes Forum Github OSD_ARTICLE_TITLE Standalone Viewers OpenSubdiv builds a number of standalone viewers that demonstrate various aspects of the software. OpenGL examples glViewer glFVarViewer glEvalLimit glStencilViewer glPtexViewer glPaintTest glShareTopology DirectX examples dxViewer dxPtexViewer Metal examples mtlViewer mtlPtexViewer Common Command Line Options While the following command line options are common, not all examples support all -- in some cases, certain options are not applicable. -f launches the application in full-screen mode if supported -yup set initial view with Y-axis up Z-up is the default -u apply uniform subdivision to all meshes -a apply adaptive subdivision to create patches for the limit surface -l depth level of uniform or adaptive refinement to apply -c count number of repetitions of the animation loop when supported default of 0 is infinite -anim interpret a given set of Obj files as an animated sequence rather than a set of distinct meshes -catmark apply the Catmark scheme to all meshes in given Obj files default -loop apply the Loop scheme to all meshes in given Obj files -bilinear apply the Bilinear scheme to all meshes in given Obj files objfiles a set of one or more meshes in Obj format requiring a .obj extension that may be distinct meshes or animated versions of a single mesh Common Keyboard Controls Left mouse button drag orbit camera Middle mouse button drag pan camera Right mouse button dolly camera n, p nextprev model 1, 2, 3, ..., 9, 0 specify adaptive isolation or uniform refinement level , - increase decrease tessellation Tab toggle full-screen Esc turn on off the HUD w switch display mode q quit Generated on 2025-01-02 0847 UTC. User Docs API Docs Release Notes Forum TM 1986 - 2017 PIXAR. ALL RIGHTS RESERVED. Terms of Use",