Difference between revisions of "2D Pseudo-Array"
Kireji Haiku (talk | contribs) m (some minor speed improvements for the example script) |
m (→LSL Implementation:: Replaced <source> with <syntaxhighlight>) |
||
(2 intermediate revisions by 2 users not shown) | |||
Line 44: | Line 44: | ||
== LSL Implementation: == | == LSL Implementation: == | ||
< | <syntaxhighlight lang="lsl2"> | ||
//----------------------------------------------------------------------------- | //----------------------------------------------------------------------------- | ||
// Script: IntegerArrayExample | // Script: IntegerArrayExample | ||
Line 52: | Line 52: | ||
// Written By: Sandie Harbour, July 2008 | // Written By: Sandie Harbour, July 2008 | ||
//----------------------------------------------------------------------------- | //----------------------------------------------------------------------------- | ||
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ | ||
// Function: initIntArray | // Function: initIntArray | ||
Line 59: | Line 59: | ||
// that will be used as an aarray. | // that will be used as an aarray. | ||
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ | ||
list makeArray (integer rows, integer cols) | list makeArray ( integer rows, integer cols ) | ||
{ | { | ||
integer i; | |||
list array = []; | list array = []; | ||
array += < rows, cols, 0 >; | array += < rows, cols, 0 >; | ||
for (i=0; i < rows * cols; ++i) | |||
{ | { | ||
array += 0; | array += 0; | ||
} | } | ||
return array; | return array; | ||
} | } | ||
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ | ||
// Function: getElement | // Function: getElement | ||
Line 80: | Line 77: | ||
// at the given row and column numbers. | // at the given row and column numbers. | ||
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ | ||
integer getElement(list array, integer row, integer col) | integer getElement( list array, integer row, integer col ) | ||
{ | { | ||
vector metadata = llList2Vector(array, 0); | vector metadata = llList2Vector( array, 0); | ||
integer cols = (integer)metadata.y; | integer cols = (integer)metadata.y; | ||
integer index = row * cols + col + 1; | integer index = row * cols + col + 1; | ||
return llList2Integer( array, index); | |||
} | |||
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ | ||
// Function: setElement | // Function: setElement | ||
Line 95: | Line 91: | ||
// the array. | // the array. | ||
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ | ||
list setElement(list array, integer row, integer col, integer value) | list setElement( list array, integer row, integer col, integer value ) | ||
{ | { | ||
vector metadata = llList2Vector( array, 0); | vector metadata = llList2Vector( array, 0); | ||
integer cols = (integer)metadata.y; | integer cols = (integer)metadata.y; | ||
integer index = row * cols + col + 1; | integer index = row * cols + col + 1; | ||
return llListReplaceList(array, [value], index, index); | return llListReplaceList(array, [value], index, index); | ||
} | } | ||
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ | ||
// | // | ||
Line 112: | Line 107: | ||
state_entry() | state_entry() | ||
{ | { | ||
integer rows = 4; | |||
integer cols = 6; | |||
integer row; | |||
integer col; | |||
integer index; | |||
// Build the array | // Build the array | ||
list elements = makeArray(4, 6); | list elements= makeArray( 4, 6 ); | ||
for (row=0; row < rows; ++row) | |||
{ | { | ||
for ( col=0; col<cols; ++col) | |||
{ | { | ||
index = row * cols + col + 1; | index = row * cols + col + 1; | ||
elements = setElement(elements, row, col, index); | elements = setElement(elements,row,col, index) ; | ||
} | } | ||
} | } | ||
row = 0; | for (row=0; row < rows; ++row) | ||
{ | { | ||
for ( col=0; col<cols; ++col) | |||
{ | { | ||
// Report the value at (3,4) | |||
integer element = getElement( elements,row,col); | |||
llOwnerSay( "row=" + (string)row | |||
+ ", col=" + (string)col | |||
+ ", index=" + (string)element); | |||
} | } | ||
} | } | ||
} | } | ||
} | } | ||
</ | </syntaxhighlight> |
Latest revision as of 13:28, 28 January 2023
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
Many times it is useful to work with multi-dimensional arrays. While LSL does not provide us with this functionality directly, it is possible to obtain the same behavior using a set of very simple algorithms.
A list is defined as “a heterogeneous list of the other data types”. It is linear by nature and can be thought of as a single column.
At the physical level, arrays are stored in contiguous sections of memory. (Another linear structure) An algorithm is used to translate between the logical rows and columns and the physical level of addresses.
Consider a list with 24 elements. Normally we visualize this as a vertical column. In this case, it is convenient to think of them as 4 rows and 6 columns.
Notice we are starting with element 1. Element zero is reserved for storing the size of the array.
0 | 1 | 2 | 3 | 4 | 5 | |
0 | 1 | 2 | 3 | 4 | 5 | 6 |
1 | 7 | 8 | 9 | 10 | 11 | 12 |
2 | 13 | 14 | 15 | 16 | 17 | 18 |
3 | 19 | 20 | 21 | 22 | 23 | 24 |
Figure 1. Indexes of a list arranged in rows and columns.
Our addressing algorithm can use the following formula:
index = row * cols + col + 1
Where:
- row is the row number of the element
- cols is the number of columns in the array
- col is the column number of the element
Example: Find the index for the data stored in row 3 and column 4.
- index = row * cols + col + 1
- index = 3 * 6 + 4 + 1
- index = 23
We will implement this in a set of functions. These functions raise the level of abstraction and give us the ability to manipulate arrays referencing rows and columns.
Sandie
LSL Implementation:
//-----------------------------------------------------------------------------
// Script: IntegerArrayExample
// Description:
// Example implementation of a 2-dimensional array of integers
//
// Written By: Sandie Harbour, July 2008
//-----------------------------------------------------------------------------
//------------------------------------------------------------------------------
// Function: initIntArray
// Descripton:
// Given the number of rows and columns, create an list of integers
// that will be used as an aarray.
//------------------------------------------------------------------------------
list makeArray ( integer rows, integer cols )
{
integer i;
list array = [];
array += < rows, cols, 0 >;
for (i=0; i < rows * cols; ++i)
{
array += 0;
}
return array;
}
//------------------------------------------------------------------------------
// Function: getElement
// Descripton:
// Return the integer which is stored in the given array
// at the given row and column numbers.
//------------------------------------------------------------------------------
integer getElement( list array, integer row, integer col )
{
vector metadata = llList2Vector( array, 0);
integer cols = (integer)metadata.y;
integer index = row * cols + col + 1;
return llList2Integer( array, index);
}
//------------------------------------------------------------------------------
// Function: setElement
// Descripton:
// Set the value in the specified row and columnn and return
// the array.
//------------------------------------------------------------------------------
list setElement( list array, integer row, integer col, integer value )
{
vector metadata = llList2Vector( array, 0);
integer cols = (integer)metadata.y;
integer index = row * cols + col + 1;
return llListReplaceList(array, [value], index, index);
}
//------------------------------------------------------------------------------
//
//------------------------------------------------------------------------------
default
{
state_entry()
{
integer rows = 4;
integer cols = 6;
integer row;
integer col;
integer index;
// Build the array
list elements= makeArray( 4, 6 );
for (row=0; row < rows; ++row)
{
for ( col=0; col<cols; ++col)
{
index = row * cols + col + 1;
elements = setElement(elements,row,col, index) ;
}
}
for (row=0; row < rows; ++row)
{
for ( col=0; col<cols; ++col)
{
// Report the value at (3,4)
integer element = getElement( elements,row,col);
llOwnerSay( "row=" + (string)row
+ ", col=" + (string)col
+ ", index=" + (string)element);
}
}
}
}