The SLIM UV unwrap algorithm implementation for Blender 4.x #114545

Open
Lukasz Czyz wants to merge 197 commits from glukoz/blender:uv_unwrapping_slim_algorithm_v5_update into main

When changing the target branch, be careful to rebase the branch in your fork to match. See documentation.
First-time contributor

SUMMARY

The patch integrates an existing implementation of the SLIM unwrapping algorithm into Blender. More info about SLIM here: https://igl.ethz.ch/projects/slim/. The patch is based on the integration code written by Aurel Gruber for Blender 2.7x (not finished and never actually merged with the master branch). To learn more about SLIM, watch the following presentation by Aurel: https://www.youtube.com/watch?v=PLUoLQUK3-s

In this PR the original Aurel's code was rebased to a recent main commit and a bunch of further improvements were introduced.

HANDLING DOUBLED VERTICES AND ZERO TRIANGLES

First of all I used the original p_chart_simplify disabled code to implement  a new function: p_chart_collapse_doubles. The collapsing code used by p_chart_collapse_doubles is almost identical to p_chart_simplify - the criteria of collapsing is different though: as the name suggests it collapses edges only to remove doubled vertices.

Thanks to the simplified collapse criteria, it seems that we can avoid explicit uncollapsing after the operation is done - instead we can easily flush UV coords to collapsed vertices just before applying the result. It is the approach the current code uses (check the p_chart_flush_collapsed_uvs function).

To sum up (together with changes from the previous update): currently the mesh preprocessing before SLIM unwrap consists of two phases:

p_chart_collapse_doubles - removing doubled vertices
p_chart_correct_zero_angles - correcting zero area triangles.

WARNING - at the current stage it is not guaranteed that the above functions will work properly together with the live unwrap functionality. They may require some improvements. The point is that I cannot risk spending much time on improving and polishing these solutions without a confirmation that such an approach is acceptable by Blender devs on the general level.

So at this moment I need a confirmation (or rejection) of this general approach in order to continue work on this task.

### SUMMARY The patch integrates an existing implementation of the SLIM unwrapping algorithm into Blender. More info about SLIM here: https://igl.ethz.ch/projects/slim/. The patch is based on the integration code written by Aurel Gruber for Blender 2.7x (not finished and never actually merged with the master branch). To learn more about SLIM, watch the following presentation by Aurel: https://www.youtube.com/watch?v=PLUoLQUK3-s In this PR the original Aurel's code was rebased to a recent main commit and a bunch of further improvements were introduced. ### HANDLING DOUBLED VERTICES AND ZERO TRIANGLES First of all I used the original `p_chart_simplify` disabled code to implement  a new function: `p_chart_collapse_doubles`. The collapsing code used by `p_chart_collapse_doubles` is almost identical to `p_chart_simplify` - the criteria of collapsing is different though: as the name suggests it collapses edges only to remove doubled vertices. Thanks to the simplified collapse criteria, it seems that we can avoid explicit uncollapsing after the operation is done - instead we can easily flush UV coords to collapsed vertices just before applying the result. It is the approach the current code uses (check the `p_chart_flush_collapsed_uvs` function). To sum up (together with changes from the previous update): currently the mesh preprocessing before SLIM unwrap consists of two phases: `p_chart_collapse_doubles` - removing doubled vertices `p_chart_correct_zero_angles` - correcting zero area triangles. WARNING - at the current stage it is not guaranteed that the above functions will work properly together with the live unwrap functionality. They may require some improvements. The point is that I cannot risk spending much time on improving and polishing these solutions without a confirmation that such an approach is acceptable by Blender devs on the general level. **So at this moment I need a confirmation (or rejection) of this general approach in order to continue work on this task.**
Lukasz Czyz added 104 commits 2023-11-06 17:50:39 +01:00
# Conflicts:
#	source/blender/editors/uvedit/uvedit_parametrizer.h
#	source/blender/editors/uvedit/uvedit_unwrap_ops.c
#	source/blender/geometry/intern/uv_parametrizer.c
# Conflicts:
#	intern/CMakeLists.txt
#	source/blender/blenloader/intern/versioning_300.c
#	source/blender/editors/uvedit/uvedit_unwrap_ops.c
#	source/blender/geometry/intern/uv_parametrizer.cc
# Conflicts:
#	release/datafiles/locale
#	release/scripts/addons
#	source/blender/blenloader/intern/versioning_260.cc
#	source/blender/blenloader/intern/versioning_300.cc
#	source/blender/editors/uvedit/CMakeLists.txt
#	source/blender/editors/uvedit/uvedit_unwrap_ops.cc
#	source/blender/geometry/CMakeLists.txt
#	source/blender/geometry/GEO_uv_parametrizer.h
#	source/blender/geometry/intern/uv_parametrizer.cc
#	source/blender/makesdna/DNA_scene_types.h
#	source/blender/nodes/geometry/CMakeLists.txt
#	source/blender/nodes/geometry/nodes/node_geo_uv_pack_islands.cc
#	source/blender/nodes/geometry/nodes/node_geo_uv_unwrap.cc
#	source/blender/windowmanager/WM_api.h
#	source/tools
# Conflicts:
#	source/blender/editors/uvedit/uvedit_unwrap_ops.cc
# Conflicts:
#	source/blender/editors/include/ED_uvedit.h
#	source/blender/editors/transform/transform.cc
#	source/blender/editors/uvedit/uvedit_unwrap_ops.cc
Lukasz Czyz changed title from The SLIM UV unwrap algorithm implementation for Blender 4.x to WIP: The SLIM UV unwrap algorithm implementation for Blender 4.x 2023-11-06 17:50:58 +01:00
Lukasz Czyz requested review from Brecht Van Lommel 2023-11-06 17:54:37 +01:00

Thanks, I will find some time to look into this again. Hopefully next week.

Thanks, I will find some time to look into this again. Hopefully next week.
Brecht Van Lommel added 28 commits 2023-11-17 19:32:20 +01:00

I'm still working my way through the code, but pushed a bunch of changes to cut the size of this PR in half. And to use proper SPDX headers and align closer to our code style.

I'm still working my way through the code, but pushed a bunch of changes to cut the size of this PR in half. And to use proper SPDX headers and align closer to our code style.

I see various warnings when building this, should show on the buildbot too:
@blender-bot build

I see various warnings when building this, should show on the buildbot too: @blender-bot build
Author
First-time contributor

I pulled your changes and after that building fails. Is that expect or is it an issue with my environment?

I pulled your changes and after that building fails. Is that expect or is it an issue with my environment?

It's not expected. Maybe try to fix the errors, and if you can't show the error log?

It's not expected. Maybe try to fix the errors, and if you can't show the error log?
Lukasz Czyz added 1 commit 2023-11-23 15:14:03 +01:00
Author
First-time contributor

Ok, I fixed compilation and all warnings related to this PR.

Ok, I fixed compilation and all warnings related to this PR.
Brecht Van Lommel added 2 commits 2023-11-23 17:25:24 +01:00
Cleanup: follow code style
All checks were successful
buildbot/vexp-code-patch-coordinator Build done.
335ea29db0

There were more warnings in the buildbot logs. I fixed them, except these:

source/blender/geometry/intern/uv_parametrizer.cc:4964:10: warning: variable ‘select’ set but not used [-Wunused-but-set-variable]
source/blender/geometry/intern/uv_parametrizer.cc:4964:26: warning: variable ‘deselect’ set but not used [-Wunused-but-set-variable]

I guess certain charts need to be skipped based on these, similar to p_chart_lscm_begin.

