A thin Julia wrapper around the C graphs library igraph
.
Most C types (like igraph_vector_int_t
) are directly available in IGraphs.LibIGraph
and also have Julian wrappers (like IGVectorInt
).
The Julian IGraph
wrapper of the C igraph_t
follows the Graphs.jl
interface.
The other wrapper types (see listed below) do not implement any convenience interfaces yet (e.g. IGVectorInt
does not provide any of the Vector
interface).
A (currently slow) convertor between Graphs.Graph
and IGraphs.IGraph
is available (simply by calling the constructors of one type on instances of the other type).
The raw bindings for igraph
are provided in IGraphs.LibIGraph
. E.g. the following C function
igraph_error_t igraph_get_eid(const igraph_t *graph, igraph_integer_t *eid,
igraph_integer_t from, igraph_integer_t to,
igraph_bool_t directed, igraph_bool_t error);
is available as the following Julia call
function igraph_get_eid(graph, eid, from, to, directed, error)
ccall((:igraph_get_eid, libigraph), igraph_error_t, (Ptr{igraph_t}, Ptr{igraph_integer_t}, igraph_integer_t, igraph_integer_t, igraph_bool_t, igraph_bool_t), graph, eid, from, to, directed, error)
end
For each C function igraph_functionname
there is a higher-level Julian functionname
(also in IGraphs.LibIGraph
), but modified as follows:
- errors are raised instead of just returned
- pointers to primitive types are hidden and the modified values of these primitive types are returned
- pointers to non-primitive C types are turned into Julian wrapper types
- the
igraph_
prefix is dropped from the function name
E.g. the C igraph_get_eid
from above becomes
function get_eid(graph, from, to, directed, error)
eid = fill(igraph_integer_t(0), ())
res = igraph_get_eid(graph.objref, pointer(eid), igraph_integer_t(from), igraph_integer_t(to), igraph_bool_t(directed), igraph_bool_t(error))
res == 0 || error("igraph's C library reports error ", res)
return (Int(eid[]),)
end
# how many functions exist in the C library that are now accessible through `LibIGraph.igraph_functionname`
julia> IGraphs.allbindings |> length
2057
# how many functions are wrapped in a more Julian call interface and accessible through `LibIGraph.functionname`
julia> IGraphs.translatedbindings |> length
1154
# the difference between those two numbers
julia> IGraphs.untranslatedbindings |> length
903
# the number of C types with Julian wrappers
julia> IGraphs.wrappedtypes |> length
18
# the mapping between a C type and the wrapper with a Julian API
julia> IGraphs.wrappedtypes
Dict{Expr, Symbol} with 18 entries:
:(Ptr{igraph_matrix_bool_t}) => :IGMatrixBool
:(Ptr{igraph_matrix_char_t}) => :IGMatrixChar
:(Ptr{igraph_vector_char_t}) => :IGVectorChar
:(Ptr{igraph_vector_int_list_t}) => :IGVectorIntList
:(Ptr{igraph_matrix_list_t}) => :IGMatrixFloatList
:(Ptr{igraph_vector_list_t}) => :IGVectorFloatList
:(Ptr{igraph_vector_complex_t}) => :IGVectorComplex
:(Ptr{igraph_adjlist_t}) => :IGAdjList
:(Ptr{igraph_matrix_complex_t}) => :IGMatrixComplex
:(Ptr{igraph_graph_list_t}) => :IGraphList
:(Ptr{igraph_bitset_list_t}) => :IGBitSetList
:(Ptr{igraph_t}) => :IGraph
:(Ptr{igraph_bitset_t}) => :IGBitSet
:(Ptr{igraph_matrix_int_t}) => :IGMatrixInt
:(Ptr{igraph_vector_t}) => :IGVectorFloat
:(Ptr{igraph_vector_int_t}) => :IGVectorInt
:(Ptr{igraph_vector_bool_t}) => :IGVectorBool
:(Ptr{igraph_matrix_t}) => :IGMatrixFloat