Registered Member
|
Actual Questions:
What exactly does Eigen use for dynamically allocating memory for large vectors/matrices/etc.? I'm guessing it uses an Eigen-specific aligned allocator, which probably uses malloc as the underlying allocator. Is this correct? (I'd look at the code myself, but it's way outside of my comfort zone. Eigen's code is up there with Boost in terms of being a wall of opaque template voodoo, and I'm too scared to try wading through it. ) Is there any way for clients to supply their own custom allocators instead (assuming they follow certain requirements, e.g. alignment), or are there any future plans for this? If not, is malloc the underlying allocator, and would hooking/redefining/wrapping/etc. malloc/free be sufficient for intercepting Eigen's memory allocation? If nothing else, does Eigen offer any way to measure its memory usage? Context, in case it matters: I'm writing a video game engine, and I'd like to tightly track and manage memory with custom allocators. I'll be using fixed-size vectors and matrices for the most part, so there aren't any worries there. However, I'd also like to experiment with dynamic fluids (especially water) in my engine. There are a lot of fluid simulation approaches, and I haven't settled on one yet, but one major approach involves solving a large set of linear equations with a preconditioned conjugate gradient method (using a modified incomplete Cholesky preconditioner with no fill-ins)...which I barely [kind of, sort of] understand. I'm actually pretty out of my depth, but I'm trying. Anyway, if I were to pick that approach, I'd have to manipulate some large vectors and a very large sparse matrix. I could write an inefficient and hacky implementation myself (and I might have to for the preconditioner), but I figure that it would probably be a lot smarter and more efficient to leverage Eigen for as much legwork as possible. The only problem is, using Eigen for the large vectors and sparse matrix might cramp my style from a memory management point of view. |
Registered Member
|
Behind the wall of template voodoo, there is this file: Eigen/src/Core/util/Memory.h which contains all the memory allocation functions we're using, and it's not too templated, it's mostly plain C. Read it! See especially the implementation of ei_aligned_malloc. We try hard to use system-specific aligned malloc functions (such as posix_memalign on POSIX systems) but if we fail to, as a fallback we use what you describe above --- malloc a bigger buffer and align it.
Unfortunately we don't support this at the moment, but I certainly agree that that could be useful. It's not clear however at what level to do it. The biggest use case we've heard of was to use distributed storage for huge matrices, and that required a separate Matrix class anyway to be efficient, so we have made sure our architecture is extensible in this respect.
Nope, it's not safe to assume that Eigen uses malloc. Right now, if you want to override Eigen's memory allocation, you have to edit Memory.h (mentioned above). Fortunately, everything goes through ei_aligned_malloc (or standard malloc / operator new) so you only have to override that.
Same answer: unfortunately no, but since all non-standard allocs go through ei_aligned_malloc / ei_aligned_free, you only have to hook into that. Oh and on linux we do some temporaries on the stack with alloca(), but you can get rid of that by defining #define EIGEN_STACK_ALLOCATION_LIMIT 0 that's in the same file.
Join us on Eigen's IRC channel: #eigen on irc.freenode.net
Have a serious interest in Eigen? Then join the mailing list! |
Registered Member
|
Hello,
I'm also interested in using a custom allocator for the same reason as the original post. I wonder if Eigen still doesn't provide a way for this. What I expect is something like how the STL containers allow the user to pass in the custom allocator. For example,
Thanks, Jeongseok |
Registered users: Bing [Bot], Google [Bot], rockscient, Yahoo [Bot]