Skip to content

Commit

Permalink
Merge pull request #204 from mfem/uint_array_dev3
Browse files Browse the repository at this point in the history
Array<T> clean up
  • Loading branch information
sshiraiwa authored Jan 9, 2024
2 parents 47892af + 896d38b commit ce1ba0b
Show file tree
Hide file tree
Showing 6 changed files with 316 additions and 101 deletions.
14 changes: 7 additions & 7 deletions .github/workflows/test_with_MFEM_master.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,8 @@ jobs:
strategy:
fail-fast: false
matrix:
#python-version: ["3.7", "3.8", "3.9", "3.10"]
python-version: ["3.10"]
python-version: ["3.7", "3.8", "3.9", "3.10"]
#python-version: ["3.10"]
os: [ubuntu-20.04]
# USE_FLAGS : cuda, parallel, libceed
env:
Expand All @@ -28,7 +28,7 @@ jobs:

include:
- os: macos-latest
python-version: 3.11
python-version: 3.9
env: {USE_FLAGS: "000"}
# - os: [ubuntu-20.04]
# python-version: 3.9
Expand Down Expand Up @@ -63,11 +63,11 @@ jobs:
pip install six numpy --verbose
if [ "${{matrix.python-version}}" = "3.10" ] ; then
#pip install numba numba-scipy --verbose
pip install scipy numba --verbose
pip install numba numba-scipy --verbose
#pip install scipy numba --verbose
else
#pip install numba numba-scipy --verbose
pip install numba scipy --verbose
pip install numba numba-scipy --verbose
#pip install numba scipy --verbose
fi
if [ -f requirements.txt ]; then
Expand Down
35 changes: 34 additions & 1 deletion mfem/_par/array.i
Original file line number Diff line number Diff line change
Expand Up @@ -134,10 +134,43 @@ namespace mfem{
%template(doubleSwap) Swap<double>;
%template(intSwap) Swap<int>;
}

/*
Instantiation of Array templates.
We instantiate some common use cases. Array.cpp instantiate these specialization.
template class Array<char>;
template class Array<int>;
template class Array<long long>;
template class Array<double>;
template class Array2D<int>;
template class Array2D<double>;
*/

%import "../common/array_instantiation_macro.i"
INSTANTIATE_ARRAY_INT
INSTANTIATE_ARRAY_DOUBLE
IGNORE_ARRAY_METHODS(bool)
INSTANTIATE_ARRAY_NUMPYARRAY(int8, char, NPY_BYTE) // 8bit
INSTANTIATE_ARRAY_NUMPYARRAY(int64, long long, NPY_LONGLONG) // 64bit

/*
For other classes, we need to ignore some methods
To ignore methos defined in Array.cpp, we use
IGNORE_ARRAY_METHODS_PREMITIVE
In more genral object, we need to futher ignore methods which uses comparision (> or == operators).
IGNORE_ARRAY_METHODS
*/

IGNORE_ARRAY_METHODS_PREMITIVE(bool)
INSTANTIATE_ARRAY_BOOL
IGNORE_ARRAY_METHODS_PREMITIVE(unsigned int)
INSTANTIATE_ARRAY_NUMPYARRAY(uint, unsigned int, NPY_UINT) // 32bit

/*
for these Array2D, we instantiate it. But we dont extend it since, Array2D<T> does not
expose the interanl pointer to array1d.
*/
%template(intArray2D) mfem::Array2D<int>;
%template(doubleArray2D) mfem::Array2D<double>;

37 changes: 35 additions & 2 deletions mfem/_ser/array.i
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ XXXPTR_SIZE_IN(bool *data_, int asize, bool)
%pythonappend mfem::Array::Array %{
if len(args) == 1 and isinstance(args[0], list):
if (len(args[0]) == 2 and hasattr(args[0][0], 'disown') and
not hasattr(args[0][1], 'disown')):
not hasattr(args[0][1], 'disown')):
## first element is SwigObject, like <Swig Object of type 'int *'>
## We do not own data in this case.
pass
Expand Down Expand Up @@ -147,8 +147,41 @@ namespace mfem{
%template(intSwap) Swap<int>;
}

/*
Instantiation of Array templates.
We instantiate some common use cases. Array.cpp instantiate these specialization.
template class Array<char>;
template class Array<int>;
template class Array<long long>;
template class Array<double>;
template class Array2D<int>;
template class Array2D<double>;
*/

%import "../common/array_instantiation_macro.i"
INSTANTIATE_ARRAY_INT
INSTANTIATE_ARRAY_DOUBLE
IGNORE_ARRAY_METHODS(bool)
INSTANTIATE_ARRAY_NUMPYARRAY(int8, char, NPY_BYTE) // for 8bit data
INSTANTIATE_ARRAY_NUMPYARRAY(int64, long long, NPY_LONGLONG) // 64bit

/*
For other classes, we need to ignore some methods
To ignore methos defined in Array.cpp, we use
IGNORE_ARRAY_METHODS_PREMITIVE
In more genral object, we need to futher ignore methods which uses comparision (> or == operators).
IGNORE_ARRAY_METHODS
*/

IGNORE_ARRAY_METHODS_PREMITIVE(bool)
INSTANTIATE_ARRAY_BOOL
IGNORE_ARRAY_METHODS_PREMITIVE(unsigned int)
INSTANTIATE_ARRAY_NUMPYARRAY(uint, unsigned int, NPY_UINT) // 32bit

/*
for these Array2D, we instantiate it. But we dont extend it since, Array2D<T> does not
expose the interanl pointer to array1d.
*/
%template(intArray2D) mfem::Array2D<int>;
%template(doubleArray2D) mfem::Array2D<double>;
1 change: 1 addition & 0 deletions mfem/_ser/gslib.i
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import_array();
%include "exception.i"
%include "../common/typemap_macros.i"
%include "../common/exception.i"
%import array.i
%import vector.i
%import mesh.i
%import gridfunc.i
Expand Down
Loading

0 comments on commit ce1ba0b

Please sign in to comment.