MASON-INTEREST-L Archives

October 2007

MASON-INTEREST-L@LISTSERV.GMU.EDU

Options: Use Monospaced Font
Show Text Part by Default
Condense Mail Headers

Message: [<< First] [< Prev] [Next >] [Last >>]
Topic: [<< First] [< Prev] [Next >] [Last >>]
Author: [<< First] [< Prev] [Next >] [Last >>]

Print Reply
Sender:
MASON Multiagent Simulation Toolkit <[log in to unmask]>
Date:
Fri, 12 Oct 2007 19:18:46 -0400
MIME-version:
1.0 (Apple Message framework v752.3)
Reply-To:
MASON Multiagent Simulation Toolkit <[log in to unmask]>
Content-type:
text/plain; charset=US-ASCII; delsp=yes; format=flowed
Subject:
From:
Sean Luke <[log in to unmask]>
In-Reply-To:
Content-transfer-encoding:
7bit
Comments:
To: MASON Multiagent Simulation Toolkit <[log in to unmask]>
Parts/Attachments:
text/plain (63 lines)
Note that on line 101 of SparseFieldPortrayal3D.java, we have:

	for(int t= globalTG.numChildren()-1; t>=0; t--)

... that is, we're going backwards through the array of children.  We  
do this because of how I understood children were stored: in a  
packed, ordered fashion.  So if you deleted a child, all the children  
to its right would be slid down one index in the array.  Since we  
were deleting as we went (sometimes), going backwards would allow us  
to do all the children in order despite deleting some of them.  This  
*shouldn't* cause the array to get too small that the index (t) would  
be out of bounds in this line (110):

	            BranchGroup localBG = (BranchGroup)globalTG.getChild(t);

... but it appears to be doing so and I'm not sure why.  My first  
guess is that the line

                     globalTG.setChild(newlocalBG, t);

is mucking up the array in a way I hadn't anticipated.  So I'd start  
looking there.

Sean

On Oct 12, 2007, at 6:43 PM, Glen E. P. Ropella wrote:

> -----BEGIN PGP SIGNED MESSAGE-----
> Hash: SHA1
>
> Sean Luke wrote:
>> This has got to be a bug in SparseFieldProtrayal3D's updateModel
>> method.  I can see all sorts of evil places where there's likely a  
>> bug
>> there -- the number one possibility is that globalTG.removeChild 
>> (t) may
>> be operating in the middle of the for-loop over  
>> globalTG.numChildren(),
>> which is probably not wise.  :-)
>>
>> Unfortunately, I do not have enough time to look at this code and  
>> debug
>> it for a week or more (grant proposal deadline).  Gabriel might have
>> time possibly.
>
> OK.  I'll spend some time trying to track it down.  If I find  
> anything,
> I'll post it.  Thanks!
>
> - --
> glen e. p. ropella, 971-219-3846, http://tempusdictum.com
> If a man can't piss in his own front yard, he's living too close to
> town. -- Tom Russell
>
> -----BEGIN PGP SIGNATURE-----
> Version: GnuPG v1.4.6 (GNU/Linux)
> Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org
>
> iD8DBQFHD/iRZeB+vOTnLkoRAiHWAJ9Kyye36NFGIklnocSjTuHrDY8LfgCg16pC
> Yya92t5CGO/5N3UCU4RX/+M=
> =1y9Y
> -----END PGP SIGNATURE-----

ATOM RSS1 RSS2