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

Update to v0.5.0 #78

Merged
merged 77 commits into from
Jun 8, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
77 commits
Select commit Hold shift + click to select a range
3db86b6
Update OCCA
noelchalmers Mar 12, 2022
fe568e5
Remove gslib
noelchalmers Mar 12, 2022
d41f047
Upgrade to newest ogs
noelchalmers Mar 12, 2022
72983ba
Add new comm_t object
noelchalmers Mar 12, 2022
4515afb
Add new memory objects
noelchalmers Mar 12, 2022
5898ed1
Add new timers
noelchalmers Mar 12, 2022
28fd90b
Move matrix routines into linAlg
noelchalmers Mar 12, 2022
71e61e5
Rename file
noelchalmers Mar 13, 2022
d7847f2
[Core] Update core lib
noelchalmers Mar 14, 2022
dd776b7
[LinAlg] Update linAlg lib
noelchalmers Mar 14, 2022
67a604c
[LinAlg] Rename some source files
noelchalmers Mar 14, 2022
4c45c96
[Core] Remove ambiguous scan overload
noelchalmers Mar 14, 2022
3297faa
[OCCA] Update to latest OCCA
noelchalmers Apr 26, 2022
228a47e
[Mesh] Move some mesh files
noelchalmers Apr 26, 2022
4c01601
[ParAdogs] Add parAdogs mesh partitioner
noelchalmers Apr 26, 2022
e655d09
[Mesh] Update mesh library
noelchalmers Apr 26, 2022
20c0cb3
[Core] Updates to core library
noelchalmers Apr 26, 2022
e8909c6
[LinAlg] Update linear algebra library
noelchalmers Apr 26, 2022
5c5f1e9
[TimeStepper] Update timeStepper library
noelchalmers Apr 26, 2022
7ffad49
[LinearSolver] Update linearSolver library
noelchalmers Apr 26, 2022
d7bc53a
[ParAlmond] Update parAlmond library
noelchalmers Apr 26, 2022
1941aa8
[Make] Makefile updates
noelchalmers Apr 26, 2022
543b116
[Advection] Update advection solver
noelchalmers Apr 26, 2022
037fdc4
[Acoustics] Update acoustics solver
noelchalmers Apr 26, 2022
cc5564c
[Gradient] Update gradient solver
noelchalmers Apr 26, 2022
08055cf
[Elliptic] Update elliptic solver
noelchalmers Apr 26, 2022
5d2c98b
[CNS] Update compressible navier stokes solver
noelchalmers Apr 26, 2022
8329841
[Test] Some test tweaks
noelchalmers Apr 26, 2022
715ea71
[LBS] Update DG Lattice Boltzmann solver
noelchalmers Apr 27, 2022
dfe568f
[LBS] Makefile tweak
noelchalmers Apr 27, 2022
231ba66
[BNS] Update Galerkin Boltzmann Navier-Stokes solver
noelchalmers Apr 27, 2022
76930d6
[FPE] Update Fokker-Planck solver
noelchalmers Apr 27, 2022
ebc1f2f
[INS] Update incompressible Navier-Stokes solver
noelchalmers Apr 28, 2022
326487c
[LinAlg] LinAlg fixes
noelchalmers Apr 28, 2022
cc2c959
[InitialGuess] FIxes in initial guess strategies
noelchalmers Apr 28, 2022
6e5234f
[Mesh] Initialize mapB to -1
noelchalmers Apr 28, 2022
1f9320b
[Mesh] mapB in mesh_t class
noelchalmers Apr 28, 2022
1f4147b
[Mesh] Bug fix in cubature setup
noelchalmers Apr 28, 2022
85b9a36
[Mesh] Bugifx in multirate setup
noelchalmers Apr 28, 2022
60a0b9f
[ParAlmond] Switch to shared_ptr to address mem leak
noelchalmers Apr 28, 2022
c072c59
[Test] Tweak one golden norm
noelchalmers Apr 28, 2022
3977517
[Test] Add ParAdogs tests
noelchalmers Apr 28, 2022
0415c68
[Solvers] Switch to strings for filenames and kernelname to avoid mem…
noelchalmers Apr 28, 2022
afdbb28
Version bump
noelchalmers Apr 28, 2022
e65f784
Merge branch 'master' of github.com:paranumal/libparanumal into staging
noelchalmers Apr 28, 2022
0c882da
Happy New Year
noelchalmers Apr 29, 2022
9139524
Need some manual barriers
noelchalmers Apr 29, 2022
2c21ada
[Solvers] Trigger ogs kernel builds during setups
noelchalmers Apr 29, 2022
6658636
[Git] Ignore rc files made by tests
noelchalmers May 1, 2022
1e1a4d3
[Make] Fix default openblas-serial lib path
noelchalmers May 1, 2022
3e15c25
[Git] Use openblas-serial in git workflow
noelchalmers May 1, 2022
febc58b
[Comm] Move some things out of the comm_t class, and into a namespace
noelchalmers May 1, 2022
8b4b759
[Mesh] Make the element type an enum
noelchalmers May 1, 2022
1502f87
[Make] Missing code coverage flags
noelchalmers May 1, 2022
d077084
[OGS] Add some more explicit instantiations to workaround issue in ol…
noelchalmers May 1, 2022
078a21c
[Timer] Can't use a the plaform's comm at the end of ogsSetup. Adding…
noelchalmers May 2, 2022
f9f3915
Update README.md
noelchalmers May 3, 2022
ef8555e
Add code diagram
noelchalmers May 5, 2022
341fd70
Merge branch 'staging' of github.com:paranumal/libparanumal into staging
noelchalmers May 5, 2022
86f0318
Update README.md
noelchalmers May 5, 2022
2be74fb
[LinearSolver] Bugfix for uninitialized memory
noelchalmers May 14, 2022
e0b3174
[Libs][Solvers] Small fixes for building in FP32 mode
noelchalmers May 14, 2022
7464423
[Core] Remove repeated compiler flags
noelchalmers May 14, 2022
8f36675
[Core] Workaround for occa dtypes being empty for user-types
noelchalmers May 14, 2022
8dbf988
Merge branch 'staging' of github.com:paranumal/libparanumal into staging
noelchalmers May 14, 2022
5152215
[ParAdogs] Reduce a termination tolerance when in FP32 mode
noelchalmers May 18, 2022
e4b42f0
[ParAdogs] Typo
noelchalmers May 18, 2022
c5b7b14
[OCCA] Switch to OCCA dev branch
noelchalmers May 20, 2022
10ec480
[Core] Add a check to not exceed the max thread count OpenMP reports
noelchalmers May 20, 2022
2f995eb
[OGS] Add some restricts to pointers for host operators
noelchalmers May 20, 2022
abaee13
[OCCA] Fix properties syntax
noelchalmers May 20, 2022
c5a56b8
[OGS] Add special code paths for scalar ogs ops
noelchalmers May 26, 2022
facc0f5
Add some notes on CPU binding to the README
noelchalmers May 26, 2022
672b275
[Acoustics] Hide more comm time with the surface kernel
noelchalmers May 26, 2022
ea5adeb
[OGS] Fix final row block entry being too large
noelchalmers May 31, 2022
f72e8de
Merge branch 'staging' of github.com:paranumal/libparanumal into staging
noelchalmers May 31, 2022
9068ad0
[OCCA] Update to OCCA v1.3
noelchalmers Jun 2, 2022
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
[Acoustics] Update acoustics solver
  • Loading branch information
