This repository contains the GAP.jl Julia package, as well as the GAP packages
JuliaInterface
and JuliaExperimental
developed for the GAP-Julia integration
as part of the OSCAR project.
WARNING: GAP.jl is intended as a low-level interface between GAP and Julia. Therefore, for the most part it does not attempt (besides some general conveniences) to provide a very “Julia-ish” interface to GAP objects and functions, nor a “GAP-ish” interface to Julia objects and functions. Instead, this is left to higher-level code, for example in the Oscar.jl package.
To install this package in Julia, use
] add GAP
After entering the following in Julia,
using GAP
one may call any GAP function by prefixing its name with GAP.Globals.
. For example:
julia> GAP.Globals.SymmetricGroup(3)
GAP: SymmetricGroup( [ 1 .. 3 ] )
The Julia types Int64
and Bool
are automatically converted to GAP objects.
Several others basic types of objects can be converted using the GapObj
constructor:
julia> x = GapObj([1,2,3])
GAP: [ 1, 2, 3 ]
For nested objects, one can use the optional recursive
keyword argument:
julia> GapObj([1,2,[3,4,5]])
GAP: [ 1, 2, <Julia: [3, 4, 5]> ]
julia> GapObj([1,2,[3,4,5]]; recursive=true)
GAP: [ 1, 2, [ 3, 4, 5 ] ]
Converting back to Julia can be done using suitable Julia constructors. For example, to convert the GAP list of integers we defined earlier back to Julia, we might do this:
julia> Vector{Int64}(x)
3-element Array{Int64,1}:
1
2
3
Issues should be reported via our issue tracker.
Responsible for GAP.jl within the OSCAR project are Thomas Breuer and Max Horn.
All code in this repository is preliminary work.
It comes with absolutely no warranty and will most likely have errors. If you use it for computations, please check the correctness of the result very carefully.
Also, everything in this repository might change in the future, so currently any update can break the code you wrote upon functionality from packages in this repository.
This software is licensed under the LGPL, version 3, or any later version.
The development of this Julia package is supported by the Deutsche Forschungsgemeinschaft DFG within the Collaborative Research Center TRR 195.