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

[WIP] Octree View Frustum Culling Example #27

Open
wants to merge 10 commits into
base: master
Choose a base branch
from

Conversation

Squareys
Copy link
Contributor

Hi @mosra !

Finally! The octree implementation, @ACapo and I started working on last year, is working! There is merely some cleanup left, especially on the MagnumExtras side, but I'm putting this out there anyway, just in case someone is in desperate need of Octree View Frustum Culling.

Basically, this should give you an idea what the API looks like at the moment.

This is in no way urgent, I know you're insanely busy for the next two weeks.

Regards, Jonathan.

@Squareys
Copy link
Contributor Author

TODOs:

  • Change License according to new license
  • Screenshot and Readme
  • Explanatory comments
  • General code cleanup

Copy link
Owner

@mosra mosra left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Roughly went over the changes, hopefully not complaining too much about code that's meant to be still reworked :)

Can you also update the doc/building.dox documentation page mentioning this example?

@@ -43,6 +43,7 @@ option(WITH_AUDIO_EXAMPLE "Build audio example (requires Magnum Audio library)"
option(WITH_BULLET_EXAMPLE "Build Bullet integration example (requires BulletIntegration library)" OFF)
cmake_dependent_option(WITH_CUBEMAP_EXAMPLE "Build CubeMap example (requires JpegImporter plugin)" OFF "NOT MAGNUM_TARGET_GLES" OFF)
cmake_dependent_option(WITH_MOTIONBLUR_EXAMPLE "Build MotionBlur example" OFF "NOT MAGNUM_TARGET_GLES" OFF)
option(WITH_OCTREE_EXAMPLE "Build Octree: example" OFF)
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the : is superfluous

MagnumExtras::SceneGraph
Magnum::Magnum)

target_compile_features(magnum-octree PRIVATE cxx_range_for)
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not needed (we expect C++11 conforming compiler).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Interestingly, I put that there, because the c++11 flag was not set for my compiler.

SceneGraph)


set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CORRADE_CXX_FLAGS}")
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please replace with

set_directory_properties(PROPERTIES CORRADE_USE_PEDANTIC_FLAGS ON)

Also please no more than one successive empty line ;)

Magnum::Application
MagnumExtras::Octree
MagnumExtras::SceneGraph
Magnum::Magnum)
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you order the libraries so all Magnum:: are together? If the link order matters, then there is a problem in the FindMagnumExtras.cmake module (each imported target should have its dependencies implicitly and not expect the user to link the dependencies explicitly).

const Color3 PINK{1.0f, 0.0f, 1.0f};
const Color3 WHITE{1.0f, 1.0f, 1.0f};
const Color3 LIGHT_GREY{0.5f, 0.5f, 0.5f};
const Color3 GREEN{0.0f, 0.2f, 0.0f};
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Use constexpr if possible and please no UPPERCASE -- these are not macros. Also, maybe it would look better with hex colors? Roughly (not the same colors):

constexpr Color3 Pink = 0xff00ff_rgbf;
constexpr Color3 White = 0xffffff_rgbf;
constexpr Color3 LightGrey = 0x999999_rgbf;
constexpr Color3 Green = 0x003300_rgbf;

const Vector3 rbf = calculateIntersection(right, bottom, far);
const Vector3 lbf = calculateIntersection(left, bottom, far);
const Vector3 rtf = calculateIntersection(right, top, far);
const Vector3 ltf = calculateIntersection(left, top, far);
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think I saw a very similarly looking code in the extras repo. So again I would suggest making a function / Frustum class out of this.

const float RAND_MAX_RANGE = float(RAND_MAX/60);
for(int i = 0; i < 10000; ++i) {
const Vector3 randomVector{float(std::rand()), float(std::rand()), float(std::rand())};
const Vector3 min = randomVector/RAND_MAX_RANGE - Vector3{30.0f};
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

std::rand() is deprecated, please use the C++11 functionality instead. It also has the ability to specify an output range, so you can get rid of the constants (and they shouldn't be uppercase).


const Float x = Matrix3({v1.w(), v2.w(), v3.w()}, {v1.y(), v2.y(), v3.y()}, {v1.z(), v2.z(), v3.z()}).determinant() / det;
const Float y = Matrix3({v1.x(), v2.x(), v3.x()}, {v1.w(), v2.w(), v3.w()}, {v1.z(), v2.z(), v3.z()}).determinant() / det;
const Float z = Matrix3({v1.x(), v2.x(), v3.x()}, {v1.y(), v2.y(), v3.y()}, {v1.w(), v2.w(), v3.w()}).determinant() / det;
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm. I would use Matrix3x3 instead of Matrix3. The difference is that the latter is meant for transformations in 2D (it has all the translation()/scaling() etc. helpers), whether the former is just a general-purpose 3x3 matrix.

And now the code compression fun:

const Float x = Matrix3x3{Math::swizzle<'w', 'y', 'z'>(v1), 
                          Math::swizzle<'w', 'y', 'z'>(v2),
                          Math::swizzle<'w', 'y', 'z'>(v3)}.determinant()/det;
const Float y = Matrix3x3{Math::swizzle<'x', 'w', 'z'>(v1), 
                          Math::swizzle<'x', 'w', 'z'>(v2),
                          Math::swizzle<'x', 'w', 'z'>(v3)}.determinant()/det;
const Float z = Matrix3x3{Math::swizzle<'x', 'y', 'w'>(v1), 
                          Math::swizzle<'x', 'y', 'w'>(v2),
                          Math::swizzle<'x', 'y', 'w'>(v3)}.determinant()/det;

Determinant of transposed matrix is equal to determinant of original matrix, so it should give the same output. There's still quite a lot of repeated code, but at least there are less places of potential error.

@@ -0,0 +1,2 @@
This example shows how to use octree view frustum culling in magnum.
![Octree](octree.png)
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please use Magnum instead of magnum in docs.

Also it would be great if this had the key bindings explained.

@mosra
Copy link
Owner

mosra commented Sep 26, 2016

Oh, and also enabling the example in all CIs, please :)

@mosra
Copy link
Owner

mosra commented Jun 16, 2020

@Squareys I'd say this is all obsoleted by #86?

@Squareys
Copy link
Contributor Author

@mosra I guess the difference is that this demos the "Official Octress" that's beeing PRd in magnum-extras. (mosra/magnum-extras#1).
Also frustum culling vs general octree is still a difference, so I think this could still have it's own viability should the octree ever make it in.
I think the state of that was that I did some crazy refactor to a. make it dimension-independent and b. faster.

@mosra
Copy link
Owner

mosra commented Jun 17, 2020

I commented because #86 has additional features the implementation in extras doesn't seem to have (loose octree, node allocation etc.) -- but OTOH the implementation in extras has tests, so neither of them is really a winner.

The real question is if the implementation in extras will ever get finished, I guess :) Judging from our priorities lately, I'm not very optimistic :D

@Squareys
Copy link
Contributor Author

in extras will ever get finished

Probably not too soon, no... but on here there are still some unmined gems like getting Frustum corners, intersecting three planes etc. We should save those somehow. (I have some refinements through the Clustered Forward+ stuff, though)

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

Successfully merging this pull request may close these issues.

3 participants