Discussion:
[osg-users] Unbounded growth in OpenFlight ReaderWriter
Daniel Emminizer, Code 5773
2018-07-31 09:53:46 UTC
Permalink
Hello All,

I've found what appears to be unbounded growth in the OpenFlight loader. I have a work-around but wanted to run it past the community since there are many here who are more familiar with the format and the loader than me.

I'm seeing uncontrolled memory growth when using the std::istream version of readNode. It appears to populate the local cache with new images, but never clears out the local cache. The filename-based version of readNode() does clear out the cache before it returns.

Does it make sense to add in:

flt::Registry::instance()->clearLocalCache();

... before the return of the ReadResult at the bottom of this method at https://github.com/openscenegraph/OpenSceneGraph/blob/master/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp#L533 ?


If that's not a good path forward, do you have any suggestions on how to clear the cache on demand?

Thanks,

- Dan
Robert Osfield
2018-07-31 10:56:40 UTC
Permalink
Hi Dan,

I'm not at a point where I can easily switch over to thinking about
OSG code written by others so rather than jump it right now I'll ask a
simple question that might help point you in a direction worthy of
investigation.

FYI, I'm not the author of the OpenFlight plugin so am in the same
boat as yourself when it comes to working out what it does, what is
intended, what might be a bug etc. Each time I'm called in to fix
something in this plugin I learn a bit more... but still lots more to
learn.

I don't personally recall working with a flt::Registry::instance()
local cache so it's a new bit of OpenFlight plugin to me. I'm a bit
surprised it's there as osgDB has it's own object cache, so I'd wonder
what the motivation was behind the local cache and whether it's really
necessary. Could it be rewritten to use the osgDB's object cache?

Robert.







On Tue, 31 Jul 2018 at 11:19, Daniel Emminizer, Code 5773
Post by Daniel Emminizer, Code 5773
Hello All,
I've found what appears to be unbounded growth in the OpenFlight loader. I have a work-around but wanted to run it past the community since there are many here who are more familiar with the format and the loader than me.
I'm seeing uncontrolled memory growth when using the std::istream version of readNode. It appears to populate the local cache with new images, but never clears out the local cache. The filename-based version of readNode() does clear out the cache before it returns.
flt::Registry::instance()->clearLocalCache();
... before the return of the ReadResult at the bottom of this method at https://github.com/openscenegraph/OpenSceneGraph/blob/master/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp#L533 ?
If that's not a good path forward, do you have any suggestions on how to clear the cache on demand?
Thanks,
- Dan
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
Chris Hanson
2018-07-31 14:39:37 UTC
Permalink
I think Brede Johansson wrote that loader once upon a time. I'm hoping to
connect with him in Oslo this week. Maybe I'll ask him about this if I do.

On Tue, Jul 31, 2018 at 11:54 AM Daniel Emminizer, Code 5773 <
Post by Daniel Emminizer, Code 5773
Hello All,
I've found what appears to be unbounded growth in the OpenFlight loader.
I have a work-around but wanted to run it past the community since there
are many here who are more familiar with the format and the loader than me.
I'm seeing uncontrolled memory growth when using the std::istream version
of readNode. It appears to populate the local cache with new images, but
never clears out the local cache. The filename-based version of readNode()
does clear out the cache before it returns.
flt::Registry::instance()->clearLocalCache();
... before the return of the ReadResult at the bottom of this method at
https://github.com/openscenegraph/OpenSceneGraph/blob/master/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp#L533
?
If that's not a good path forward, do you have any suggestions on how to
clear the cache on demand?
Thanks,
- Dan
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
--
Chris 'Xenon' Hanson, omo sanza lettere. ***@AlphaPixel.com
http://www.alphapixel.com/
Training • Consulting • Contracting
3D • Scene Graphs (Open Scene Graph/OSG) • OpenGL 2 • OpenGL 3 • OpenGL 4 •
GLSL • OpenGL ES 1 • OpenGL ES 2 • OpenCL
Legal/IP • Forensics • Imaging • UAVs • GIS • GPS •
osgEarth • Terrain • Telemetry • Cryptography • LIDAR • Embedded • Mobile •
iPhone/iPad/iOS • Android
@alphapixel <https://twitter.com/alphapixel> facebook.com/alphapixel (775)
623-PIXL [7495]
Daniel Emminizer, Code 5773
2018-07-31 15:48:09 UTC
Permalink
Hi Chris,

