By the way, I'm mistaken regarding packed being deprecated, after checking manuals again, I did not find any references to it. I remember reading about it somewhere since release of XE 2, but perhaps got it confused with something else. Sorry.
By the way, I'm mistaken regarding packed being deprecated, after checking manuals again, I did not find any references to it. I remember reading about it somewhere since release of XE 2, but perhaps got it confused with something else. Sorry.
Packed records or packed arrays are used when you wnat to decrease the memory needed to store theese. Packed comes into effect if the records or arrays contains variables which by default aren't alined to 2, 4, 8 bit alingment. Default alingmnets for variables differ by variable type and is defined so that it offers optimized performance for working with theese variables.
But with the usage of Packed command you can override theese default alignments and pack data closely together thus lowering the memory consumption. Doing so also decreases the peformance of working with theese variables a bit since they are no longer optimally aligned. Unles you are using large record or large array difference in performance probably won't even be noticable.
Using of Packed records is sometimes necessary if you are sending some data to another application which is developed with different compiler since not all compilers use same data aligment for reaching optimal performance. In some cases using non packed records can cause for data in other program to be read incorectly.
So always make sure to check program documentation as of which type of records it can recieve. Same goes for varios API functions.
This memory optimization gave me a slight headache today. Was trying to use dynamic array of singles as source for vbo data and result was trash. Later it turned out that there's no such problems with static array. Can I force dynamic array to be bit aligned(or whatever its the problem)? using 'packed array' didn't help and Id' rather have a buffer that can grow if needed.
I have been using dynamic arrays with no problem, never had to use pack arrays, just arrays of pack records. what are you tring to pass ?
turned out that I was dereferencing a pointer in a wrong way
with static array it was just:
glBufferData(GL_ARRAY_BUFFER,x,buffer,GL_STATIC_DR AW);
and with dynamic should be:
glBufferData(GL_ARRAY_BUFFER,x,@buffer^[0],GL_STATIC_DRAW);
where 'buffer' is a pointer for that array type.
ps: it liiveees!!
Last edited by laggyluk; 01-12-2012 at 11:42 PM.
there is no way the compiler would change the layout for dynamic vs static that would break the compatibilty of the two. my guess is that you are miscalculating the size some where and the data isn't making it to the final destination. Edit:guess Iwas too slow, so you got it, looks good.
Last edited by Carver413; 02-12-2012 at 12:20 AM.
Not sure if it's solved but I want to make a comment about record alignment. In the engine I wrote and used in the 2nd. PGD Challenge I didn't use records to store data that is used with OpenGL; I use vectors (ARRAY) instead. For example, to store xyz points I used something like:
To access to each axis I use the CONST (i.e. Point[COOR_X], etc). This way I can use the "v" functions without alignment problems.Code:CONST COOR_X = 0; COOR_Y = 1; COOR_Z = 2; TYPE Vector3D = ARRAY [0..2] OF glFloat;
No signature provided yet.
Bookmarks