[Numpy-discussion] Compile extension modules with Visual Studio 2005

Geoffrey Zhu zyzhu2000@gmail....
Tue Jul 24 14:01:14 CDT 2007


Hi Robert,


On 7/24/07, Robert Kern <robert.kern@gmail.com> wrote:
> Geoffrey Zhu wrote:
> > Hi,
> >
> > I am about to write a C extension module. C functions in the module will
> > take and return numpy arrays. I found a tutorial online, but I am not
> > sure about the following:
> >
> > 1. Can I compile my extension with Visual Studio 2005? My impression is
> > that I will have to link with numpy libraries, and, if numpy was
> > compiled with a different compiler, I might have problems. However, if
> > numpy is a DLL, maybe there is a way that I can build a LIB file based
> > on the DLL and link with the LIB file. Does anyone have experience in
> > doing this?
>
> numpy isn't the issue. The main Windows Python distribution requires Visual
> Studio 2003 for building extensions. One can do it with mingw, though, with care.
>
> > 2. I am new to writing python extensions. The tutorial is doing things
> > by hand. Does anyone know what is the best way to do this? How about SWIG?
>
> There isn't a single best way. They all have tradeoffs. It might be easiest for
> you to actually just write your C functions into a DLL without referencing numpy
> or Python at all and call those functions using ctypes. That avoids needing a
> specific compiler and is a pretty handy tool to learn.
>
> If you do want to write an extension, I think I might suggest starting with
> writing one by hand. It helps with the other techniques to know what's going on
> underneath.
>
> --
> Robert Kern
>
> "I have come to believe that the whole world is an enigma, a harmless enigma
> that is made terrible by our own mad attempt to interpret it as though it had
> an underlying truth."
> -- Umberto Eco
> _______________________________________________
> Numpy-discussion mailing list
> Numpy-discussion@scipy.org
> http://projects.scipy.org/mailman/listinfo/numpy-discussion
>

Thanks for your help. Do you know what exactly is the issue of having
to use VS2003 to build extensions? If the interactions are done at DLL
level, shouldn't call compilers that can generate DLLs work?

It doesn't look like using ctypes would be an option, as my goal is to
'vectorize' some operations.

Thanks a lot,
Geoffrey


More information about the Numpy-discussion mailing list