<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Chuck,<div><br></div><div>Thank you for giving us that important conclusion, under a quite difficult situations.</div><div><br></div><div>I wonder if there is any distinction in the usage of vnl_matrix vs vnl_matrix_fixed. I would expect that operations done for pixel transforms should have there dimension know at run-time and should be able to use the vnl_matrix_fixed.</div><div><br></div><div>I also have considered methods to transform a whole array of points at a time. I wonder if for 3x3*3*256 sized operations ( scan-line size ) if there would be benefit with the library based operations.</div><div><br></div><div>Brad</div><div><br></div><div><br><div><div>On Mar 12, 2015, at 10:02 AM, Chuck Atkins <<a href="mailto:chuck.atkins@kitware.com">chuck.atkins@kitware.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><div dir="ltr">I worked with Julie Langou, maintainer of LAPACK, on this project a few years ago.  The funding situation ended up very strange and messy and we basically had to cram 3 months worth of effort into 3 weeks, so needless to say, we were not able to really achieve our goals.  However, we spent a fair amount of time profiling ITK and analyzing it's hot spots from vnl to determine where to best spend the small ammount of time we had.  The results were not as straight forward as we expected.  It turns out that most of the use for vnl_matrix and vnl_vector was actually for an enourmous number of operations on very small sized vectors and matricies (dimensions of 2, 3, or 4), often for coordinate and geometry calculations or for small per-pixel operations that were not easily vectorized in the implementation at the time.  In these cases, the overhead of calling out to a BLAS or LAPACK library was much too expensive and the existing use of VNL was far more optimal.  This falls apart, however when trying to use vnl for more complex algorithms since the larger matrix operations will be where the benefit can be seen.  So just re-implementing the vnl vector and matrix classes and operators with underlying BLAS and LAPACK routines turned out to not be the best solution for ITK as a whole.<br><div><div class="gmail_extra"><br clear="all"><div><div class="gmail_signature"><div dir="ltr">- Chuck<br></div></div></div>
<br><div class="gmail_quote">On Thu, Mar 12, 2015 at 8:32 AM, Bradley Lowekamp <span dir="ltr"><<a href="mailto:blowekamp@mail.nih.gov" target="_blank">blowekamp@mail.nih.gov</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hello,<br>
<br>
If I was writing my own ITK classes, and needed a fast matrix library I would likely pursue an additional dependency on an efficient numeric library for that project, such as eigen.<br>
<br>
However for the broad appeal of ITK I would think a flexible back end would be best. As I think there are a variety of BLAS and LAPACK libraries available ( commercial, open source, vender free ). It would be nice to pick one what has been optimized for the current architecture. I would think it would be most flexible to use this interface in the back end of a chosen numeric interface ( currently VNL ). Unfortunately, I don't have as much experience with these libraries as I'd like.<br>
<br>
Brad<br>
<div class="HOEnZb"><div class="h5"><br>
On Mar 12, 2015, at 5:15 AM, <a href="mailto:m.staring@lumc.nl">m.staring@lumc.nl</a> wrote:<br>
<br>
> Hi,<br>
><br>
> I think the eigen library is a mature and very fast library for these kind of things:<br>
> <a href="http://eigen.tuxfamily.org/index.php?title=Main_Page" target="_blank">http://eigen.tuxfamily.org/index.php?title=Main_Page</a><br>
><br>
> You may want to check it out, to see if it offers what you need.<br>
><br>
> It would be great to be able to use these within the itk.<br>
><br>
> 2c<br>
> Marius<br>
><br>
> -----Original Message-----<br>
> From: Insight-developers [mailto:<a href="mailto:insight-developers-bounces@itk.org">insight-developers-bounces@itk.org</a>] On Behalf Of Jian Cheng<br>
> Sent: Wednesday, March 11, 2015 23:17<br>
> To: Matt McCormick<br>
> Cc: Chuck Atkins; ITK<br>
> Subject: Re: [ITK-dev] efficiency of vnl_matrix<br>
><br>
> Hi Matt,<br>
><br>
> Thanks for your help, and also for the ITK workshop in UNC last time.<br>
><br>
> It is very unfortunate. The efficiency of these numerical math operators are very important for many applications.<br>
><br>
> I recently released an ITK based toolbox, called dmritool, for diffusion MRI data processing.<br>
> It has some files to add some supports of blas, lapack, mkl to vnl_matrix and vnl_vector.<br>
> <a href="http://diffusionmritool.github.io/dmritool_doxygen/utlBlas_8h_source.html" target="_blank">http://diffusionmritool.github.io/dmritool_doxygen/utlBlas_8h_source.html</a><br>
> <a href="http://diffusionmritool.github.io/dmritool_doxygen/utlVNLBlas_8h_source.html" target="_blank">http://diffusionmritool.github.io/dmritool_doxygen/utlVNLBlas_8h_source.html</a><br>
><br>
> Those functions are not internally for vnl_matrix class. They are operators for the data pointer stored in vnl_matrix object.<br>
> Thus, later I made a N-dimensional array library which internally includes those functions, and also supports expression template to avoid temporary copies.<br>
> <a href="http://diffusionmritool.github.io/dmritool_doxygen/utlMatrix_8h_source.html" target="_blank">http://diffusionmritool.github.io/dmritool_doxygen/utlMatrix_8h_source.html</a><br>
> <a href="http://diffusionmritool.github.io/dmritool_doxygen/utlVector_8h_source.html" target="_blank">http://diffusionmritool.github.io/dmritool_doxygen/utlVector_8h_source.html</a><br>
><br>
> The efficiency comparison between vnl_vector/vnl_matrix and the vector/matrix using openblas, lapack, or mkl can be found by running those two tests <a href="https://github.com/DiffusionMRITool/dmritool/blob/master/Modules/HelperFunctions/test/utlVNLBlasGTest.cxx" target="_blank">https://github.com/DiffusionMRITool/dmritool/blob/master/Modules/HelperFunctions/test/utlVNLBlasGTest.cxx</a><br>
> <a href="https://github.com/DiffusionMRITool/dmritool/blob/master/Modules/HelperFunctions/test/utlVNLLapackGTest.cxx" target="_blank">https://github.com/DiffusionMRITool/dmritool/blob/master/Modules/HelperFunctions/test/utlVNLLapackGTest.cxx</a><br>
><br>
> Maybe some codes can be used as patches in somewhere in ITK. I am not sure. Maybe we need more discussion on it.<br>
> With your help and discussion, I will be very glad to make my first patch to ITK.<br>
> Thanks.<br>
><br>
> best,<br>
> Jian Cheng<br>
><br>
><br>
> On 03/11/2015 04:39 PM, Matt McCormick wrote:<br>
>> Hi Jian,<br>
>><br>
>> Yes, it would be wonderful to improve the efficiency of these basic<br>
>> numerical operations.<br>
>><br>
>> Funding for the Refactor Numerical Libraries has currently ended, and<br>
>> the effort is currently frozen.  However, you are more than welcome to<br>
>> pick it up and we can help you get it into ITK.  More information on<br>
>> the patch submission process can be found here [1] and in the ITK<br>
>> Software Guide.<br>
>><br>
>> Thanks,<br>
>> Matt<br>
>><br>
>> [1]<br>
>> <a href="https://insightsoftwareconsortium.github.io/ITKBarCamp-doc/CommunitySo" target="_blank">https://insightsoftwareconsortium.github.io/ITKBarCamp-doc/CommunitySo</a><br>
>> ftwareProcess/SubmitAPatchToGerrit/index.html<br>
>><br>
>> On Wed, Mar 11, 2015 at 4:07 PM, Jian Cheng <<a href="mailto:jian.cheng.1983@gmail.com">jian.cheng.1983@gmail.com</a>> wrote:<br>
>>> Hi,<br>
>>><br>
>>> My task using ITK has intensive matrix-matrix product, pseudo-inverse, etc.<br>
>>> Thus the performance is actually mainly determined by the matrix<br>
>>> library I used.<br>
>>> Firstly I use vnl_matrix and vnl_vector in ITK. Then I found it is<br>
>>> very inefficient because vnl matrix lib does not use blas and lapack.<br>
>>> After I wrote my own matrix class which uses openblas and lapack, I<br>
>>> got a hug gain of performance.<br>
>>><br>
>>> I found there is a proposal to improve the efficiency of numerical<br>
>>> libraries in ITK.<br>
>>> <a href="http://www.itk.org/Wiki/ITK/Release_4/Refactor_Numerical_Libraries" target="_blank">http://www.itk.org/Wiki/ITK/Release_4/Refactor_Numerical_Libraries</a><br>
>>> I am not sure how is the progress of the proposal.<br>
>>> I wonder when the vnl matrix lib can internally support blas and<br>
>>> lapack, or mkl, so that we can just use it without lose of the efficiency.<br>
>>> Thanks.<br>
>>><br>
>>> best,<br>
>>> Jian Cheng<br>
>>> _______________________________________________<br>
>>> Powered by <a href="http://www.kitware.com/" target="_blank">www.kitware.com</a><br>
>>><br>
>>> Visit other Kitware open-source projects at<br>
>>> <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
>>><br>
>>> Kitware offers ITK Training Courses, for more information visit:<br>
>>> <a href="http://kitware.com/products/protraining.php" target="_blank">http://kitware.com/products/protraining.php</a><br>
>>><br>
>>> Please keep messages on-topic and check the ITK FAQ at:<br>
>>> <a href="http://www.itk.org/Wiki/ITK_FAQ" target="_blank">http://www.itk.org/Wiki/ITK_FAQ</a><br>
>>><br>
>>> Follow this link to subscribe/unsubscribe:<br>
>>> <a href="http://public.kitware.com/mailman/listinfo/insight-developers" target="_blank">http://public.kitware.com/mailman/listinfo/insight-developers</a><br>
><br>
> _______________________________________________<br>
> Powered by <a href="http://www.kitware.com/" target="_blank">www.kitware.com</a><br>
><br>
> Visit other Kitware open-source projects at <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
><br>
> Kitware offers ITK Training Courses, for more information visit:<br>
> <a href="http://kitware.com/products/protraining.php" target="_blank">http://kitware.com/products/protraining.php</a><br>
><br>
> Please keep messages on-topic and check the ITK FAQ at:<br>
> <a href="http://www.itk.org/Wiki/ITK_FAQ" target="_blank">http://www.itk.org/Wiki/ITK_FAQ</a><br>
><br>
> Follow this link to subscribe/unsubscribe:<br>
> <a href="http://public.kitware.com/mailman/listinfo/insight-developers" target="_blank">http://public.kitware.com/mailman/listinfo/insight-developers</a><br>
> _______________________________________________<br>
> Powered by <a href="http://www.kitware.com/" target="_blank">www.kitware.com</a><br>
><br>
> Visit other Kitware open-source projects at<br>
> <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
><br>
> Kitware offers ITK Training Courses, for more information visit:<br>
> <a href="http://kitware.com/products/protraining.php" target="_blank">http://kitware.com/products/protraining.php</a><br>
><br>
> Please keep messages on-topic and check the ITK FAQ at:<br>
> <a href="http://www.itk.org/Wiki/ITK_FAQ" target="_blank">http://www.itk.org/Wiki/ITK_FAQ</a><br>
><br>
> Follow this link to subscribe/unsubscribe:<br>
> <a href="http://public.kitware.com/mailman/listinfo/insight-developers" target="_blank">http://public.kitware.com/mailman/listinfo/insight-developers</a><br>
<br>
</div></div></blockquote></div><br></div></div></div>
</blockquote></div><br></div></body></html>