@blender-bot build

There were more warnings in the buildbot logs. I fixed them, except these: ``` source/blender/geometry/intern/uv_parametrizer.cc:4964:10: warning: variable ‘select’ set but not used [-Wunused-but-set-variable] source/blender/geometry/intern/uv_parametrizer.cc:4964:26: warning: variable ‘deselect’ set but not used [-Wunused-but-set-variable] ``` I guess certain charts need to be skipped based on these, similar to `p_chart_lscm_begin`. @blender-bot build
Brecht Van Lommel added 3 commits 2023-11-23 20:45:08 +01:00
Brecht Van Lommel requested changes 2023-11-23 20:50:22 +01:00
Dismissed
@ -222,0 +263,4 @@
}
else {
/* We use the properties from the last unwrap operator for subsequent
* live unwrap and minize stretch operators. */

This comment seems to be incorrect, and perhaps this code and WM_operator_current_or_default_properties_alloc can be removed?

  • ED_uvedit_live_unwrap passes in toolsettings, so this code does not run
  • unwrap_exec does not pass in tool settings, but the operator should already remember its properties
  • pack_islands_exec and average_islands_scale_exec do not pass in tool settings, but these properties seems irrelevant to them.
This comment seems to be incorrect, and perhaps this code and `WM_operator_current_or_default_properties_alloc` can be removed? * `ED_uvedit_live_unwrap` passes in toolsettings, so this code does not run * `unwrap_exec` does not pass in tool settings, but the operator should already remember its properties * `pack_islands_exec` and `average_islands_scale_exec` do not pass in tool settings, but these properties seems irrelevant to them.
Author
First-time contributor

The main rationale of this code was to make the minimize stretch operator use the latest options used by the unwrap operator.

The rationale is not reflected in the current state of the implementation because the minimize stretch operator hasn't been ported to use SLIM yet. But it will probably be ported sooner or later so this code may be useful in the future.

The main rationale of this code was to make the minimize stretch operator use the latest options used by the unwrap operator. The rationale is not reflected in the current state of the implementation because the minimize stretch operator hasn't been ported to use SLIM yet. But it will probably be ported sooner or later so this code may be useful in the future.

The last used unwrap settings are already stored in the scene tool settings, so minimize stretch should get them from there instead.

The last used unwrap settings are already stored in the scene tool settings, so minimize stretch should get them from there instead.
Author
First-time contributor

I see. So I removed that call.

I see. So I removed that call.
brecht marked this conversation as resolved
@ -2605,0 +2826,4 @@
else {
uiDefAutoButsRNA(
layout, &ptr, unwrap_draw_check_prop_abf, NULL, NULL, UI_BUT_LABEL_ALIGN_NONE, false);
}

I think this would benefit from a manual layout now, using uiItemR for individual properties instead of uiDefAUtoButsRNA. That way properties can be grouped better.

For SLIM I think it could be grouped like this:

Method
Iterations
Reflection Mode

Vertex Group
Factor

Use Subdivision Surface

Correct Aspect
Margin Method
Margin
I think this would benefit from a manual layout now, using `uiItemR` for individual properties instead of `uiDefAUtoButsRNA`. That way properties can be grouped better. For SLIM I think it could be grouped like this: ``` Method Iterations Reflection Mode Vertex Group Factor Use Subdivision Surface Correct Aspect Margin Method Margin ```
Author
First-time contributor

Done, though I wasn't able to add separators between prop groups you specified. I was looking for a C++ counterpart of the Python layout.separator() call but with no luck.

Done, though I wasn't able to add separators between prop groups you specified. I was looking for a C++ counterpart of the Python `layout.separator()` call but with no luck.

It's uiItemS().

It's `uiItemS()`.
@ -2610,3 +2838,4 @@
{0, nullptr, 0, nullptr, nullptr},
};
static const EnumPropertyItem reflection_items[] = {{0, "ALLOW", 0, "Allow Flips", ""},

Could this be made into a allow_flips boolean? Doesn't seem like it should be an enum.

Could this be made into a `allow_flips` boolean? Doesn't seem like it should be an enum.
Author
First-time contributor

Done.

Done.
brecht marked this conversation as resolved
@ -4286,0 +4961,4 @@
slim::MatrixTransferChart &mt_chart = mt->mt_charts[i];
bool select = false, deselect = false;
int npins = 0;

select, deselect and npins are not used. Does this need similar logic to p_chart_lscm_begin, skipping some charts based on these?

Right now when you use live unwrap, and select a pin on one island and move it, it will continue solving other islands. I think this is unexpected, and would cause poor performance when there are many islands but you only want to work on one.

`select`, `deselect` and `npins` are not used. Does this need similar logic to `p_chart_lscm_begin`, skipping some charts based on these? Right now when you use live unwrap, and select a pin on one island and move it, it will continue solving other islands. I think this is unexpected, and would cause poor performance when there are many islands but you only want to work on one.
Author
First-time contributor

Done.

Done.
brecht marked this conversation as resolved

HANDLING DOUBLED VERTICES AND ZERO TRIANGLES

First of all I used the original p_chart_simplify disabled code to implement  a new function: p_chart_collapse_doubles. The collapsing code used by p_chart_collapse_doubles is almost identical to p_chart_simplify - the criteria of collapsing is different though: as the name suggests it collapses edges only to remove doubled vertices.

Thanks to the simplified collapse criteria, it seems that we can avoid explicit uncollapsing after the operation is done - instead we can easily flush UV coords to collapsed vertices just before applying the result. It is the approach the current code uses (check the p_chart_flush_collapsed_uvs function).

Is this code in the pull request? I do not see functions with these names.

The approach sounds good to me.

> ### HANDLING DOUBLED VERTICES AND ZERO TRIANGLES > > First of all I used the original `p_chart_simplify` disabled code to implement  a new function: `p_chart_collapse_doubles`. The collapsing code used by `p_chart_collapse_doubles` is almost identical to `p_chart_simplify` - the criteria of collapsing is different though: as the name suggests it collapses edges only to remove doubled vertices. > > Thanks to the simplified collapse criteria, it seems that we can avoid explicit uncollapsing after the operation is done - instead we can easily flush UV coords to collapsed vertices just before applying the result. It is the approach the current code uses (check the `p_chart_flush_collapsed_uvs` function). Is this code in the pull request? I do not see functions with these names. The approach sounds good to me.

I was going to open a devtalk topic for user feedback, but it seems the code for doubled vertices and zero triangles is missing? If so I can wait for that. Text was going to be:

There is an improved UV unwrapping method under review, and it would be great to get some user testing. The main advantage of this method is that it can better preserve area, instead of mainly caring about preserving angles like the existing Angle Based method. It can be tested by using Unwrap and selecting "SLIM" in the Adjust Last Operation panel.

Download builds.

Mainly helpful would be:

  • Test various different meshes, with varying complexity, poor topology, thin triangles, .. to find potential bugs.
  • Test if pinning and live unwrapping works well. Unlike Conformal/Angle Based, SLIM is iterative and does not converge to the solution immediately. How is the user interface for this?
  • Test unwrapping with a weight painted map. Did you find this feature useful? How is the user interface?
I was going to open a devtalk topic for user feedback, but it seems the code for doubled vertices and zero triangles is missing? If so I can wait for that. Text was going to be: > There is an improved [UV unwrapping method under review](https://projects.blender.org/blender/blender/pulls/114545), and it would be great to get some user testing. The main advantage of this method is that it can better preserve area, instead of mainly caring about preserving angles like the existing Angle Based method. It can be tested by using Unwrap and selecting "SLIM" in the Adjust Last Operation panel. > > [Download builds](https://builder.blender.org/download/patch/PR114545/). > > Mainly helpful would be: > * Test various different meshes, with varying complexity, poor topology, thin triangles, .. to find potential bugs. > * Test if pinning and live unwrapping works well. Unlike Conformal/Angle Based, SLIM is iterative and does not converge to the solution immediately. How is the user interface for this? > * Test unwrapping with a weight painted map. Did you find this feature useful? How is the user interface?
Lukasz Czyz added 6 commits 2023-11-24 12:12:34 +01:00
Author
First-time contributor

Indeed, I forgot to rebase the collapse_doubles part of the original change. Now it's fixed. I think you can open the devtalk topic now :)

I will look into other change requests in the next week.

Indeed, I forgot to rebase the collapse_doubles part of the original change. Now it's fixed. I think you can open the devtalk topic now :) I will look into other change requests in the next week.

@blender-bot package

@blender-bot package
Member

Package build started. Download here when ready.

Package build started. [Download here](https://builder.blender.org/download/patch/PR114545) when ready.
Brecht Van Lommel added 1 commit 2023-11-24 18:15:35 +01:00
With callback functions for cost/allowed, nearly all the code can
be shared with simplification.
Brecht Van Lommel added 1 commit 2023-11-24 19:16:17 +01:00

The double vertex collapsing code looks fine to me. After deduplicating it with the simplify implementation, it's also not much extra code.

The double vertex collapsing code looks fine to me. After deduplicating it with the simplify implementation, it's also not much extra code.
User feedback topic: https://devtalk.blender.org/t/slim-uv-unwrapping/32192
Lukasz Czyz added 6 commits 2023-12-01 19:26:25 +01:00

@glukoz are you following the feedback topic? Would be good if you can reply there too.

I think the most obvious improvements to make are to have two separate entries in the Unwrap menu, and to rename Vertex Group to indicate its purpose. For both the trickiest part is finding good names. We should also consider renaming SLIM to something that's easier to understand along with that, as we did for ABF and LSCM in the past.

There was one example of an unwrap failing, maybe possible to solve by tweaking the degenerate triangle handling?
https://devtalk.blender.org/t/slim-uv-unwrapping/32192/26

Report about pins not working well:
https://devtalk.blender.org/t/slim-uv-unwrapping/32192/27

@glukoz are you following the feedback topic? Would be good if you can reply there too. I think the most obvious improvements to make are to have two separate entries in the Unwrap menu, and to rename Vertex Group to indicate its purpose. For both the trickiest part is finding good names. We should also consider renaming SLIM to something that's easier to understand along with that, as we did for ABF and LSCM in the past. There was one example of an unwrap failing, maybe possible to solve by tweaking the degenerate triangle handling? https://devtalk.blender.org/t/slim-uv-unwrapping/32192/26 Report about pins not working well: https://devtalk.blender.org/t/slim-uv-unwrapping/32192/27

@blender-bot package

@blender-bot package
Member

Package build started. Download here when ready.

Package build started. [Download here](https://builder.blender.org/download/patch/PR114545) when ready.
Author
First-time contributor

@glukoz are you following the feedback topic? Would be good if you can reply there too.

Sure, I will take a look on it.

There was one example of an unwrap failing, maybe possible to solve by tweaking the degenerate triangle handling?
https://devtalk.blender.org/t/slim-uv-unwrapping/32192/26

Sure, I can tweak the algorithm so that the given mesh is processed BUT keep in mind that even after tweaking there may be another mesh which will not pass the test. I mean the algorithm does its best to fix a mesh but it cannot guarantee that it will work for every degenerated example. The question is whether you can accept such an approach in the long term.

> @glukoz are you following the feedback topic? Would be good if you can reply there too. Sure, I will take a look on it. > There was one example of an unwrap failing, maybe possible to solve by tweaking the degenerate triangle handling? > https://devtalk.blender.org/t/slim-uv-unwrapping/32192/26 Sure, I can tweak the algorithm so that the given mesh is processed BUT keep in mind that even after tweaking there may be another mesh which will not pass the test. I mean the algorithm does its best to fix a mesh but it cannot guarantee that it will work for every degenerated example. The question is whether you can accept such an approach in the long term.

Sure, I can tweak the algorithm so that the given mesh is processed BUT keep in mind that even after tweaking there may be another mesh which will not pass the test. I mean the algorithm does its best to fix a mesh but it cannot guarantee that it will work for every degenerated example. The question is whether you can accept such an approach in the long term.

What I did for ABF and LSCM is to keep investigating and fixing user reports until failures become rare. There's no well defined cut-off point for that. But it's important to look at some user reported ones since they tend to catch things a developer can find in testing.

If it turns out there is a certain class of problems we don't know how to solve, and it's common, then we can decide if some other algorithm is needed to clean up the geometry or if we accept it. But I would expect simple adjustments could go a long way. For example the in uv_initializer.cpp, if that step fails perhaps the angles could be clamped to some minimum value. Something similar really helped for ABF. If some other step fails, maybe similar clamping is possible in the solver.

> Sure, I can tweak the algorithm so that the given mesh is processed BUT keep in mind that even after tweaking there may be another mesh which will not pass the test. I mean the algorithm does its best to fix a mesh but it cannot guarantee that it will work for every degenerated example. The question is whether you can accept such an approach in the long term. What I did for ABF and LSCM is to keep investigating and fixing user reports until failures become rare. There's no well defined cut-off point for that. But it's important to look at some user reported ones since they tend to catch things a developer can find in testing. If it turns out there is a certain class of problems we don't know how to solve, and it's common, then we can decide if some other algorithm is needed to clean up the geometry or if we accept it. But I would expect simple adjustments could go a long way. For example the in `uv_initializer.cpp`, if that step fails perhaps the angles could be clamped to some minimum value. Something similar really helped for ABF. If some other step fails, maybe similar clamping is possible in the solver.

What do you think about naming like this?

In the operator properties:
SLIM -> Minimum Stretch
Vertex Group -> Importance Weights

In the unwrap menu add two separate operators:

  • Unwrap Angle Based
  • Unwrap Minimum Stretch

It ties in with the same algorithm being used for minimize stretch later.

What do you think about naming like this? In the operator properties: SLIM -> Minimum Stretch Vertex Group -> Importance Weights In the unwrap menu add two separate operators: * Unwrap Angle Based * Unwrap Minimum Stretch It ties in with the same algorithm being used for minimize stretch later.

I ran ABF and SLIM on a random subset of the dataset here. See attachment for script and results.
http://staff.ustc.edu.cn/~fuxm/projects/ProgressivePara/dataset.html

There are a fair amount of models where SLIM fails. Some of them actually succeed when removing the minimum angle and double vertex threshold, though have not checked if the results are good in general.

I ran ABF and SLIM on a random subset of the dataset here. See attachment for script and results. http://staff.ustc.edu.cn/~fuxm/projects/ProgressivePara/dataset.html There are a fair amount of models where SLIM fails. Some of them actually succeed when removing the minimum angle and double vertex threshold, though have not checked if the results are good in general.
Author
First-time contributor

What do you think about naming like this?

The naming seems ok for me.

I will take a look at the failing examples soon.

> What do you think about naming like this? The naming seems ok for me. I will take a look at the failing examples soon.
Lukasz Czyz added 13 commits 2024-01-02 15:23:22 +01:00
# Conflicts:
#	doc/license/SPDX-license-identifiers.txt
#	source/blender/makesdna/DNA_scene_types.h
Make format.
All checks were successful
buildbot/vexp-code-patch-lint Build done.
buildbot/vexp-code-patch-darwin-arm64 Build done.
buildbot/vexp-code-patch-darwin-x86_64 Build done.
buildbot/vexp-code-patch-linux-x86_64 Build done.
buildbot/vexp-code-patch-windows-amd64 Build done.
buildbot/vexp-code-patch-coordinator Build done.
e2422af2c4
Author
First-time contributor

In this update I worked on improving the function for correcting degenerate triangles. The function name is now p_chart_correct_degenerate_triangles. I reworked the function so it now checks two triangle parameters: area and minimum angle - the function tries to correct both parameters so they are above specified thresholds (note that both parameters are independent from the mathematical point of view).

The p_chart_correct_degenerate_triangles function is now able to deal with double vertices so the question is whether we still want to use the p_chart_collapse_doubles function.

I ran a test on the enrite D2 mesh set and it turned out that the correction function in the current state lowers the failing mesh count from 28 to 18. Note that the entire D2 set consists of 6190 meshes.

I investigated some of the failing 18 meshes and it turns out that SLIM may fail even when the correction function is able to correct all triangles in the mesh (by min area and min angle). Note that I double check that all triangles are actually corrected before the function returns (using asserts). So it looks like the failing meshes may be caused by bugs in the SLIM implementation itself.

Now I will take a look at the issue with pins not being respected by SLIM.

In this update I worked on improving the function for correcting degenerate triangles. The function name is now `p_chart_correct_degenerate_triangles`. I reworked the function so it now checks two triangle parameters: area and minimum angle - the function tries to correct both parameters so they are above specified thresholds (note that both parameters are independent from the mathematical point of view). The `p_chart_correct_degenerate_triangles` function is now able to deal with double vertices so the question is whether we still want to use the `p_chart_collapse_doubles` function. I ran a test on the enrite D2 mesh set and it turned out that the correction function in the current state lowers the failing mesh count from 28 to 18. Note that the entire D2 set consists of 6190 meshes. I investigated some of the failing 18 meshes and it turns out that SLIM may fail even when the correction function is able to correct all triangles in the mesh (by min area and min angle). Note that I double check that all triangles are actually corrected before the function returns (using asserts). So it looks like the failing meshes may be caused by bugs in the SLIM implementation itself. Now I will take a look at the issue with pins not being respected by SLIM.

@blender-bot package

@blender-bot package
Member

Package build started. Download here when ready.

Package build started. [Download here](https://builder.blender.org/download/patch/PR114545) when ready.
Lukasz Czyz added 3 commits 2024-02-05 17:06:16 +01:00
# Conflicts:
#	source/blender/blenloader/intern/versioning_300.cc
#	source/blender/nodes/geometry/CMakeLists.txt
SLIM - compilation fix.
Some checks failed
buildbot/vexp-code-patch-lint Build done.
buildbot/vexp-code-patch-darwin-x86_64 Build done.
buildbot/vexp-code-patch-darwin-arm64 Build done.
buildbot/vexp-code-patch-linux-x86_64 Build done.
buildbot/vexp-code-patch-windows-amd64 Build done.
buildbot/vexp-code-patch-coordinator Build done.
17dc993248
Author
First-time contributor

I solved the problem with pins not being respected.

Now the main question is whether you still want to merge this algorithm given the fact that SLIM may fail even when the correction function is able to correct all triangles in the mesh (by min area and min angle) - as I explained above.

I solved the problem with pins not being respected. Now the main question is whether you still want to merge this algorithm given the fact that SLIM may fail even when the correction function is able to correct all triangles in the mesh (by min area and min angle) - as I explained above.
Author
First-time contributor

@brecht Could you start a build with the recent changes? I am not sure whether I can do it on my own.

@brecht Could you start a build with the recent changes? I am not sure whether I can do it on my own.

@blender-bot package

@blender-bot package
Member

Package build started. Download here when ready.

Package build started. [Download here](https://builder.blender.org/download/patch/PR114545) when ready.

I'd like to have another look to see if I can find some solution for those failures. I don't think it's a blocker if we can't, but would be nice.

Then I guess this is nearly ready to merge for Blender 4.2? Still need to check all the latest changes.

I'd like to have another look to see if I can find some solution for those failures. I don't think it's a blocker if we can't, but would be nice. Then I guess this is nearly ready to merge for Blender 4.2? Still need to check all the latest changes.
Author
First-time contributor

@brecht Could ask people for feedback for the latest build in the dev thread? Unfortunately I cannot add 3 messages in a row there.

@brecht Could ask people for feedback for the latest build in the dev thread? Unfortunately I cannot add 3 messages in a row there.

@glukoz I've changed your trust level on devtalk to remove that restriction.

@glukoz I've changed your trust level on devtalk to remove that restriction.
Lukasz Czyz added 8 commits 2024-05-13 12:33:58 +02:00
First-time contributor

Very happy to see more updates on this patch! Really looking forward to it! Thanks for all the work Lukasz and Brecht! :)

Very happy to see more updates on this patch! Really looking forward to it! Thanks for all the work Lukasz and Brecht! :)
Lukasz Czyz added 1 commit 2024-05-13 13:30:31 +02:00
# Conflicts:
#	source/blender/editors/sculpt_paint/sculpt_uv.cc
#	source/blender/editors/uvedit/uvedit_unwrap_ops.cc
#	source/blender/geometry/intern/uv_parametrizer.cc
Lukasz Czyz added 1 commit 2024-05-13 14:04:31 +02:00
make format.
All checks were successful
buildbot/vexp-code-patch-darwin-x86_64 Build done.
buildbot/vexp-code-patch-linux-x86_64 Build done.
buildbot/vexp-code-patch-windows-amd64 Build done.
buildbot/vexp-code-patch-coordinator Build done.
ee70b9c412

@blender-bot package

@blender-bot package
Member

Package build started. Download here when ready.

Package build started. [Download here](https://builder.blender.org/download/patch/PR114545) when ready.
Gangneron requested changes 2024-05-17 15:43:51 +02:00
@ -0,0 +1,89 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,17 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,94 @@
/* SPDX-FileCopyrightText: 2013 Alec Jacobson
First-time contributor

Add Blende Authors 2024

Add `Blende Authors 2024`

I did not consider there to be significant changes that required claiming copyright from Blender authors.

I did not consider there to be significant changes that required claiming copyright from Blender authors.
brecht marked this conversation as resolved
@ -0,0 +1,40 @@
/* SPDX-FileCopyrightText: 2014 Alec Jacobson, 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,196 @@
/* SPDX-FileCopyrightText: 2013 Alec Jacobson
First-time contributor

Add Blender Authors 2024

Add `Blender Authors 2024`

I did not consider there to be significant changes that required claiming copyright from Blender authors.

I did not consider there to be significant changes that required claiming copyright from Blender authors.
brecht marked this conversation as resolved
@ -0,0 +1,48 @@
/* SPDX-FileCopyrightText: 2013 Alec Jacobson, 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,43 @@
/* SPDX-FileCopyrightText: 2013 Alec Jacobson, 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,58 @@
/* SPDX-FileCopyrightText: 2013 Alec Jacobson, 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,165 @@
/* SPDX-FileCopyrightText: 2016 Michael Rabinovich, 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,42 @@
/* SPDX-FileCopyrightText: 2016 Michael Rabinovich, 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,222 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,65 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,235 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,14 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,803 @@
/* SPDX-FileCopyrightText: 2016 Michael Rabinovich, 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,118 @@
/* SPDX-FileCopyrightText: 2016 Michael Rabinovich, 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,47 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,162 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,288 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,59 @@
/* SPDX-FileCopyrightText: 2023 Blender Authors
First-time contributor

Change 2023 by 2024

Change `2023` by `2024`
brecht marked this conversation as resolved
@ -0,0 +1,95 @@
/* SPDX-License-Identifier: GPL-2.0-or-later */
First-time contributor

Add /* SPDX-FileCopyrightText: 2024 Blender Authors and delete / before * SPDX-License-Identifier: GPL-2.0-or-later

Add `/* SPDX-FileCopyrightText: 2024 Blender Authors` and delete `/` before `* SPDX-License-Identifier: GPL-2.0-or-later`
First-time contributor

It's just some license information changes

It's just some license information changes
Author
First-time contributor

What do you think about naming like this?

In the operator properties:
SLIM -> Minimum Stretch
Vertex Group -> Importance Weights

In the unwrap menu add two separate operators:

  • Unwrap Angle Based
  • Unwrap Minimum Stretch

It ties in with the same algorithm being used for minimize stretch later.

Has a final decision to change the naming like this already been made? Should I implement it?

> What do you think about naming like this? > > In the operator properties: > SLIM -> Minimum Stretch > Vertex Group -> Importance Weights > > In the unwrap menu add two separate operators: > * Unwrap Angle Based > * Unwrap Minimum Stretch > > It ties in with the same algorithm being used for minimize stretch later. Has a final decision to change the naming like this already been made? Should I implement it?
First-time contributor

Hi @glukoz ,

Thank you for your work implementing SLIM for Blender. I've been implementing SLIM privately and noticed some differences between our implementations, as well as the original paper repo. Just some thoughts/qns:

  1. Intersections. It is possible that SLIM creates new intersections between triangles in the unwrap of a chart. This can be fixed by implementing the second check in Section 3.3 of the Smith and Schaefer paper. (ie. solving the quadratic eqn for when the determinant is zero between all boundary edges and boundary vertices). While the original repo doesn't seem to address this, having no new unwrap intersections might be something Blender users want.

  2. Line search. The original repo performs a bisection line search until Wolfe conditions are satisfied, whereas this repo has a more lightweight approach. As I am not an expert in this area, do you have any insight into the difference here?

Anyways, first time posting on the Blender repo. Do let me know if there's anything I can do to help. Thanks once again for your efforts here.

Hi @glukoz , Thank you for your work implementing SLIM for Blender. I've been implementing SLIM privately and noticed some differences between our implementations, as well as the original paper repo. Just some thoughts/qns: 1. Intersections. It is possible that SLIM creates new intersections between triangles in the unwrap of a chart. This can be fixed by implementing the second check in Section 3.3 of the [Smith and Schaefer paper](https://people.engr.tamu.edu/schaefer/research/bijective.pdf). (ie. solving the quadratic eqn for when the determinant is zero between all boundary edges and boundary vertices). While the original repo doesn't seem to address this, having no new unwrap intersections might be something Blender users want. 2. Line search. The original repo performs a bisection line search until Wolfe conditions are satisfied, whereas this repo has a more lightweight approach. As I am not an expert in this area, do you have any insight into the difference here? Anyways, first time posting on the Blender repo. Do let me know if there's anything I can do to help. Thanks once again for your efforts here.

Has a final decision to change the naming like this already been made? Should I implement it?

Yes, you can make the changes.

> Has a final decision to change the naming like this already been made? Should I implement it? Yes, you can make the changes.

@Gangneron Copyright years do not have to be updated to the latest. Adding some missing Blender Authors is good though.
https://developer.blender.org/docs/handbook/guidelines/license_headers/

@Gangneron Copyright years do not have to be updated to the latest. Adding some missing Blender Authors is good though. https://developer.blender.org/docs/handbook/guidelines/license_headers/
Author
First-time contributor

Hi @glukoz ,

Thank you for your work implementing SLIM for Blender. I've been implementing SLIM privately and noticed some differences between our implementations, as well as the original paper repo. Just some thoughts/qns:

Thank you for your input. Unfortunately I am familiar with the mathematical side of Blender-SLIM integration as it was originally implemented by Aurel Gruber - I am only taking care of the integration from the general architecture point of view.

That being said, I noticed a strange SLIM behaviour: If an input is passed to SLIM with no flipped triangles, it looks like SLIM may still generate an output with flips from such an input. Could you confirm that it may be the case indeed?

> Hi @glukoz , > > Thank you for your work implementing SLIM for Blender. I've been implementing SLIM privately and noticed some differences between our implementations, as well as the original paper repo. Just some thoughts/qns: > Thank you for your input. Unfortunately I am familiar with the mathematical side of Blender-SLIM integration as it was originally implemented by Aurel Gruber - I am only taking care of the integration from the general architecture point of view. That being said, I noticed a strange SLIM behaviour: If an input is passed to SLIM with no flipped triangles, it looks like SLIM may still generate an output with flips from such an input. Could you confirm that it may be the case indeed?
Author
First-time contributor

Yes, you can make the changes.

One question about the optimal way to implement this: what about moving the method prop from wmOperatorType::srna to wmOperatorType::prop and renaming the method values to:

Angle Based
Angle Based (Conformal)
Minimum Stretch

?

Or find some other name for Conformal?

> Yes, you can make the changes. One question about the optimal way to implement this: what about moving the `method` prop from `wmOperatorType::srna` to `wmOperatorType::prop` and renaming the method values to: Angle Based Angle Based (Conformal) Minimum Stretch ? Or find some other name for Conformal?

I would just keep it "Angle Based", "Conformal" and "Minimum Stretch". I don't think potential new names are going to be much more clear, that's it's worth users re-learning them (and tutorials going out of date).

I didn't understand what you meant moving from wmOperatorType::srna and wmOperatorType::prop. All operators properties are in srna, and prop is used for the "primary" property in the user interface in some places. Though I don't think such a primary property is needed here.

I would just keep it "Angle Based", "Conformal" and "Minimum Stretch". I don't think potential new names are going to be much more clear, that's it's worth users re-learning them (and tutorials going out of date). I didn't understand what you meant moving from `wmOperatorType::srna` and `wmOperatorType::prop`. All operators properties are in `srna`, and `prop` is used for the "primary" property in the user interface in some places. Though I don't think such a primary property is needed here.
Author
First-time contributor

I didn't understand what you meant moving from wmOperatorType::srna and wmOperatorType::prop. All operators properties are in srna, and prop is used for the "primary" property in the user interface in some places. Though I don't think such a primary property is needed here.

Correct me if I am wrong, but wouldn't such a move result in Blender showing method choices explicitly for example when searching for the Unwrap operator in the F3 menu? Like it is the case for the Merge operator for example:
image

Wouldn't that be convenient for the user?

> I didn't understand what you meant moving from `wmOperatorType::srna` and `wmOperatorType::prop`. All operators properties are in `srna`, and `prop` is used for the "primary" property in the user interface in some places. Though I don't think such a primary property is needed here. Correct me if I am wrong, but wouldn't such a move result in Blender showing method choices explicitly for example when searching for the Unwrap operator in the F3 menu? Like it is the case for the Merge operator for example: ![image](/attachments/6c277927-cf39-42b0-a737-eb6905e5e94e) Wouldn't that be convenient for the user?

Good point, it seems useful to do it for that case.

Good point, it seems useful to do it for that case.
Lukasz Czyz added 6 commits 2024-06-25 10:29:07 +02:00
Author
First-time contributor

Recent changes:

  • renaming:
    SLIM -> Minimum Stretch
    Vertex Group -> Importance Weights
    Factor -> Weights Factor

  • expanding the Unwrap operator in the UV editor menu using methods:
    image

  • reusing the UV editor unwrap menu in the 3D viewport UV menu (to make the UI consistent):
    image

Recent changes: * renaming: SLIM -> Minimum Stretch Vertex Group -> Importance Weights Factor -> Weights Factor * expanding the Unwrap operator in the UV editor menu using methods: <img width="194" alt="image" src="attachments/9c15d22b-42a6-412f-9756-707a58574405"> * reusing the UV editor unwrap menu in the 3D viewport UV menu (to make the UI consistent): <img width="919" alt="image" src="attachments/d6e5c354-7a4a-4ea4-ae29-7621e167445c">
Author
First-time contributor

One issue: the 'Importance Weights' label is truncated in the operator popup due to the popup is too narrow:
image

Can the width of the popup be increased somehow?

One issue: the 'Importance Weights' label is truncated in the operator popup due to the popup is too narrow: <img width="303" alt="image" src="attachments/c9dd266d-0272-424a-b94c-945081436313"> Can the width of the popup be increased somehow?
First-time contributor

One issue: the 'Importance Weights' label is truncated in the operator popup due to the popup is too narrow:
image

Can the width of the popup be increased somehow?

Not possible to my knowledge, at least not in Phyton, and I can not think of any operation that has more width than default in Blender either.

So I guess it could just be shortend to Weight or Importance and just have a tool tip with the full name and what it does, for now.

In the future it would be good if it was supported and exposed in the phyton api, as it adds some extra flexibility. Like how width is currently supported in for example invoke_props_dialogue menus.

> One issue: the 'Importance Weights' label is truncated in the operator popup due to the popup is too narrow: > <img width="303" alt="image" src="attachments/c9dd266d-0272-424a-b94c-945081436313"> > > Can the width of the popup be increased somehow? Not possible to my knowledge, at least not in Phyton, and I can not think of any operation that has more width than default in Blender either. So I guess it could just be shortend to Weight or Importance and just have a tool tip with the full name and what it does, for now. In the future it would be good if it was supported and exposed in the phyton api, as it adds some extra flexibility. Like how width is currently supported in for example invoke_props_dialogue menus.
Author
First-time contributor

So I guess it could just be shortend to Weight or Importance and just have a tool tip with the full name and what it does, for now.

If the popup cannot be widened, then my proposition is to shorten the label to Imp. Weights

> So I guess it could just be shortend to Weight or Importance and just have a tool tip with the full name and what it does, for now. If the popup cannot be widened, then my proposition is to shorten the label to `Imp. Weights`

One way to get around it would be to add a boolean:

              [x] Importance Weights
   Attribute  [ uv_importance       ]
      Factor  [        1.0          ]

Maybe by having a default attribute name, it encourages users to use the same one making it easier to re-run the operator on different objects.

One way to get around it would be to add a boolean: ``` [x] Importance Weights Attribute [ uv_importance ] Factor [ 1.0 ] ``` Maybe by having a default attribute name, it encourages users to use the same one making it easier to re-run the operator on different objects.
Lukasz Czyz added 2 commits 2024-06-25 21:54:06 +02:00
Make format.
All checks were successful
buildbot/vexp-code-patch-lint Build done.
buildbot/vexp-code-patch-darwin-x86_64 Build done.
buildbot/vexp-code-patch-darwin-arm64 Build done.
buildbot/vexp-code-patch-linux-x86_64 Build done.
buildbot/vexp-code-patch-windows-amd64 Build done.
buildbot/vexp-code-patch-coordinator Build done.
e81e939a64
Author
First-time contributor

One way to get around it would be to add a boolean:

I've implemented it.

One suggestion: what about such names:

				[x] Importance Weights
Weights Group	[ uv_importance       ]
Weights Factor	[        1.0          ]

?

It would be an indication for the user that the given props are logically related.

> One way to get around it would be to add a boolean: I've implemented it. One suggestion: what about such names: ``` [x] Importance Weights Weights Group [ uv_importance ] Weights Factor [ 1.0 ] ``` ? It would be an indication for the user that the given props are logically related.

Sure, those names are fine. You can also add a few separators (uiItemS) to better group properties.

Sure, those names are fine. You can also add a few separators (uiItemS) to better group properties.

@blender-bot package

@blender-bot package
Member

Package build started. Download here when ready.

Package build started. [Download here](https://builder.blender.org/download/patch/PR114545) when ready.

@glukoz I'll be on a 6 month sabbatical starting next week, so someone else will have to land this. I think this is in a good state now and my review comments have been addressed. It would be nice if somehow this could be made more numerically robust, though it's also not a blocker I think.

For the release notes we'll need some text, explaining advantages and limitations on a user level. And I think images that demonstrate the results on 2 or 3 models.

CC @howardt @ideasman42, maybe a topic for the modeling module meeting?

FYI @Sergey

@glukoz I'll be on a 6 month sabbatical starting next week, so someone else will have to land this. I think this is in a good state now and my review comments have been addressed. It would be nice if somehow this could be made more numerically robust, though it's also not a blocker I think. For the release notes we'll need some text, explaining advantages and limitations on a user level. And I think images that demonstrate the results on 2 or 3 models. CC @howardt @ideasman42, maybe a topic for the modeling module meeting? FYI @Sergey
Author
First-time contributor

Sure, those names are fine. You can also add a few separators (uiItemS) to better group properties.

I am currently on a short leave. I will update the names and the prop layout after this weekend.

> Sure, those names are fine. You can also add a few separators (uiItemS) to better group properties. I am currently on a short leave. I will update the names and the prop layout after this weekend.
Lukasz Czyz added 1 commit 2024-07-01 13:25:12 +02:00
Lukasz Czyz added 1 commit 2024-07-01 13:27:37 +02:00
Author
First-time contributor

Improvements done.

Can we merge this change now?

Improvements done. Can we merge this change now?
Sergey Sharybin dismissed brecht’s review 2024-07-02 16:38:58 +02:00
Sergey Sharybin dismissed brecht’s review 2024-07-02 16:39:01 +02:00
Reason:
No description provided.
Sergey Sharybin requested review from Howard Trickey 2024-07-02 16:39:34 +02:00
Sergey Sharybin requested review from Campbell Barton 2024-07-02 16:39:42 +02:00

@glukoz Thanks for the updates.
It was discussed during the Modelling Meeting. Howard and Campbell will pick up the review.

@glukoz Thanks for the updates. It was discussed during the [Modelling Meeting](https://projects.blender.org/blender/blender/pulls/114545). Howard and Campbell will pick up the review.
First-time contributor

Hi @glukoz ,

Thank you for your work implementing SLIM for Blender. I've been implementing SLIM privately and noticed some differences between our implementations, as well as the original paper repo. Just some thoughts/qns:

Thank you for your input. Unfortunately I am familiar with the mathematical side of Blender-SLIM integration as it was originally implemented by Aurel Gruber - I am only taking care of the integration from the general architecture point of view.

That being said, I noticed a strange SLIM behaviour: If an input is passed to SLIM with no flipped triangles, it looks like SLIM may still generate an output with flips from such an input. Could you confirm that it may be the case indeed?

Hi again @glukoz, apologies for the late response. I have not experienced this, but then again I have been running SLIM on small datasets. Will let you know if it crops up in more rigorous testing.

Just a thought: perhaps this is an issue in flip_avoiding_line_search.cpp. As an experiment, maybe try changing line 161-162 to the following:

double max_step_size = min(1., min_step_to_singularity);
cur_v = cur_v + max_step_size * d;
return energy(cur_v);

min_step_to_singularity should be the exact update value at which a flip occurs. If it is a smaller value than our intended update (1 * d), then we should use it instead. If this fixes the issue, then we know it is a problem inside the line_search function.

> > Hi @glukoz , > > > > Thank you for your work implementing SLIM for Blender. I've been implementing SLIM privately and noticed some differences between our implementations, as well as the original paper repo. Just some thoughts/qns: > > > > Thank you for your input. Unfortunately I am familiar with the mathematical side of Blender-SLIM integration as it was originally implemented by Aurel Gruber - I am only taking care of the integration from the general architecture point of view. > > That being said, I noticed a strange SLIM behaviour: If an input is passed to SLIM with no flipped triangles, it looks like SLIM may still generate an output with flips from such an input. Could you confirm that it may be the case indeed? > > > > > Hi again @glukoz, apologies for the late response. I have not experienced this, but then again I have been running SLIM on small datasets. Will let you know if it crops up in more rigorous testing. Just a thought: perhaps this is an issue in `flip_avoiding_line_search.cpp`. As an experiment, maybe try changing line 161-162 to the following: ``` double max_step_size = min(1., min_step_to_singularity); cur_v = cur_v + max_step_size * d; return energy(cur_v); ``` `min_step_to_singularity` should be the exact update value at which a flip occurs. If it is a smaller value than our intended update (1 * d), then we should use it instead. If this fixes the issue, then we know it is a problem inside the `line_search` function.
Member

I tried this out and it seems to work well. @glukoz are you still working on things, or do you think it is ready at this point?

I tried this out and it seems to work well. @glukoz are you still working on things, or do you think it is ready at this point?
Lukasz Czyz added 1 commit 2024-07-15 17:45:11 +02:00
# Conflicts:
#	source/blender/editors/uvedit/CMakeLists.txt
#	source/blender/nodes/geometry/CMakeLists.txt
Author
First-time contributor

I tried this out and it seems to work well. @glukoz are you still working on things, or do you think it is ready at this point?

I think it is ready.

> I tried this out and it seems to work well. @glukoz are you still working on things, or do you think it is ready at this point? I think it is ready.
Member

I'm getting crashes when using average island scale in this build.

  1. Add mesh "monkey"
  2. Go into edit mode
  3. select all uv's
  4. Run average island scale in the uv editor.

Blender freezes and crashes

I'm getting crashes when using `average island scale` in this build. 1. Add mesh "monkey" 2. Go into edit mode 3. select all uv's 4. Run average island scale in the uv editor. Blender freezes and crashes
Member

Other than the average island scale crash
#114545 (comment)
, I think this build works really nice. 👍 ❤️

@ideasman42 mentioned in the module meeting 240715 that he got different result when using live unwrap vs just using the minimize stretch unwrap with default settings. It seems to me that this is a result of live unwrap generates more iteration when moving vertices around.

If the the operators parameter iterations is changed to from 10 to 100 you get a result that more resembles to what you get when using live unwrap.

Other than the `average island scale crash` https://projects.blender.org/blender/blender/pulls/114545#issuecomment-1241121 , I think this build works really nice. 👍 ❤️ @ideasman42 mentioned in the module meeting 240715 that he got different result when using live unwrap vs just using the `minimize stretch unwrap` with default settings. It seems to me that this is a result of live unwrap generates more iteration when moving vertices around. If the the operators parameter `iterations` is changed to from 10 to 100 you get a result that more resembles to what you get when using live unwrap.
Lukasz Czyz added 1 commit 2024-07-17 14:36:56 +02:00
Author
First-time contributor

I'm getting crashes when using average island scale in this build.

Fixed it with the latest commit. Thank you for thorough testing!

> I'm getting crashes when using `average island scale` in this build. Fixed it with the latest commit. Thank you for thorough testing!

If it's considered ready from the side of the PR author, I'll remove the WIP prefix.

For live unwrap there is a trade-off. If it starts from scratch after every mouse motion, it will give the same results as regular unwrap, but it will be much slower and it won't be very interactive. This is why it works incrementally.

For LSCM/ABF there is a trick with matrix factorization to make it fast, but that's not applicable to SLIM unfortunately.

If it's considered ready from the side of the PR author, I'll remove the WIP prefix. For live unwrap there is a trade-off. If it starts from scratch after every mouse motion, it will give the same results as regular unwrap, but it will be much slower and it won't be very interactive. This is why it works incrementally. For LSCM/ABF there is a trick with matrix factorization to make it fast, but that's not applicable to SLIM unfortunately.
Brecht Van Lommel changed title from WIP: The SLIM UV unwrap algorithm implementation for Blender 4.x to The SLIM UV unwrap algorithm implementation for Blender 4.x 2024-07-24 22:05:28 +02:00
Author
First-time contributor

Thank you. What would be the next step for this?

Thank you. What would be the next step for this?

@ideasman42 @howardt Is this something on your agenda to review?

@ideasman42 @howardt Is this something on your agenda to review?
Iliya Katushenock reviewed 2024-08-01 11:32:08 +02:00
@ -99,0 +114,4 @@
*/
struct ParamSlimOptions {
public:

public: for structure can be omited.

`public:` for structure can be omited.
glukoz marked this conversation as resolved
@ -99,0 +121,4 @@
bool skip_initialization = false;
};
void uv_parametrizer_slim_solve(ParamHandle *handle,

Pass const arguments first.

Pass const arguments first.

No, I think it's better to keep the API consistent and always put ParamHandle first.

No, I think it's better to keep the API consistent and always put ParamHandle first.
brecht marked this conversation as resolved
@ -99,0 +126,4 @@
int *count_changed,
int *count_failed);
void uv_parametrizer_slim_live_begin(ParamHandle *handle, const ParamSlimOptions *mt_options);

Use references where this possible.

Use references where this possible.

I would not expect changes like this to an existing file to start using newer conventions. That kind of refactoring can be done separately.

I would not expect changes like this to an existing file to start using newer conventions. That kind of refactoring can be done separately.
brecht marked this conversation as resolved
@ -7,2 +7,4 @@
*/
#include <functional>
#include <vector>

Use blender containers instead of std where this possible (BLI_vector.hh)

Use blender containers instead of std where this possible (`BLI_vector.hh`)

It's not obviously the right thing here when this is interfacing with code in intern/ where we generally don't use these Blender containers.

It's not obviously the right thing here when this is interfacing with code in intern/ where we generally don't use these Blender containers.
Member

I agree that is appropriate for interfacing with code in intern/

I agree that <vector> is appropriate for interfacing with code in intern/
howardt marked this conversation as resolved
@ -344,6 +354,31 @@ static void p_face_angles(PFace *f, double *r_a1, double *r_a2, double *r_a3)
p_triangle_angles(v1->co, v2->co, v3->co, r_a1, r_a2, r_a3);
}
static float p_vec_cos(const float v1[3], const float v2[3], const float v3[3])

Use BLI_math_vector_types.hh instead of C math for new code.

Use `BLI_math_vector_types.hh` instead of C math for new code.

I would not expect changes like this to an existing file to start using newer conventions. That kind of refactoring can be done separately.

I would not expect changes like this to an existing file to start using newer conventions. That kind of refactoring can be done separately.
brecht marked this conversation as resolved
@ -645,2 +703,3 @@
static PVert *p_vert_add(ParamHandle *handle, PHashKey key, const float co[3], PEdge *e)
static PVert *p_vert_add(
ParamHandle *handle, PHashKey key, const float co[3], const float weight, PEdge *e)

Use r_ prefix for destination arguments, like PEdge *r_edge.

Use `r_` prefix for destination arguments, like `PEdge *r_edge`.

This is just adding a weight argument to an existing function, this PR is not the place to start refactoring existing code.

This is just adding a weight argument to an existing function, this PR is not the place to start refactoring existing code.
brecht marked this conversation as resolved
@ -1026,3 +1088,1 @@
e1->vert = p_vert_lookup(handle, vkeys[i1], co[i1], e1);
e2->vert = p_vert_lookup(handle, vkeys[i2], co[i2], e2);
e3->vert = p_vert_lookup(handle, vkeys[i3], co[i3], e3);
float weight1, weight2, weight3;

Do not create multiple variables at single line.

Do not create multiple variables at single line.

I don't see this in our C/C++ guidelines, does not make sense to me either.

I don't see this in our C/C++ guidelines, does not make sense to me either.
brecht marked this conversation as resolved
@ -1680,6 +1755,7 @@ static void p_collapse_edge(PEdge *edge, PEdge *pair)
}
}
#if 0

Is this code is unused? Can be deleted? Or at least add comment why...

Is this code is unused? Can be deleted? Or at least add comment why...

It should be kept, it's part of previously uncommented code that may still get used again.

It should be kept, it's part of previously uncommented code that may still get used again.
brecht marked this conversation as resolved
@ -2201,0 +2250,4 @@
{
/* Move from `collapsed_*`. */
PVert *v, *nextv = nullptr;

next_vert, vert_iter, next_edge, edge_iter, next_face, ...

`next_vert`, `vert_iter`, `next_edge`, `edge_iter`, `next_face`, ...

This is existing code that was moved, not the place here to start refactoring that.

This is existing code that was moved, not the place here to start refactoring that.
brecht marked this conversation as resolved
@ -2201,0 +2254,4 @@
PEdge *e, *nexte = nullptr;
PFace *f, *nextf = nullptr;
for (v = chart->collapsed_verts; v; v = nextv) {

for (PVert vert_iter = chart->collapsed_verts; vert_iter != nullptr; vert_iter = next_vert)

`for (PVert vert_iter = chart->collapsed_verts; vert_iter != nullptr; vert_iter = next_vert)`

This is existing code that was moved, not the place here to start refactoring that.

This is existing code that was moved, not the place here to start refactoring that.

I do not see where is from this code is moved/

I do not see where is from this code is moved/

It was moved out of p_chart_simplify_compute in the same file.

It was moved out of p_chart_simplify_compute in the same file.

I do not see the change of this file in this patch, i do not think copy-past of the function from somewhere as part of new feature is such a trivial cleanup that don't worh to be cleaned more.

I do not see the change of this file in this patch, i do not think copy-past of the function from somewhere as part of new feature is such a trivial cleanup that don't worh to be cleaned more.

Ah, this is was a function, had to ask my first question for ome other part of the code..\

Ah, this is was a function, had to ask my first question for ome other part of the code..\
brecht marked this conversation as resolved
@ -3802,1 +3883,4 @@
float *tri_uv[3] = {uv[v0], uv[v1], uv[v2]};
float *tri_weight = nullptr;
float tri_weight_tmp[3];

float3

`float3`

That kind of refactoring should be done for the file as a whole, doing it for individual places just makes things more messy.

That kind of refactoring should be done for the file as a whole, doing it for individual places just makes things more messy.
brecht marked this conversation as resolved
@ -4286,0 +4389,4 @@
p_collapsing_verts(edge, pair, &oldv, &keepv);
/* do not collapse a pinned vertex unless the target vertex
* is also pinned */

Add period in the end of the sentence.

Add period in the end of the sentence.
glukoz marked this conversation as resolved
@ -4286,0 +4408,4 @@
return p_edge_length_squared(collapse_e);
}
static void p_chart_collapse_doubles(PChart *chart, float threshold)

const float threshold

`const float threshold`
glukoz marked this conversation as resolved
@ -4286,0 +4443,4 @@
static bool p_validate_corrected_coords_point(const PEdge *corr_e,
const float corr_co1[3],
const float corr_co2[3],
float min_area,

const float min_area

`const float min_area`
glukoz marked this conversation as resolved
@ -4286,0 +4520,4 @@
const PVert *other_v1 = e->next->vert;
const PVert *other_v2 = e->next->next->vert;
float area = area_tri_v3(corr_co, other_v1->co, other_v2->co);

const float area

`const float area`
glukoz marked this conversation as resolved
@ -4286,0 +4542,4 @@
static bool p_edge_matrix(float R[3][3], const float edge_dir[3])
{
static const float eps = 1.0e-5;

constexpr float eps =

`constexpr float eps =`
glukoz marked this conversation as resolved
@ -4286,0 +4603,4 @@
float min_area,
float min_angle_cos)
{
static const float ref_edges[][3] = {{1.0f, 0.0f, 0.0f},

std::array<float3, ...>

`std::array<float3, ...> `
glukoz marked this conversation as resolved
@ -4286,0 +4635,4 @@
PEdge *e = f->edge;
for (int i = 0; i < 3; i++) {
float angle = (float)i / 3.0f * 2.0f * M_PI;

Use function style cast. math::numbers::pi

Use function style cast. `math::numbers::pi`

That kind of refactoring should be done for the file as a whole, doing it for individual places just makes things more inconsistent.

That kind of refactoring should be done for the file as a whole, doing it for individual places just makes things more inconsistent.
brecht marked this conversation as resolved
@ -4286,0 +4697,4 @@
float face_area = p_face_area(f);
PEdge *max_edge = nullptr;
float max_edge_len = -std::numeric_limits<float>::infinity();

::lowest()

`::lowest()`

-infinity and lowest are not the same.

-infinity and lowest are not the same.
brecht marked this conversation as resolved
@ -4286,0 +4700,4 @@
float max_edge_len = -std::numeric_limits<float>::infinity();
PEdge *min_edge = nullptr;
float min_edge_len = std::numeric_limits<float>::infinity();

::max()

`::max()`

infinity and max are not the same.

infinity and max are not the same.

I asked to change this not because they are the same.

I asked to change this not because they are the same.

I still see no reason to change this code?

I still see no reason to change this code?

max/lowest initial values seems more convenient in looking for the min/max.

`max`/`lowest` initial values seems more convenient in looking for the min/max.
brecht marked this conversation as resolved
@ -4286,0 +4771,4 @@
PVert *corr_v = corr_e->vert;
/* check 4 distinct directions */
static const int DIR_COUNT = 16;

Name style for the varibles, constexpr int

Name style for the varibles, `constexpr int`
glukoz marked this conversation as resolved
@ -4286,0 +5168,4 @@
slim::MatrixTransferChart &mt_chart,
slim::PinnedVertexData &pinned_vertex_data)
{
auto &pinned_vertex_indices = pinned_vertex_data.pinned_vertex_indices;

Always write the type instead of auto except of the cases with complicated templates (like map iterator).

Always write the type instead of `auto` except of the cases with complicated templates (like map iterator).
glukoz marked this conversation as resolved