I think that would be good. I have some modifications following Robert’s advice and after more testing I will be posting a PR. Yes, all of the object caching in OpenFlight plugin is the original code from Brede. It all dates back to 2006.

I was able to swap to use osgDB::Registry’s object cache with no complications on my end. I also got to learn more about the object caching system and how it clears out old values. Thanks Robert for the suggestion to look in this direction.

I ended up posting a PR at https://github.com/openscenegraph/OpenSceneGraph/pull/583 - It’s low priority since it’s a 12 year old issue, and because it takes a lot of work to get large enough images to crash an app from the problem on modern systems.

Thanks,

- Dan



From: osg-users [mailto:osg-users-***@lists.openscenegraph.org] On Behalf Of Chris Hanson
Sent: Tuesday, July 31, 2018 10:40 AM
To: OpenSceneGraph Users
Subject: Re: [osg-users] Unbounded growth in OpenFlight ReaderWriter

I think Brede Johansson wrote that loader once upon a time. I'm hoping to connect with him in Oslo this week. Maybe I'll ask him about this if I do.

On Tue, Jul 31, 2018 at 11:54 AM Daniel Emminizer, Code 5773 <***@nrl.navy.mil<mailto:***@nrl.navy.mil>> wrote:
Hello All,

I've found what appears to be unbounded growth in the OpenFlight loader. I have a work-around but wanted to run it past the community since there are many here who are more familiar with the format and the loader than me.

I'm seeing uncontrolled memory growth when using the std::istream version of readNode. It appears to populate the local cache with new images, but never clears out the local cache. The filename-based version of readNode() does clear out the cache before it returns.

Does it make sense to add in:

flt::Registry::instance()->clearLocalCache();

... before the return of the ReadResult at the bottom of this method at https://github.com/openscenegraph/OpenSceneGraph/blob/master/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp#L533 ?


If that's not a good path forward, do you have any suggestions on how to clear the cache on demand?

Thanks,

- Dan

_______________________________________________
osg-users mailing list
osg-***@lists.openscenegraph.org<mailto:osg-***@lists.openscenegraph.org>
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
--
Chris 'Xenon' Hanson, omo sanza lettere. ***@AlphaPixel.com http://www.alphapixel.com/
Training • Consulting • Contracting
3D • Scene Graphs (Open Scene Graph/OSG) • OpenGL 2 • OpenGL 3 • OpenGL 4 • GLSL • OpenGL ES 1 • OpenGL ES 2 • OpenCL
Legal/IP • Forensics • Imaging • UAVs • GIS • GPS • osgEarth • Terrain • Telemetry • Cryptography • LIDAR • Embedded • Mobile • iPhone/iPad/iOS • Android
@alphapixel<https://twitter.com/alphapixel> facebook.com/alphapixel<http://facebook.com/alphapixel> (775) 623-PIXL [7495]
Robert Osfield
2018-07-31 16:00:10 UTC
Permalink
Hi Dan,

Changes looks good to me, just merged. Nice to see a bug fix/feature
improvement that removes three times as much code as it adds! :-)

