On Thu, Dec 1, 2011 at 4:48 PM, Mohammad Mirzadeh <span dir="ltr">&lt;<a href="mailto:mirzadeh@gmail.com">mirzadeh@gmail.com</a>&gt;</span> wrote:<br><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<div dir="ltr">Hi guys,<div><br></div><div>I am having a conceptual problem trying to design my vector wrappers for my application. The problem is some of vector functionality in PETSc require extra function calls which makes it hard to design a good wrapper. One example that I encountered was when trying to write the destructor for my vector object. You see, for example, the following code is not good enough</div>
</div></blockquote><div><br></div><div>1) We asked before, what could you possibly gain by writing a wrapper?</div><div><br></div><div>2) If you insist on doing this, register PetscFinalize() with atexit().</div><div><br>
</div><div>   Matt</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;"><div dir="ltr"><div>Vector::~Vector(){</div><div>VecDestroy(v_local);</div><div>}</div>
<div><br></div><div>This, in itself wont work since all calls to VecDestroy() should be made before PetscFinalize() and this wont happen if you define a Vector in your main function since the destructor is called upon exit ... So, I had to fix this by actually having a destructor function memer that I could call explicitly before PetscFinalize() or create the Vector object on the heap so that I can manually invoke the destructor via delete operator!</div>


<div><br></div><div>Another example I&#39;m struggling with is the following: I am trying to write accessors so that I can do the following:</div><div><br></div><div>Vector a (PETSC_COMM_WORLD, PETSC_DECIDE,10); // make a petsc vector of global length 10 using my own wrappers</div>


<div>for (int i=0; i&lt;a.GetLocalSize(); i++){</div><div>a(i) = i;</div><div>}</div><div><br></div><div>For this to work, I am using the VecGetArray() and VecRestoreArray() functions. The problem is you cannot easily use them inside the accessor which basically looks something like:</div>


<div><br></div><div>inline double&amp; Vector::operator()(int i){</div><div>return ptr_to_dataArray[i];</div><div>}</div><div><br></div><div>since you need to call to VecRestoreArray after the assignment which means after return!. The simple fix to this is to call the VecGetArray() and VecRestoreArray() in the main function where you are putting in the values but this does not look very neat to me ... so I ended up putting the VecGetArray() inside the constructor and VecRestoreArray() inside the destructor to automate the process. </div>


<div><br></div><div>Now I have the following two questions. 1) Is this safe? As far as I could understand from the manual, VecGetArray() &quot;returns&quot; a pointer to internal data stored on this processor. Then I guess VecRestoreArray() is there to somehow nullify the pointer to prevent accidental use of pointer? Since all pointers all private members of my class I assume this is safe then unless these two functions are actually doing some extra work?</div>


<div><br></div><div>2) Is there any better way of writing these wrappers and get around the problem of having to call &quot;supplemental&quot; functions safely?</div><div><br></div><div>Sorry if my lack of knowledge is causing all these confusion. </div>


<div><br></div><div>Thanks,</div><div>Mohammad</div><div><br></div><div><br></div></div>
</blockquote></div><br><br clear="all"><div><br></div>-- <br>What most experimenters take for granted before they begin their experiments is infinitely more interesting than any results to which their experiments lead.<br>
-- Norbert Wiener<br>