noelchalmers committed Apr 26, 2022
commit 037fdc40e3f4f8a51d30d8a55d051bc880014146
43 changes: 22 additions & 21 deletions solvers/acoustics/acoustics.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,55 +36,56 @@ SOFTWARE.

#define DACOUSTICS LIBP_DIR"/solvers/acoustics/"

using namespace libp;

class acousticsSettings_t: public settings_t {
public:
acousticsSettings_t(MPI_Comm& _comm);
acousticsSettings_t(comm_t _comm);
void report();
void parseFromFile(platformSettings_t& platformSettings,
meshSettings_t& meshSettings,
const string filename);
const std::string filename);
};

class acoustics_t: public solver_t {
public:
mesh_t &mesh;
mesh_t mesh;

int Nfields;

TimeStepper::timeStepper_t* timeStepper;
timeStepper_t timeStepper;

halo_t* traceHalo;
ogs::halo_t traceHalo;

dfloat *q;
occa::memory o_q;
memory<dfloat> q;
deviceMemory<dfloat> o_q;

occa::memory o_Mq;
deviceMemory<dfloat> o_Mq;

occa::kernel volumeKernel;
occa::kernel surfaceKernel;
kernel_t volumeKernel;
kernel_t surfaceKernel;

occa::kernel initialConditionKernel;
kernel_t initialConditionKernel;

acoustics_t() = delete;
acoustics_t() = default;
acoustics_t(platform_t &_platform, mesh_t &_mesh,
acousticsSettings_t& _settings):
solver_t(_platform, _settings), mesh(_mesh) {}

~acoustics_t();
acousticsSettings_t& _settings) {
Setup(_platform, _mesh, _settings);
}

//setup
static acoustics_t& Setup(platform_t& platform, mesh_t& mesh,
acousticsSettings_t& settings);
void Setup(platform_t& _platform, mesh_t& _mesh,
acousticsSettings_t& _settings);

void Run();

void Report(dfloat time, int tstep);

void PlotFields(dfloat* Q, char *fileName);
void PlotFields(memory<dfloat> Q, const std::string fileName);

void rhsf(occa::memory& o_q, occa::memory& o_rhs, const dfloat time);
void rhsf(deviceMemory<dfloat>& o_q, deviceMemory<dfloat>& o_rhs, const dfloat time);

dfloat MaxWaveSpeed();
};

#endif
#endif
47 changes: 24 additions & 23 deletions solvers/acoustics/acousticsMain.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -29,39 +29,40 @@ SOFTWARE.
int main(int argc, char **argv){

// start up MPI
MPI_Init(&argc, &argv);
comm_t::Init(argc, argv);

MPI_Comm comm = MPI_COMM_WORLD;
LIBP_ABORT("Usage: ./acousticsMain setupfile", argc!=2);

if(argc!=2)
LIBP_ABORT(string("Usage: ./acousticsMain setupfile"));
{ /*Scope so everything is destructed before MPI_Finalize */
comm_t comm(comm_t::world().Dup());

//create default settings
platformSettings_t platformSettings(comm);
meshSettings_t meshSettings(comm);
acousticsSettings_t acousticsSettings(comm);
//create default settings
platformSettings_t platformSettings(comm);
meshSettings_t meshSettings(comm);
acousticsSettings_t acousticsSettings(comm);

//load settings from file
acousticsSettings.parseFromFile(platformSettings, meshSettings,
argv[1]);
//load settings from file
acousticsSettings.parseFromFile(platformSettings, meshSettings,
argv[1]);

// set up platform
platform_t platform(platformSettings);
// set up platform
platform_t platform(platformSettings);

platformSettings.report();
meshSettings.report();
acousticsSettings.report();
platformSettings.report();
meshSettings.report();
acousticsSettings.report();

// set up mesh
mesh_t& mesh = mesh_t::Setup(platform, meshSettings, comm);
// set up mesh
mesh_t mesh(platform, meshSettings, comm);

// set up acoustics solver
acoustics_t& acoustics = acoustics_t::Setup(platform, mesh, acousticsSettings);
// set up acoustics solver
acoustics_t acoustics(platform, mesh, acousticsSettings);

// run
acoustics.Run();
// run
acoustics.Run();
}

// close down MPI
MPI_Finalize();
comm_t::Finalize();
return LIBP_SUCCESS;
}
17 changes: 6 additions & 11 deletions solvers/acoustics/makefile
Original file line number Diff line number Diff line change
Expand Up @@ -77,11 +77,8 @@ include ../../make.top
endif
endif

