<html><body><div style="color:#000; background-color:#fff; font-family:HelveticaNeue, Helvetica Neue, Helvetica, Arial, Lucida Grande, sans-serif;font-size:10pt"><div style="" class=""><span style="" class="">I have 2 examples of how I was planning to call functions. 1 example is the function that just creates the mat. I changed the name to %mat instead of %cv-mat so it would match OpenCV's Mat class name better. The other example, add, I provide because it is an example of a function that would accept a mat as a parameter, I use add here as an example of all functions that would accept either my garbarge collected verion or my non garbage collected. <br style="" class=""><br style="" class="">I plan to provide both so, if you absolutely need to, you can get a speed increase. Also fnalizers seem to be twice as slow as manual memory management and 4 times slower than with-* macros, and I was advised by my tutor to include all 3 forms of MM. All of
the functions to create the %mat and %mat-expr type are written correctly for both. I was hoping you can give me a thumbs up on if the 2 examples are good, so I can go ahead and write all of my finalizers for all of my types. <br style="" class=""><br style="" class=""><br style="" class="">Example 1:<br style="" class=""><br style="" class="">;; Mat::Mat()<br style="" class="">;; Mat* cv_create_Mat()<br style="" class="">(defcfun ("cv_create_Mat" %mat) %mat<br style="" class=""> "MAT constructor")<br style="" class=""><br style="" class="">;; Mat::Mat()<br style="" class="">;; Mat* cv_create_Mat()<br style="" class="">(defcfun ("cv_create_Mat" %%mat) (%mat :garbage-collect t))<br style="" class=""><br style="" class=""><br style="" class="">(defun mat (&rest args)<br style="" class=""> (cond ((eq (first args) nil) (%mat))<br style="" class=""> ((eq :t (car args)) (%%mat))<br style="" class=""> (t
nil)))<br style="" class=""><br style="" class=""><br style="" class="">Example 2:<br style="" class=""><br style="" class="">;; MatExpr + operator<br style="" class="">;; MatExpr* cv_Mat_add(Mat* m1, Mat* m2)<br style="" class="">(defcfun ("cv_Mat_add" %add) (:pointer mat-expr)<br style="" class=""> (m1 %mat)<br style="" class=""> (m2 %mat))<br style="" class=""><br style="" class="">;; MatExpr + operator<br style="" class="">;; MatExpr* cv_Mat_add(Mat* m1, Mat* m2)<br style="" class="">(defcfun ("cv_Mat_add" %%add) (%mat-expr :garbage-collect t)<br style="" class=""> (m1 %mat)<br style="" class=""> (m2 %mat))<br style="" class=""><br style="" class=""><br style="" class=""><br style="" class="">(defun add (&rest args)<br style="" class=""> (cond ((eq :t (last args)) (%%add (first args) (second args)))<br style="" class=""> (t (%add (first args) (second
args)))))<br style="" class=""><br style="" class=""><br style="" class=""><br style="" class="">Btw you asked what my motivation for writing an OpenCV wrapper was and it's because of these 4 reasons:<br style="" class=""><br style="" class="">1. The libraries that exist are wrappers for the deprecated C OpenCV interface, mine is for the consistently updated C++ interface<br style="" class=""><br style="" class="">2: They are incomplete, mine is 3 times bigger or more than the two that exist now , and it aims to be complete within 3 months max<br style="" class=""><br style="" class="">3. Mine is aiming for inclusion in OpenCV proper, a generator is being built that will automatically generate all of my low-level functions/types/constants when OpenCV is built...so it will always be up to date<br style="" class=""><br style="" class="">4: I'm helping the C wrappers for the C++ interface that this library binds to so I will be at the forefront of
the knowledge needed to keep this library, supported and revolutionary as the first complete Lisp computer vision library<br style="" class=""><br style="" class=""><br style="" class=""><br style="" class=""><br style="" class=""></span></div><div style="display: block;" class="yahoo_quoted"> <div class="" style="font-family: HelveticaNeue, Helvetica Neue, Helvetica, Arial, Lucida Grande, sans-serif; font-size: 10pt"> <div class="" style="font-family: HelveticaNeue, Helvetica Neue, Helvetica, Arial, Lucida Grande, sans-serif; font-size: 12pt"> <div style="" class="" dir="ltr"> <font style="" class="" face="Arial" size="2"> On Saturday, April 26, 2014 5:55 AM, Joeish W <joeish80829@yahoo.com> wrote:<br style="" class=""> </font> </div> <blockquote class="" style=""> <div style="" class=""><div style="" class="" id="yiv3295478122"><div style="" class=""><div class="" style="color:#000;background-color:#fff;font-family:HelveticaNeue, Helvetica
Neue, Helvetica, Arial, Lucida Grande, sans-serif;font-size:10pt"><div style="" class="" id="yiv3295478122"><div style="" class=""><div class="" style="color:#000;background-color:#fff;font-family:HelveticaNeue, Helvetica Neue, Helvetica, Arial, Lucida Grande, sans-serif;font-size:10pt">Some new exciting information...I ran the create-mat function a million times and my memory went up a slight bit, I ran a million more and it went up a gain..I ran a million more and it actually leveled off. After running a million more times it actually started going down. I was able to see the Lisp GC at work...It doesn't seem to kick in until memory becomes an issue, again sir ...it was an honor<br style="" class="" clear="none"><div style="" class="" id="yiv3295478122yui_3_13_0_12_1398512961307_8"><span style="" class="" id="yiv3295478122yui_3_13_0_12_1398512961307_15"><br style="" class="" clear="none"></span></div><div style="" class=""
id="yiv3295478122yqt36003"><div style="" class="" id="yiv3295478122yqt74208"><div class="" id="yiv3295478122yui_3_13_0_12_1398512961307_10" style="display:block"> <div class="" style="font-family:HelveticaNeue, Helvetica Neue, Helvetica, Arial, Lucida Grande, sans-serif;font-size:10pt"> <div class="" style="font-family:HelveticaNeue, Helvetica Neue, Helvetica, Arial, Lucida Grande, sans-serif;font-size:12pt"> <div style="" class="" dir="ltr"> <font style="" class="" face="Arial" size="2"> On Saturday, April 26, 2014 4:24 AM, Willem Rein Oudshoorn <woudshoo@xs4all.nl> wrote:<br style="" class="" clear="none"> </font> </div> <blockquote class="" style=""> <div style="" class="">Joeish W <<a style="" class="" rel="nofollow" shape="rect" ymailto="mailto:joeish80829@yahoo.com" target="_blank" href="mailto:joeish80829@yahoo.com">joeish80829@yahoo.com</a>> writes:<br style="" class="" clear="none"><br style="" class="" clear="none"><br style=""
class="" clear="none">> (defcfun ("cv_create_Mat" create-mat) (%cv-mat :garbage-collect t))<br style="" class="" clear="none">><br style="" class="" clear="none">> a million times to bench mark it it was actually 4 times slower than<br style="" class="" clear="none">> my original code....I really do need this all to be fast code, since<br style="" class="" clear="none">> computer vision can benefit from the speed. Also I noticed when I<br style="" class="" clear="none">> ran the (create-mat) function 1,000,000
times my ram went up a tiny<br style="" class="" clear="none">> bit and didn't go down..Is that normal for finalizers.<br style="" class="" clear="none"><br style="" class="" clear="none">Well, that it is a bit slower is not really surprising because:<br style="" class="" clear="none"><br style="" class="" clear="none">1. CLOS classes are instantatied to wrap the pointer <br style="" class="" clear="none">2. The trivial garbage needs to keep track of the objects<br style="" class="" clear="none">3. The conversion code is done by generic functions.<br style="" class="" clear="none"><br style="" class="" clear="none">However, this is solvable. But I really would not focus on this right<br style="" class="" clear="none">now. I cannot really imagine that creating the matrix is the<br style="" class="" clear="none">bottleneck. <br style="" class="" clear="none"><br style="" class="" clear="none">With respect to the memory, as long as it
does not grow indefinitely I<br style="" class="" clear="none">would not worry about it. The trivial garbage package might introduce<br style="" class="" clear="none">some memory overhead which is not directly reclaimed by the garbage<br style="" class="" clear="none">collector. <br style="" class="" clear="none"><br style="" class="" clear="none"><br style="" class="" clear="none">> When I use<br style="" class="" clear="none">> with-* macros or manual MM I don't get an increase in ram on my<br style="" class="" clear="none">> system. I would like to include finalizers in my library but is there<br style="" class="" clear="none">> any way to
overcome these obstacles to make that happen...Again the<br style="" class="" clear="none">> time you took to help me on this is much appreciated. :)You really<br style="" class="" clear="none">> helped me to understand.<br style="" class="" clear="none"><br style="" class="" clear="none">Using `with-*` macros is a good idea. Inside these macros you can<br style="" class="" clear="none">do the manual garbage collection and avoid maybe the generic type<br style="" class="" clear="none">conversion. But to make it robust the `with-*` macros will not (I<br style="" class="" clear="none">expect) be faster than the code you have now. <br style="" class="" clear="none"><br style="" class="" clear="none">Making the code fast is certainly doable and not hard, but you should<br style="" class="" clear="none">first make it work and figure what needs to be fast and which<br style="" class="" clear="none">conveniences you are willing
to give up for the speed improvement.<br style="" class="" clear="none"><br style="" class="" clear="none">Wim Oudshoorn<br style="" class="" clear="none"><br style="" class="" clear="none"><br style="" class="" clear="none">_______________________________________________<br style="" class="" clear="none">Cffi-devel mailing list<br style="" class="" clear="none"><a style="" class="" rel="nofollow" shape="rect" ymailto="mailto:Cffi-devel@common-lisp.net" target="_blank" href="mailto:Cffi-devel@common-lisp.net">Cffi-devel@common-lisp.net</a><br style="" class="" clear="none"><a style="" class="" rel="nofollow" shape="rect" target="_blank" href="http://common-lisp.net/cgi-bin/mailman/listinfo/cffi-devel">http://common-lisp.net/cgi-bin/mailman/listinfo/cffi-devel</a><br style="" class="" clear="none"><br style="" class="" clear="none"><br style="" class="" clear="none"></div> </blockquote> </div> </div> </div></div></div>
</div></div></div></div></div></div><br style="" class=""><br style="" class=""></div> </blockquote> </div> </div> </div> </div></body></html>