Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Julia bindings #1025

Open
wants to merge 111 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
111 commits
Select commit Hold shift + click to select a range
8de441a
Partial Julia bindings
eschnett Jun 27, 2021
b657d95
Julia: Wrap store_chunk
eschnett Jun 27, 2021
2de8c93
Move Julia package to a separate repository
eschnett Jun 28, 2021
eee0d35
Require C++17 for Julia wrappers
eschnett Jun 28, 2021
4d71540
Julia: Only require C++14
eschnett Jun 28, 2021
0e6ec91
Julia: Switch back to C++17
eschnett Jun 28, 2021
48d6024
Disable std::variant on Apple with clang
eschnett Jun 28, 2021
2865845
cmake: Only look for C++ MPI
eschnett Jun 28, 2021
9c81660
Install Julia bindings
eschnett Jun 29, 2021
d33895e
Rename to WriteIterations::getindex
eschnett Jul 3, 2021
492912d
Rename to MeshRecordComponent1
eschnett Jul 4, 2021
5ab016c
Simplify function names
eschnett Jul 4, 2021
34f11ab
Use separate function names for templates
eschnett Jul 5, 2021
d679474
New API for loadChunk
eschnett Jul 7, 2021
828222b
Split files to reduce build time
eschnett Jul 7, 2021
4697250
Merge branch 'dev' into eschnett/julia-bindings
eschnett Jul 7, 2021
bc3d5f9
Disable ReadIterations
eschnett Jul 7, 2021
2492182
Define chunk function wrappers
eschnett Jul 7, 2021
8d444e8
Add functions to create shared_ptrs
eschnett Jul 7, 2021
29cd7ff
Use `cxx_` prefix instead of `1` suffix
eschnett Jul 7, 2021
d4d0db7
Rename Container to CXX_Container; remove unused code
eschnett Jul 8, 2021
b41d41e
Correct wrapping names
eschnett Jul 8, 2021
b1801e1
Wrap availableChunks
eschnett Jul 8, 2021
e7861d6
Merge branch 'dev' into eschnett/julia-bindings
eschnett Jul 8, 2021
91b07e7
Correct error in wrapping WrittenChunkInfo
eschnett Jul 8, 2021
5839134
Correct template parameter type
eschnett Jul 8, 2021
933f01a
Merge branch 'dev' into eschnett/julia-bindings
eschnett Jul 30, 2021
1f6559b
Julia: Rename SeriesImpl -> SeriesInterface
eschnett Jul 30, 2021
d7ebecb
Merge branch 'dev' into eschnett/julia-bindings
eschnett Aug 7, 2021
0df99cc
Merge branch 'dev' into eschnett/julia-bindings
eschnett Aug 20, 2021
e315fe8
Disable Julia bindings by default
eschnett Aug 20, 2021
895e060
Clean up macro FORALL_OPENPMD_TYPES
eschnett Aug 20, 2021
1fe64f1
Avoid compiler warnings
eschnett Aug 20, 2021
46a7b00
Experiment with templates for iterating over types
eschnett Aug 20, 2021
bcf29cc
Simplify cmake statements for Julia
eschnett Sep 17, 2021
a9955b3
Correct Julia bindings for MPI_Comm
eschnett Sep 17, 2021
b0c1fd0
Rename Julia library to openPMD.jl
eschnett Sep 17, 2021
2f26607
Merge branch 'dev' of https://github.com/openPMD/openPMD-api into esc…
eschnett Sep 17, 2021
5c192e3
Remove Julia wrapper for "DATATYPE"
eschnett Sep 17, 2021
5c4d14f
Remove "AUTO" logic for Julia
eschnett Sep 17, 2021
7c663d8
CI: Build Julia bindings on macOS
eschnett Sep 17, 2021
d42b4d6
CI: Install Julia via homebrew
eschnett Sep 17, 2021
cbb0da4
CI: Correct cmake options for installing libcxxwrap-julia
eschnett Sep 18, 2021
a288938
CI: Require macOS 10.12+ for Julia bindings
eschnett Sep 18, 2021
dd9aff6
CI: Build Julia bindings on gcc9_py38_pd_nompi_h5_ad1_ad2_libcpp
eschnett Sep 18, 2021
19af703
Add `close` function to Series object
eschnett Oct 13, 2021
ffac9cf
Merge branch 'dev' of https://github.com/openPMD/openPMD-api into esc…
eschnett Oct 13, 2021
f32b68b
[julia] Wrap Series::closeee
eschnett Oct 13, 2021
3d23f12
Julia interface: Clean up handling std::array<double, 7>
eschnett Dec 17, 2021
88d734a
Merge branch 'dev' of https://github.com/openPMD/openPMD-api into esc…
eschnett Dec 30, 2021
7daa833
Resolve merge errors
eschnett Dec 31, 2021
218b67e
Update Julia interface
eschnett Dec 31, 2021
1e9e69c
CI: Update to Julia 1.6.5; correct yaml syntax
eschnett Dec 31, 2021
de3d451
CI: Use newer version of libcxxwrap-julia
eschnett Dec 31, 2021
896daeb
CI: Correct Julia/libcxxwrap download commands
eschnett Dec 31, 2021
1228708
Avoid unused-parameter warning
eschnett Dec 31, 2021
d146f5f
Avoid compiler warnings
eschnett Dec 31, 2021
d7eefb9
Add missing include header
eschnett Dec 31, 2021
d3c042b
Correct pointer casts
eschnett Jan 1, 2022
3c9f215
Remove outdated function from Julia bindings
eschnett Jan 2, 2022
32f4fe6
[Julia] Use memcpy to handle MPI_Comm
eschnett Jan 2, 2022
b9c0bc4
Merge remote-tracking branch 'mainline/dev' into eschnett/julia-bindings
ax3l Jan 25, 2022
9edac3b
CI: Simply with cmake-easyinstall
ax3l Jan 25, 2022
a6a4d55
Merge branch 'dev' into eschnett/julia-bindings
eschnett Mar 8, 2022
3f1a23d
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Mar 8, 2022
84bce33
Set CMAKE_OSX_DEPLOYMENT_TARGET to 10.14
eschnett Mar 8, 2022
e6a18e7
Merge branch 'dev' into eschnett/julia-bindings
eschnett Nov 11, 2022
46d19af
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Nov 11, 2022
479b3d7
Julia: Update ADIOS2 format enum constants
eschnett Nov 11, 2022
20cdbe7
Julia: Wrap call to seriesFlush in lambda to resolve overload
eschnett Nov 11, 2022
e31818f
Simplify CMakeLists.txt
eschnett May 19, 2023
9c97be2
Merge branch 'dev' into eschnett/julia-bindings
eschnett May 19, 2023
61fe000
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 19, 2023
c11fcd0
CI: Correct yaml syntax
eschnett May 19, 2023
e602993
CI: Require newer macOS when installing dependencies
eschnett May 19, 2023
e364217
CI: Require newer libcxxwrap on macOS
eschnett May 19, 2023
7424187
CI: Require macOS 10.15 for Julia bindings
eschnett May 19, 2023
4be71b1
CI: Install `dot` executable when building documentation
eschnett May 19, 2023
655febb
Document install with Julia
eschnett May 19, 2023
13ea8b4
CI: Rename workflow
eschnett May 19, 2023
130c167
Replace FORALL_OPENPMD_TYPES -> forallJuliaTypes
franzpoeschel Jun 5, 2023
769adbc
Replace typedef -> using
franzpoeschel Jun 5, 2023
b381ad8
Use overload_cast
franzpoeschel Jun 5, 2023
c6f63a1
Rename USE_Julia to USE_JULIA
eschnett Aug 1, 2023
f7e4424
Add copyright comments to Julia bindings
eschnett Aug 1, 2023
21cecd4
CI: Update USE_JULIA config option
eschnett Aug 1, 2023
8dc4076
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Aug 1, 2023
db180de
Merge pull request #2 from franzpoeschel/julia-bindings-review
eschnett Aug 2, 2023
8fb74b9
Add minimal Julia example
eschnett Aug 2, 2023
ddf4fbc
CI: Run Julia self-tests
eschnett Aug 2, 2023
2ee34a0
CI: Install CxxWrap for Julia tests
eschnett Aug 2, 2023
a17a10d
CI: Install CxxWrap for Julia tests
eschnett Aug 2, 2023
5229a57
CI: Switch to Julia 1.7
eschnett Aug 3, 2023
100a586
Merge branch 'dev' into julia-bindings-current-dev
franzpoeschel Aug 10, 2023
3b1b37c
Set openPMD.jl library target properties
franzpoeschel Aug 10, 2023
1918464
Add low-level Julia test
franzpoeschel Aug 10, 2023
c6fe874
Install CxxWrap Julia package and fix CI run
franzpoeschel Aug 11, 2023
d548c90
Install CxxWrap Julia package and fix CI run
franzpoeschel Aug 11, 2023
d427b19
Update RPATH setting to generalized method
franzpoeschel Aug 18, 2023
184610f
Merge branch 'eschnett/julia-bindings' of ssh://github.com/eschnett/o…
eschnett Aug 18, 2023
d59773a
Don't export openPMD_datatypes to Julia
eschnett Sep 5, 2023
724806e
Merge branch 'dev' into eschnett/julia-bindings
eschnett Sep 5, 2023
54a5052
Don't export openPMD_datatypes to Julia
eschnett Sep 5, 2023
fa2efa5
Configure Julia include and library directories
eschnett Sep 5, 2023
5d5612d
Configure Julia include and library directories
eschnett Sep 5, 2023
9eaec53
Don't configure Julia include and library directories
eschnett Sep 6, 2023
cac9488
Julia: Correct `set_const` definitions for `Datatype` enum
eschnett Sep 7, 2023
5213e2e
CI: Correct shared library suffix for Apple
eschnett Sep 8, 2023
805756f
Julia: Correct low-level test
eschnett Sep 9, 2023
a0b015e
CI: Install libcxxwrap-julia @v0.11.0
eschnett Sep 9, 2023
26b6ca7
Merge branch 'dev' into eschnett/julia-bindings
eschnett Oct 13, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Julia interface: Clean up handling std::array<double, 7>
  • Loading branch information
