Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fully deterministic output #124

Open
nh2 opened this issue Oct 13, 2019 · 2 comments
Open

Fully deterministic output #124

nh2 opened this issue Oct 13, 2019 · 2 comments

Comments

@nh2
Copy link
Contributor

nh2 commented Oct 13, 2019

Hi,

is it possible to make texrecon produce fully deterministic output?

I noticed (with the versions from #120 (comment)) that multiple runs on the same input produce different outputs.

Most significantly, the order of texture patches in the generated material0000_map_Kd.png texture atlases is permuted (observed especially when OpenMP based multithreading is used).

But there is also nondeterminism when when there's no multithreading (when the environment variable OMP_THREAD_LIMIT=1 is set). I've observed sometimes that the PNG files are visually identical but differ slightly in size and contents (for example, for my 4k² texture, idiff reports 31 pixels being minimally different).

  1. Where in the code might this nondeterminism originate from?
  2. Do you think this is the only place of nondeterminism in texrecon?
  3. What do you think is needed to make it fully deterministic?

Thanks a lot for this software!

@nmoehrle
Copy link
Owner

The algorithm is supposed to be deterministic, there was a time when the non deterministic version of mapMAP was used, but that has been changed. If it isn't that is a bug, either uninitialized memory or a race condition. Do you know where the results start to differ? Is the labeling.vec still the same?

@nh2
Copy link
Contributor Author

nh2 commented Oct 15, 2019

I forgot to comment here: PR #126 has many determinsim fixes. May not be all yet but should certainly help.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants