POV-Ray : Newsgroups : povray.text.scene-files : bounding box calculator Server Time
15 Jan 2025 08:09:08 EST (-0500)
  bounding box calculator (Message 31 to 40 of 43)  
<<< Previous 10 Messages Goto Latest 10 Messages Next 3 Messages >>>
From: Thomas de Groot
Subject: Re: bounding box calculator
Date: 6 Nov 2019 03:26:53
Message: <5dc283cd@news.povray.org>
Op 04/11/2019 om 09:09 schreef Thomas de Groot:
> - the test is also useful with hyperboloid, superellipsoid, and 
> isosurface objects. Quartic and parametric objects do no comply, 
> probably they are not 'solid'? I did not test this thoroughly.
> 

The test (using version 2 of bounder.inc) for quartic objects is 
interesting. Using the Lemniscate object the BB seems to be infinite and 
the test is considered optimal. See image attached.

-- 
Thomas


Post a reply to this message


Attachments:
Download 'quarticbound.jpg' (174 KB)

Preview of image 'quarticbound.jpg'
quarticbound.jpg


 

From: Thomas de Groot
Subject: Re: bounding box calculator
Date: 6 Nov 2019 03:39:27
Message: <5dc286bf$1@news.povray.org>
Op 05/11/2019 om 01:19 schreef jr:
> "jr" <cre### [at] gmailcom> wrote:
>> ... I wrote a macro which "scans" an object's BB ...
> 
> find attached the second update of the 'Bounder'.
> 
> things have changed a little.  now, if the object's BB is found to be "(near)
> optimal", the macro prints that and ends, otherwise, ie having some "slack", the
> macro prints the difference lines as before, plus the optimised extents and
> dimensions, as per Thomas's feedback.
> 
> also new, if "slack" is reported, two variables with the differences from the
> BB's min/max extents are declared, to allow use of the info from in-scene.
> after 'Bounder' has run, one can for instance:
> 
> #ifdef(Bounder_min_diff)
>    // do something
> #end
> 
> so.  version 3.  fingers crossed.
> 
> 
> enjoy, jr.
> 

With version 3, I get a parser error in the scene file when the object 
is considered as near optimal: "Expected 'numeric expression', 
undeclared 'Bounder_min_diff' found instead"

-- 
Thomas


Post a reply to this message

From: jr
Subject: Re: bounding box calculator
Date: 6 Nov 2019 05:15:01
Message: <web.5dc29d0734d8ef06feeb22ff0@news.povray.org>
hi,

Thomas de Groot <tho### [at] degrootorg> wrote:
> Op 04/11/2019 om 09:09 schreef Thomas de Groot:
> > - the test is also useful with hyperboloid, superellipsoid, and
> > isosurface objects. Quartic and parametric objects do no comply,
> > probably they are not 'solid'? I did not test this thoroughly.
>
> The test (using version 2 of bounder.inc) for quartic objects is
> interesting. Using the Lemniscate object the BB seems to be infinite and
> the test is considered optimal. See image attached.

I see the BB change in size when the object is aligned, no idea(s).
interesting.


regards, jr.


Post a reply to this message

From: jr
Subject: Re: bounding box calculator
Date: 6 Nov 2019 05:20:00
Message: <web.5dc29d3b34d8ef06feeb22ff0@news.povray.org>
hi,

Thomas de Groot <tho### [at] degrootorg> wrote:
> Op 05/11/2019 om 01:19 schreef jr:
> > "jr" <cre### [at] gmailcom> wrote:
> >> ...
> > also new, if "slack" is reported, two variables with the differences from the
> > BB's min/max extents are declared, to allow use of the info from in-scene.
> > after 'Bounder' has run, one can for instance:
> >
> > #ifdef(Bounder_min_diff)
> >    // do something
> > #end
>
> With version 3, I get a parser error in the scene file when the object
> is considered as near optimal: "Expected 'numeric expression',
> undeclared 'Bounder_min_diff' found instead"

pls read the added comments in the file.  the vars are only 'declare'd _if_
there's any worthwhile "slack" to report.

the '#ifdef()' idiom though ought to work in any case (it does here).


regards, jr.


Post a reply to this message

From: jr
Subject: Re: bounding box calculator
Date: 6 Nov 2019 06:25:00
Message: <web.5dc2ad7034d8ef06feeb22ff0@news.povray.org>
hi,

Thomas de Groot <tho### [at] degrootorg> wrote:
> Op 04/11/2019 om 09:09 schreef Thomas de Groot:
> > - the test is also useful with hyperboloid, superellipsoid, and
> > isosurface objects. Quartic and parametric objects do no comply,
> > probably they are not 'solid'? I did not test this thoroughly.
>
> The test (using version 2 of bounder.inc) for quartic objects is
> interesting. Using the Lemniscate object the BB seems to be infinite and
> the test is considered optimal. See image attached.

I think I will add, in the header/comments of the file, a list of "unsuitable
for use with this macro" shapes.  what do you (and others) think?  thanks.


regards, jr.


Post a reply to this message

From: Thomas de Groot
Subject: Re: bounding box calculator
Date: 6 Nov 2019 06:51:13
Message: <5dc2b3b1@news.povray.org>
Op 06/11/2019 om 11:15 schreef jr:
> hi,
> 
> Thomas de Groot <tho### [at] degrootorg> wrote:
>> Op 05/11/2019 om 01:19 schreef jr:
>>> "jr" <cre### [at] gmailcom> wrote:
>>>> ...
>>> also new, if "slack" is reported, two variables with the differences from the
>>> BB's min/max extents are declared, to allow use of the info from in-scene.
>>> after 'Bounder' has run, one can for instance:
>>>
>>> #ifdef(Bounder_min_diff)
>>>     // do something
>>> #end
>>
>> With version 3, I get a parser error in the scene file when the object
>> is considered as near optimal: "Expected 'numeric expression',
>> undeclared 'Bounder_min_diff' found instead"
> 
> pls read the added comments in the file.  the vars are only 'declare'd _if_
> there's any worthwhile "slack" to report.
> 
> the '#ifdef()' idiom though ought to work in any case (it does here).
> 
> 

Yes, I thought so. The problem is not with the macro but with my test 
scene. I shall try to add something there which bypasses this.

-- 
Thomas


Post a reply to this message

From: Thomas de Groot
Subject: Re: bounding box calculator
Date: 6 Nov 2019 07:23:30
Message: <5dc2bb42$1@news.povray.org>
Op 06/11/2019 om 11:15 schreef jr:
> the '#ifdef()' idiom though ought to work in any case (it does here).
> 

It does! My bad.

Interesting test following this earlier post:

Op 04/11/2019 om 09:09 schreef Thomas de Groot:
 > - rotating the object changes the 'tightness' of the standard BB. I 
did that with a simple cylinder: when properly aligned along one of the 
axis, the BB test is always optimal; rotate the cylinder (e.g. 
<45,45,45>) and do the test, and the standard BB becomes too wide.
 >

I have to correct this: The BB only becomes slightly less optimal in the 
example cited. With increasing complexity of the object however, 
optimisation kicks in.

(1) use the following object: superellipsoid {<0.50, 3.50>}. The test is 
optimal.

(2) change the object to: superellipsoid {<0.50, 3.50> rotate 45}. The 
BB has now 'at least 5% "slack".'

-- 
Thomas


Post a reply to this message

From: Bald Eagle
Subject: Re: bounding box calculator
Date: 6 Nov 2019 07:25:00
Message: <web.5dc2baac34d8ef064eec112d0@news.povray.org>
"jr" <cre### [at] gmailcom> wrote:

