[interprocess] Performance problem with managed_shared_memory
data:image/s3,"s3://crabby-images/41270/41270cd89db839e3cb50aa39a939b6fedb8645fc" alt=""
Hi there,
I have a performance problem using the managed_shared_memory and the
interprocess_vector. I attached a minimalistic, compilable example that
demonstrates this.
I create a vector that contains a simple class and I write into this
vector. If the vector is located in the shared_memory this takes much
longer than if it is located in the process-local memory. The main
difference then is the used allocator. But I can not explain it.
If I run the attached code, I get the following results:
(running on Ubuntu 8.10, Boost version 1.40, gcc-Version 4.3.3)
SHMEM_TESTING: Mean: 0.024768 seconds.
else Mean: 0.015022 seconds.
I do not understand where the difference results from. Is there anybody
who has an explanation for that?
#include
data:image/s3,"s3://crabby-images/38c13/38c13dc5a3211b15354ca494d1f3a396af2dcaf0" alt=""
Moritz escribió:
Hi there,
I have a performance problem using the managed_shared_memory and the interprocess_vector. I attached a minimalistic, compilable example that demonstrates this. I create a vector that contains a simple class and I write into this vector. If the vector is located in the shared_memory this takes much longer than if it is located in the process-local memory. The main difference then is the used allocator. But I can not explain it.
Process shared containers use relative pointers so that each dereference needs additional operations to get the address on each process. Example: T &operator[](size_type idx) { *(start_+ idx;) } start_ is a smart pointer so pointer arithmetic is not trivial. The compiler can't also apply as many optimization as with raw pointers. So this is expected behaviour. You can improve it a bit with: for ( unsigned int i = 0; i < vec->size(); ++i ) { Point3f &f = ( *vec )[i]; f.x = i; f.y = i; f.z = i; } Or even faster obtaining a raw pointer to the first element: Point3f *first = &(*vec )[0]; for ( unsigned int i = 0; i < vec->size(); ++i ) { first[i].x = i; first[i].y = i; first[i].z = i; } Best, Ion
data:image/s3,"s3://crabby-images/41270/41270cd89db839e3cb50aa39a939b6fedb8645fc" alt=""
Hi Ion, thank you for your tremendous support in this mailing list. Best regards, Moritz Ion Gaztañaga wrote:
Process shared containers use relative pointers so that each dereference needs additional operations to get the address on each process. Example:
[...]
Best,
Ion
participants (2)
-
Ion Gaztañaga
-
Moritz