#gslib
GS_DIR=${LIBP_TPL_DIR}/gslib

#libraries
ACOUSTICS_LIBP_LIBS=timeStepper mesh ogs linAlg core
ACOUSTICS_LIBP_LIBS=timeStepper mesh parAdogs ogs linAlg core

#includes
INCLUDES=${LIBP_INCLUDES} \
Expand All @@ -92,11 +89,10 @@ DEFINES =${LIBP_DEFINES} \
-DLIBP_DIR='"${LIBP_DIR}"'

#.cpp compilation flags
ACOUSTICS_CXXFLAGS=${LIBP_MPICXXFLAGS} ${DEFINES} ${INCLUDES}
ACOUSTICS_CXXFLAGS=${LIBP_CXXFLAGS} ${DEFINES} ${INCLUDES}

#link libraries
LIBS=-L${LIBP_LIBS_DIR} $(addprefix -l,$(ACOUSTICS_LIBP_LIBS)) \
-L$(GS_DIR)/lib -lgs \
${LIBP_LIBS}

#link flags
Expand Down Expand Up @@ -144,10 +140,10 @@ endif
# rule for .cpp files
%.o: %.cpp $(DEPS) | libp_libs
ifneq (,${verbose})
$(LIBP_MPICXX) -o $*.o -c $*.cpp $(ACOUSTICS_CXXFLAGS)
$(LIBP_CXX) -o $*.o -c $*.cpp $(ACOUSTICS_CXXFLAGS)
else
@printf "%b" "$(OBJ_COLOR)Compiling $(@F)$(NO_COLOR)\n";
@$(LIBP_MPICXX) -o $*.o -c $*.cpp $(ACOUSTICS_CXXFLAGS)
@$(LIBP_CXX) -o $*.o -c $*.cpp $(ACOUSTICS_CXXFLAGS)
endif

#cleanup
Expand All @@ -158,8 +154,7 @@ clean-libs: clean
${MAKE} -C ${LIBP_LIBS_DIR} clean

clean-kernels: clean-libs
# $(shell ${OCCA_DIR}/bin/occa clear all -y)
rm -rf ~/.occa/
rm -rf ${LIBP_DIR}/.occa/

realclean: clean
${MAKE} -C ${LIBP_LIBS_DIR} realclean
Expand All @@ -177,4 +172,4 @@ info:
@true

test: acousticsMain
@${MAKE} -C $(LIBP_TEST_DIR) --no-print-directory test-acoustics
@${MAKE} -C $(LIBP_TEST_DIR) --no-print-directory test-acoustics
4 changes: 0 additions & 4 deletions solvers/acoustics/okl/acousticsSurfaceHex3D.okl
Original file line number Diff line number Diff line change
Expand Up @@ -151,8 +151,6 @@ void surfaceTerms(const int e,
}
}

@barrier("global");