> > The test (using version 2 of bounder.inc) for quartic objects is
> > interesting. Using the Lemniscate object the BB seems to be infinite and
> > the test is considered optimal. See image attached.
>
> I see the BB change in size when the object is aligned, no idea(s).
> interesting.


I guess add some #debug output, and maybe show some or all of the trace ()
tests, coloring them red or green according to if they "hit" or not.  Show each
successive BB with a different color, and that would help show what was going on
and give a better idea.

I would imagine that if POV-Ray can see and render the object, then the macro
ought to give sensible results.

Given an infinite (or sufficiently large) object along one axis, perhaps a
bounding rectangle (a cross-section of the infinitely long BB) could be shown /
reported.


Maybe after the SVD adventure, we coulld throw some function {} foo in there and
do a semi-transparent isosurface as a representation, which would allow
"infinite" objects to be easily displayed (by 'scaling' one axis to 0)

Just some early-morning thoughts.


Post a reply to this message

From: jr
Subject: Re: bounding box calculator
Date: 6 Nov 2019 08:50:00
Message: <web.5dc2cf5334d8ef06feeb22ff0@news.povray.org>
hi,

Thomas de Groot <tho### [at] degrootorg> wrote:
> Op 06/11/2019 om 11:15 schreef jr:
> > the '#ifdef()' idiom though ought to work in any case (it does here).
>
> It does! My bad.
>
> Interesting test following this earlier post:
> ...
> (1) use the following object: superellipsoid {<0.50, 3.50>}. The test is
> optimal.
> (2) change the object to: superellipsoid {<0.50, 3.50> rotate 45}. The
> BB has now 'at least 5% "slack".'

another candidate.  nice.  :-)  (more in reply to BE)


regards, jr.


Post a reply to this message

From: jr
Subject: Re: bounding box calculator
Date: 6 Nov 2019 08:50:01
Message: <web.5dc2cf6234d8ef06feeb22ff0@news.povray.org>
hi,

"Bald Eagle" <cre### [at] netscapenet> wrote:
> "jr" <cre### [at] gmailcom> wrote:
> > > The test (using version 2 of bounder.inc) for quartic objects is
> > > interesting. Using the Lemniscate object the BB seems to be infinite and
> > > the test is considered optimal. See image attached.
> > I see the BB change in size when the object is aligned, no idea(s).
> > interesting.
>
> I guess add some #debug output, and maybe show some or all of the trace ()
> tests, coloring them red or green according to if they "hit" or not.  Show each
> successive BB with a different color, and that would help show what was going on
> and give a better idea.

I'd play with something like that, no doubt, but won't put effort into (cf my
"rant" in an earlier reply to Thomas).

the 'Bounder' does not use 'trace()' though, it's all 'inside()' testing.

> I would imagine that if POV-Ray can see and render the object, then the macro
> ought to give sensible results.

agree, provided the object is amenable to 'inside()' testing.

ideally, I'd like a developer who knows POV-Ray's 'inside()' inside out (pun
intended) to chime in, giving us POV-Ray's "perspective" of processing an object
using 'inside()'.

> Given an infinite (or sufficiently large) object along one axis, perhaps a
> bounding rectangle (a cross-section of the infinitely long BB) could be shown /
> reported.

I'm more inclined[*] to provide a list of unsuitable object types, then the onus
is on the user to avoid things like the "Lemniscate"s reported by Thomas.

[*] currently.

> Maybe after the SVD adventure, we coulld throw some function {} foo in there and
> do a semi-transparent isosurface as a representation, which would allow
> "infinite" objects to be easily displayed (by 'scaling' one axis to 0)

again, nice but who'd write the code?

> Just some early-morning thoughts.

(one hand on keyboard, the other cradling the first cup of coffee, no doubt
:-))


regards, jr.


Post a reply to this message

<<< Previous 10 Messages Goto Latest 10 Messages Next 3 Messages >>>

Copyright 2003-2023 Persistence of Vision Raytracer Pty. Ltd.