eschnett committed Dec 17, 2021
commit 3d23f12061650dccf4cb0e5e42f902f56945c71e
2 changes: 1 addition & 1 deletion src/binding/julia/Mesh.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ void define_julia_Mesh(jlcxx::Module &mod) {
type.method("cxx_set_grid_unit_SI!", &Mesh::setGridUnitSI);
type.method(
"cxx_set_unit_dimension!",
[](Mesh &mesh, const array7<double> &unitDimension) {
[](Mesh &mesh, const array_double_7 &unitDimension) {
return mesh.setUnitDimension(std::map<UnitDimension, double>{
{UnitDimension::L, unitDimension[uint8_t(UnitDimension::L)]},
{UnitDimension::M, unitDimension[uint8_t(UnitDimension::M)]},
Expand Down
8 changes: 8 additions & 0 deletions src/binding/julia/Series.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,14 @@

#include "defs.hpp"

#if openPMD_HAVE_MPI
#include <mpi.h>

namespace jlcxx {
template <> struct IsMirroredType<MPI_Comm> : std::false_type {};
} // namespace jlcxx
#endif

// Define supertype relationships
namespace jlcxx {
template <> struct SuperType<SeriesInterface> { typedef Attributable type; };
Expand Down
91 changes: 49 additions & 42 deletions src/binding/julia/defs.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ template <> struct sized_uint<4> { using type = std::uint32_t; };
template <> struct sized_uint<8> { using type = std::uint64_t; };
template <std::size_t I> using sized_uint_t = typename sized_uint<I>::type;

template <typename T> using array7 = std::array<T, 7>;
using array_double_7 = std::array<double, 7>;

/*
* Generate code fo all openPMD types. Use is e.g. as follows:
Expand Down Expand Up @@ -82,7 +82,7 @@ template <typename T> using array7 = std::array<T, 7>;
/* MACRO("VEC_CLONG_DOUBLE", Datatype::VEC_CLONG_DOUBLE, \
* std::vector<std::complex<long double>>) */ \
MACRO("VEC_STRING", Datatype::VEC_STRING, std::vector<std::string>) \
MACRO("ARR_DBL_7", Datatype::ARR_DBL_7, array7<double>) \
MACRO("ARR_DBL_7", Datatype::ARR_DBL_7, array_double_7) \
MACRO("BOOL", Datatype::BOOL, bool)

#define FORALL_SCALAR_OPENPMD_TYPES(MACRO) \
Expand All @@ -104,72 +104,79 @@ template <typename T> using array7 = std::array<T, 7>;
/* MACRO("CLONG_DOUBLE", Datatype::CLONG_DOUBLE, std::complex<long \
* double>) */ \
MACRO("STRING", Datatype::STRING, std::string) \
MACRO("ARR_DBL_7", Datatype::ARR_DBL_7, array7<double>) \
MACRO("ARR_DBL_7", Datatype::ARR_DBL_7, array_double_7) \
MACRO("BOOL", Datatype::BOOL, bool)

// This C++ version is a bit more tedious to use than the macro version above
template <typename T> T typeval() { return T{}; }
template <typename F, typename... Args>
void forall_openPMD_types(const F &f, Args &&...args) {
f("CHAR", Datatype::CHAR, char{}, std::forward<Args>(args)...);
f("UCHAR", Datatype::UCHAR, (unsigned char){}, std::forward<Args>(args)...);
f("SHORT", Datatype::SHORT, short{}, std::forward<Args>(args)...);
f("INT", Datatype::INT, int{}, std::forward<Args>(args)...);
f("LONG", Datatype::LONG, long{}, std::forward<Args>(args)...);
f("LONGLONG", Datatype::LONGLONG, (long long){}, std::forward<Args>(args)...);
f("USHORT", Datatype::USHORT, (unsigned short){},
f("CHAR", Datatype::CHAR, typeval<char>(), std::forward<Args>(args)...);
f("UCHAR", Datatype::UCHAR, typeval<unsigned char>(),
std::forward<Args>(args)...);
f("UINT", Datatype::UINT, (unsigned int){}, std::forward<Args>(args)...);
f("ULONG", Datatype::ULONG, (unsigned long){}, std::forward<Args>(args)...);
f("ULONGLONG", Datatype::ULONGLONG, (unsigned long long){},
f("SHORT", Datatype::SHORT, typeval<short>(), std::forward<Args>(args)...);
f("INT", Datatype::INT, typeval<int>(), std::forward<Args>(args)...);
f("LONG", Datatype::LONG, typeval<long>(), std::forward<Args>(args)...);
f("LONGLONG", Datatype::LONGLONG, typeval<long long>(),
std::forward<Args>(args)...);
f("FLOAT", Datatype::FLOAT, float{}, std::forward<Args>(args)...);
f("DOUBLE", Datatype::DOUBLE, double{}, std::forward<Args>(args)...);
// f("LONG_DOUBLE", Datatype::LONG_DOUBLE, (long double){},
// std::forward<Args>(args)...);
f("CFLOAT", Datatype::CFLOAT, std::complex<float>{},
f("USHORT", Datatype::USHORT, typeval<unsigned short>(),
std::forward<Args>(args)...);
f("UINT", Datatype::UINT, typeval<unsigned int>(),
std::forward<Args>(args)...);
f("ULONG", Datatype::ULONG, typeval<unsigned long>(),
std::forward<Args>(args)...);
f("CDOUBLE", Datatype::CDOUBLE, std::complex<double>{},
f("ULONGLONG", Datatype::ULONGLONG, typeval<unsigned long long>(),
std::forward<Args>(args)...);
// f("CLONG_DOUBLE", Datatype::CLONG_DOUBLE, std::complex<long double>{},
f("FLOAT", Datatype::FLOAT, typeval<float>(), std::forward<Args>(args)...);
f("DOUBLE", Datatype::DOUBLE, typeval<double>(), std::forward<Args>(args)...);
// f("LONG_DOUBLE", Datatype::LONG_DOUBLE, typeval<long double>(),
// std::forward<Args>(args)...);
f("STRING", Datatype::STRING, std::string{}, std::forward<Args>(args)...);
f("VEC_CHAR", Datatype::VEC_CHAR, std::vector<char>{},
f("CFLOAT", Datatype::CFLOAT, typeval<std::complex<float>>(),
std::forward<Args>(args)...);
f("VEC_UCHAR", Datatype::VEC_UCHAR, std::vector<unsigned char>{},
f("CDOUBLE", Datatype::CDOUBLE, typeval<std::complex<double>>(),
std::forward<Args>(args)...);
f("VEC_SHORT", Datatype::VEC_SHORT, std::vector<short>{},
// f("CLONG_DOUBLE", Datatype::CLONG_DOUBLE, typeval<std::complex<long
// double>>(), std::forward<Args>(args)...);
f("STRING", Datatype::STRING, typeval<std::string>(),
std::forward<Args>(args)...);
f("VEC_INT", Datatype::VEC_INT, std::vector<int>{},
f("VEC_CHAR", Datatype::VEC_CHAR, typeval<std::vector<char>>(),
std::forward<Args>(args)...);
f("VEC_LONG", Datatype::VEC_LONG, std::vector<long>{},
f("VEC_UCHAR", Datatype::VEC_UCHAR, typeval<std::vector<unsigned char>>(),
std::forward<Args>(args)...);
f("VEC_LONGLONG", Datatype::VEC_LONGLONG, std::vector<long long>{},
f("VEC_SHORT", Datatype::VEC_SHORT, typeval<std::vector<short>>(),
std::forward<Args>(args)...);
f("VEC_USHORT", Datatype::VEC_USHORT, std::vector<unsigned short>{},
f("VEC_INT", Datatype::VEC_INT, typeval<std::vector<int>>(),
std::forward<Args>(args)...);
f("VEC_UINT", Datatype::VEC_UINT, std::vector<unsigned int>{},
f("VEC_LONG", Datatype::VEC_LONG, typeval<std::vector<long>>(),
std::forward<Args>(args)...);
f("VEC_ULONG", Datatype::VEC_ULONG, std::vector<unsigned long>{},
f("VEC_LONGLONG", Datatype::VEC_LONGLONG, typeval<std::vector<long long>>(),
std::forward<Args>(args)...);
f("VEC_ULONGLONG", Datatype::VEC_ULONGLONG, std::vector<unsigned long long>{},
f("VEC_USHORT", Datatype::VEC_USHORT, typeval<std::vector<unsigned short>>(),
std::forward<Args>(args)...);
f("VEC_FLOAT", Datatype::VEC_FLOAT, std::vector<float>{},
f("VEC_UINT", Datatype::VEC_UINT, typeval<std::vector<unsigned int>>(),
std::forward<Args>(args)...);
f("VEC_DOUBLE", Datatype::VEC_DOUBLE, std::vector<double>{},
f("VEC_ULONG", Datatype::VEC_ULONG, typeval<std::vector<unsigned long>>(),
std::forward<Args>(args)...);
// f("VEC_LONG_DOUBLE", Datatype::VEC_LONG_DOUBLE, std::vector<long double>{},
// std::forward<Args>(args)...);
f("VEC_CFLOAT", Datatype::VEC_CFLOAT, std::vector<std::complex<float>>{},
f("VEC_ULONGLONG", Datatype::VEC_ULONGLONG,
typeval<std::vector<unsigned long long>>(), std::forward<Args>(args)...);
f("VEC_FLOAT", Datatype::VEC_FLOAT, typeval<std::vector<float>>(),
std::forward<Args>(args)...);
f("VEC_CDOUBLE", Datatype::VEC_CDOUBLE, std::vector<std::complex<double>>{},
f("VEC_DOUBLE", Datatype::VEC_DOUBLE, typeval<std::vector<double>>(),
std::forward<Args>(args)...);
// f("VEC_LONG_DOUBLE", Datatype::VEC_LONG_DOUBLE, typeval<std::vector<long
// double>>(), std::forward<Args>(args)...);
f("VEC_CFLOAT", Datatype::VEC_CFLOAT,
typeval<std::vector<std::complex<float>>>(), std::forward<Args>(args)...);
f("VEC_CDOUBLE", Datatype::VEC_CDOUBLE,
typeval<std::vector<std::complex<double>>>(), std::forward<Args>(args)...);
// f("VEC_CLONG_DOUBLE", Datatype::VEC_CLONG_DOUBLE,
// std::vector<std::complex<long double>>{}, std::forward<Args>(args)...);
f("VEC_STRING", Datatype::VEC_STRING, std::vector<std::string>{},
// typeval<std::vector<std::complex<long double>>>(),
// std::forward<Args>(args)...);
f("VEC_STRING", Datatype::VEC_STRING, typeval<std::vector<std::string>>(),
std::forward<Args>(args)...);
f("ARR_DBL_7", Datatype::ARR_DBL_7, array7<double>{},
f("ARR_DBL_7", Datatype::ARR_DBL_7, typeval<array_double_7>(),
std::forward<Args>(args)...);
f("BOOL", Datatype::BOOL, bool{}, std::forward<Args>(args)...);
f("BOOL", Datatype::BOOL, typeval<bool>(), std::forward<Args>(args)...);
}

namespace {
Expand Down Expand Up @@ -261,7 +268,7 @@ void add_pair_type(jlcxx::Module &mod, const std::string &name) {
} // namespace

namespace jlcxx {
template <> struct IsMirroredType<std::array<double, 7>> : std::false_type {};
template <> struct IsMirroredType<array_double_7> : std::false_type {};
} // namespace jlcxx

// We use one function per header file
Expand Down