Cheers,
Robert.
On Tue, 31 Jul 2018 at 16:48, Daniel Emminizer, Code 5773
Post by Daniel Emminizer, Code 5773
Hi Chris,
I think that would be good. I have some modifications following Robert’s advice and after more testing I will be posting a PR. Yes, all of the object caching in OpenFlight plugin is the original code from Brede. It all dates back to 2006.
I was able to swap to use osgDB::Registry’s object cache with no complications on my end. I also got to learn more about the object caching system and how it clears out old values. Thanks Robert for the suggestion to look in this direction.
I ended up posting a PR at https://github.com/openscenegraph/OpenSceneGraph/pull/583 - It’s low priority since it’s a 12 year old issue, and because it takes a lot of work to get large enough images to crash an app from the problem on modern systems.
Thanks,
- Dan
Sent: Tuesday, July 31, 2018 10:40 AM
To: OpenSceneGraph Users
Subject: Re: [osg-users] Unbounded growth in OpenFlight ReaderWriter
I think Brede Johansson wrote that loader once upon a time. I'm hoping to connect with him in Oslo this week. Maybe I'll ask him about this if I do.
Hello All,
I've found what appears to be unbounded growth in the OpenFlight loader. I have a work-around but wanted to run it past the community since there are many here who are more familiar with the format and the loader than me.
I'm seeing uncontrolled memory growth when using the std::istream version of readNode. It appears to populate the local cache with new images, but never clears out the local cache. The filename-based version of readNode() does clear out the cache before it returns.
flt::Registry::instance()->clearLocalCache();
... before the return of the ReadResult at the bottom of this method at https://github.com/openscenegraph/OpenSceneGraph/blob/master/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp#L533 ?
If that's not a good path forward, do you have any suggestions on how to clear the cache on demand?
Thanks,
- Dan
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
--
Training • Consulting • Contracting
3D • Scene Graphs (Open Scene Graph/OSG) • OpenGL 2 • OpenGL 3 • OpenGL 4 • GLSL • OpenGL ES 1 • OpenGL ES 2 • OpenCL
Legal/IP • Forensics • Imaging • UAVs • GIS • GPS • osgEarth • Terrain • Telemetry • Cryptography • LIDAR • Embedded • Mobile • iPhone/iPad/iOS • Android
@alphapixel facebook.com/alphapixel (775) 623-PIXL [7495]
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
Robert Osfield
2018-07-31 16:04:22 UTC
Permalink
Post by Daniel Emminizer, Code 5773
I think Brede Johansson wrote that loader once upon a time. I'm hoping to connect with him in Oslo this week. Maybe I'll ask him about this if I do.
Brede's original OpenFlight plugin back in fall of 2000 was our first
major community submission and probably one of the most important in
the history of the OpenSceneGraph project.

Being able to load OpenFlight models made it possible for the vis-sim
market to quickly evaluate the OSG and solidify it as a serious
contender. Brede's work and his companies willingness to donate it to
the open source community is something we should all celebrate :-)

Robert.
David Glenn
2018-07-31 20:17:00 UTC
Permalink
Post by Robert Osfield
Post by Daniel Emminizer, Code 5773
I think Brede Johansson wrote that loader once upon a time. I'm hoping to connect with him in Oslo this week. Maybe I'll ask him about this if I do.
Brede's original OpenFlight plugin back in fall of 2000 was our first
major community submission and probably one of the most important in
the history of the OpenSceneGraph project.
Being able to load OpenFlight models made it possible for the vis-sim
market to quickly evaluate the OSG and solidify it as a serious
contender. Brede's work and his companies willingness to donate it to
the open source community is something we should all celebrate :-)
Robert.
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
------------------
Post generated by Mail2Forum
Your not going to get any argument from me on that one Robert! I have leaned so much about and from the open flight format by creating models and useing them in my OSG projects. Hands down, it's still my faveret format for Sim models - dispight me being pushed into using FBX and OBJ formats by my handlers. Cheers to Brede Johansson!

------------------------
David Glenn
---------------
D Glenn 3D Computer Graphics Entertainment.
www.dglenn.com

------------------
Read this topic online here:
http://forum.openscenegraph.org/viewtopic.php?p=74446#74446

Loading...