几何尺寸与公差论坛

 找回密码
 注册
查看: 493|回复: 0

handling large stiffness matri

[复制链接]
发表于 2009-9-9 15:49:16 | 显示全部楼层 |阅读模式
handling large stiffness matrix
does any know how to handle very large arrays or matrices in vb6.0.  i get a memory error when using arrays that are of several thousand terms. (ie 3000x3000).  this is for math calculations for stiffness matrix of steel structures.
i have seen suggestions to use an array of arrays.  in other words each row of the matrix would have an array.  this seems to be a good idea, but i don't know how to create additional arrays at runtime since the actual size of the matrix is unknown at design time.
any ideas appreciated.
check out our whitepaper library.
either an array of arrays as suggested or if all else fails you can write the array to the hd... might slow things down a tad, thought... i haven't had to use that since early dos stuff.
i use delphi, and it's pretty easy to create an array of arrays, and i used to do it in vb4... before i migrated... shouldn't be too difficult in vb, though.
i would use fortran. i also wrote a routine in basic to do matrix inversion and othe functions. of course basic is almost extinct these days.
i have nor used vb, but with pascal and/or c, c++, there is a technique to generate somthing similar to dynamic memory or you can use linking list of pointer technique in c/c++ to generate new element in the matrix, this is just another way to manage element in order of the language.
i believe you can find this also in vb.
good luck.
if you matrix is symmetric (which it probably is) and if it has plenty of zeros, you might consider storing only one half (upper triangle for example) as a vector and ommit non-zero elements (skyline). there are solvers around for this approach, but they were mainly written in fortran. also, this might add a little to your execution time. if you decide to go for this option, it might be worth considering adding a routine to optimize element/node numbering.
if you are programming an fe program, using a frontal solver might help you to avoid large matrices problem since you do not need to forma a global stffness matrix- see hinton and owen finite element programming for example.
for a 3000 by 3000 matrix...  you are talking about  9 million array elements.  if you are using single precicion floating point math...  you'll need 36 mb of memory just to hold your data.  of course...  for a matrix of that size...  single precision math is likely going to blow up in your face.  you need double precision ( 8 byte ).  i'm not sure what that data type is called in vb.   so...  now you're talking about 72 mb just to hold your stiffness matrix values.  you'll then need more memory to solve your problem.  and... don't forget about memory to load your executable code and to run windows itself.   i'm not sure what limits vb is putting on your arrays.   look in your vb documentation.  it should be able to accept your values...  though you should probably be using some type of dynamically allocated arrays.
i'd recommend that you don't try to code an "array of arrays".   if vb won't let you do the array size you need, then... vb is not the language you should be using.  as others have already suggested...  it is highly likely that you don't actually need a matrix that large.   you really don't want to store and solve all elements of your matrix if the overwhelming majority of your elements are zero.   of course...  the techniques for solving these matrix equations is well beyond the scope of this forum.  frontal solvers are great!!!  however...  implementing them is anything but simple.  look for information on band and skyline and envelope storage and solver methods.
last...  but last...   if you do have to solve equations with so many terms...  i highly suggest you use something other than vb.   even if you can get vb to solve your equations...  you will be waiting forever plus some.   even for simple string manipulation algorithms ( where vb is supposed to be worthy ),  i've found that simple fortran code will run considerably faster.  for numerical computations... the timings will be incredibly different.  i personally recommend fortran.  of course...  c and c++ would be other common choices.
if you're using vb for it's gui capabilities...  that's fine.  write a vb front and back end with a fortran dll to do your actual number crunching.   of course... before you do any of these things...  i suggest you do a little research to see if you actually need to work with such large matrices.  ( hint:  if you are inverting your matrices... you are doing way too much work ).
dan   
thanks for the input from everyone.  the start of this little project is to create a parametric modeler to model smaller geometries in 2d.  this way i can model up to about 500 nodes even if no improvement is made to the solution algorithm.  however, this would be incredibly slow so i won't waste my time with simple inversion.
i agree with most of the comments above, especially regarding solving all 3000 equations.  i am only using the top half of the matrix, and plan to implement the skyline method and solve by cholesky factorization.  also, since it will be parametric, i can optimize the node order any way i like without much difficulty.  however, most of the skyline examples i have seen use lu factorization.
is cholesky ok or should i stick with lu?  everything seems to indicate that cholesky is fastest.
stick with cholesky.   it's stable and pretty easy to implement.  all you really need is the simple cholesky method ( which is essentially lu factorization ).   if you implement a skyline system...  you're code will probably run quite fast  ( i have several codes of my own implementing cholesky with skyline methods ).    a banded method is often acceptable also.  it's not quite as good as skyline, but....  it's easier and faster to code.
good luck,
dan
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|几何尺寸与公差论坛

GMT+8, 2025-1-18 09:40 , Processed in 0.036644 second(s), 20 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表