// face 1 & 3
for(int es=0;es<p_NblockS;++es;@inner(2)){
for(int k=0;k<p_Nq;++k;@inner(1)){
Expand All @@ -172,8 +170,6 @@ void surfaceTerms(const int e,
}
}

@barrier("global");

// face 2 & 4
for(int es=0;es<p_NblockS;++es;@inner(2)){
for(int k=0;k<p_Nq;++k;@inner(1)){
Expand Down
6 changes: 0 additions & 6 deletions solvers/acoustics/okl/acousticsSurfaceQuad2D.okl
Original file line number Diff line number Diff line change
Expand Up @@ -136,8 +136,6 @@ void surfaceTerms(const int e,
}
}

@barrier("local");

// for all face nodes of all elements
// face 0 & 2
for(int es=0;es<p_NblockS;++es;@inner(1)){
Expand All @@ -158,8 +156,6 @@ void surfaceTerms(const int e,
}
}

@barrier("local");

// face 1 & 3
for(int es=0;es<p_NblockS;++es;@inner(1)){
for(int j=0;j<p_Nq;++j;@inner(0)){
Expand All @@ -179,8 +175,6 @@ void surfaceTerms(const int e,
}
}

@barrier("local");

// for each node in the element
for(int es=0;es<p_NblockS;++es;@inner(1)){
for(int i=0;i<p_Nq;++i;@inner(0)){
Expand Down
3 changes: 0 additions & 3 deletions solvers/acoustics/okl/acousticsSurfaceTet3D.okl
Original file line number Diff line number Diff line change
Expand Up @@ -138,9 +138,6 @@ void upwind(const dfloat nx,
}
}

// wait for all @shared memory writes of the previous inner loop to complete
@barrier("local");

// for each node in the element
for(int es=0;es<p_NblockS;++es;@inner(1)){
for(int n=0;n<p_maxNodes;++n;@inner(0)){
Expand Down
3 changes: 0 additions & 3 deletions solvers/acoustics/okl/acousticsSurfaceTri2D.okl
Original file line number Diff line number Diff line change
Expand Up @@ -131,9 +131,6 @@ void upwind(const dfloat nx,
}
}

// wait for all @shared memory writes of the previous inner loop to complete
@barrier("local");

// for each node in the element
for(int es=0;es<p_NblockS;++es;@inner(1)){
for(int n=0;n<p_maxNodes;++n;@inner(0)){
Expand Down
2 changes: 0 additions & 2 deletions solvers/acoustics/okl/acousticsVolumeHex3D.okl
Original file line number Diff line number Diff line change
Expand Up @@ -108,8 +108,6 @@ SOFTWARE.
}
}

@barrier("local");

for(int k=0;k<p_Nq;++k;@inner(2)){
for(int j=0;j<p_Nq;++j;@inner(1)){
for(int i=0;i<p_Nq;++i;@inner(0)){
Expand Down
2 changes: 0 additions & 2 deletions solvers/acoustics/okl/acousticsVolumeQuad2D.okl
Original file line number Diff line number Diff line change
Expand Up @@ -81,8 +81,6 @@ SOFTWARE.
}
}

@barrier("local");

for(int j=0;j<p_Nq;++j;@inner(1)){
for(int i=0;i<p_Nq;++i;@inner(0)){
const dlong gid = e*p_Np*p_Nvgeo+ j*p_Nq +i;
Expand Down
8 changes: 0 additions & 8 deletions solvers/acoustics/okl/acousticsVolumeTet3D.okl
Original file line number Diff line number Diff line change
Expand Up @@ -103,8 +103,6 @@ SOFTWARE.

}

@barrier("local");

for(int n=0;n<p_Np;++n;@inner(0)){

dfloat rhsq0 = 0, rhsq1 = 0, rhsq2 = 0, rhsq3 = 0;
Expand Down Expand Up @@ -155,8 +153,6 @@ SOFTWARE.
s_w[n] = q[qbase+3*p_Np];
}

@barrier("local");

for(int n=0;n<p_Np;++n;@inner(0)){

// prefetch geometric factors (constant on triangle)
Expand Down Expand Up @@ -246,8 +242,6 @@ SOFTWARE.
}
}

@barrier("local");

for(int n=0;n<p_Np;++n;@inner(0)){

dfloat r_drhodr[p_Nvol], r_drhods[p_Nvol], r_drhodt[p_Nvol];
Expand Down Expand Up @@ -372,8 +366,6 @@ SOFTWARE.
}
}

@barrier("local");

for(int et=0;et<p_NblockV;++et;@inner(1)){
for(int n=0;n<p_Np;++n;@inner(0)){

Expand Down
2 changes: 0 additions & 2 deletions solvers/acoustics/okl/acousticsVolumeTri2D.okl
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,6 @@ SOFTWARE.
}
}

@barrier("local");

for(int n=0;n<p_Np;++n;@inner(0)){

dfloat rhsq0 = 0, rhsq1 = 0, rhsq2 = 0;
Expand Down
Loading