Initial commit for a particle specific load balancer.
This load balancer is attempting to address performance issues in the DLB associated with particles.
In particular, the DLB balances on a single cost metric which is a function of the number of particles
and cells. This load balancer seperates the metric and load balances in two phases. During the first
phase any patches that have particles are assigned to processors and in the second phase all remaining patches
are assigned to processors. During the first phase the load balancer attemptes to equalize the number of particles
on each processor. The second phase then load balances the remaining processors while attempting to equalize
the number of cells on each processor, this is done while mainting the assignments from the first phase.
Theoretically this will help avoid synchronization problems associated with having varying numbers of particles
on each processor.
1423 lines of code changed in 6 files:
Moved some classes from DLB.h to LBC.h so they can be more readily reused. Also fixed the indenting of LBC.h
115 lines of code changed in 3 files:
Thrashing:
interpolateToParticlesAndUpdate()
#if'd out getRegion calls
HARDCODED velocity to [-100, -100, 0] used for debugging relocate.
removed:
d_nextOutputTime
d_recompile
boundary traction face code
scheduleSwitchTest()
setParticleDefault()
checkNeedAddMPMMaterial()
setNeedAddMaterialFlag()
needRecompile
23 lines of code changed in 2 files:
findNeighboringPatches()
hasFiner & hasCoarser sections
- no longer using coarse/fine interface face iterator to determine if a patch is a
neighbor. Now returning ALL patches in the adjacent fine or coarse level. I wish there was a more efficient
algorithm but there isn't.
38 lines of code changed in 1 file:
pulled weed
0 lines of code changed in 2 files:
Cleaning up source term addition for old transport equations. Now the "new" sources can be activated by adding the <src ... > tag in the eqn's xml node in the same manner we are using for new scalar eqns.
116 lines of code changed in 18 files:
comment out debugging output
1 lines of code changed in 1 file:
findNeighboringPatches()
- ascii art
- hasCoarser & hasFiner sections
using a larger footprint to select patches with.
relocateParticles()
in the merging section of the code.
patches-> toPatches
59 lines of code changed in 1 file:
Moved the logic which removes particles that are not within the query range withing the query. Also save the results after removing those particles back into the database so future queries are faster.
64 lines of code changed in 2 files:
Missed a few more of these temp copy copies.
9 lines of code changed in 1 file:
Save temp copies for FE integration.
5 lines of code changed in 1 file:
BoundaryConditions.*:
Standard Arches inlets can now be named.
Inlet area is printed out with name when case starts up.
Also allow one to set the second mixture fraction in the old ARCHES bc. This is needed for property evaluation and should be fixed at some point when the old property evaluator goes away.
InletStream.cc:
Initializing second mixture fraction.
ExplicitSolver.cc
Tweaks on the scalar solver solve. i
Because of the multiple density issue and the generally bad abstraction of how density is handled, the scalar eqn needs to use tempDensity to stand in for the previous rk density for the FE update.
ScalarEqn.cc
Changes in which density is used.
Turns out Arches is copying density from old_dw->new_dw at the beginning of each time step so old_dw density was never needed.
Also need to use tempDensity for the explicit update.
Finally, needed to change the "evalTransportEqn" to check if the equation used density guess to be able to handle density abstraction (see update to ExplicitSolver.cc).
arches_ups.xml
Update spec to allow for naming of inlet and adding mixture_fraction_2 value or <FlowInlet>.
41 lines of code changed in 6 files:
Fixed a memory leak.
0 lines of code changed in 1 file:
First of a couple changes to how particle subsets are stored.
This removes the low and high index from the map key and changes the map to a multimap. Queries now search this multimap and then linearlly search the resulting entries (should be between 1-7 entries) for a sufficient match.
This eliminates linear searches through the entire particle subset database in order to find a sufficient match.
310 lines of code changed in 18 files:
- Saving weight label and "small" value so we don't have to find it each time
- Not setting weight/weighted abscissa to 0 (I thought I had changed this already but apparently not...)
28 lines of code changed in 2 files:
Adding momentum exchange between gas phase and particle phase with the drag model
232 lines of code changed in 22 files:
updated scheduling algorithm
36 lines of code changed in 2 files:
Fixed an uninitialized variable warning.
2 lines of code changed in 1 file:
Allowing for adiabatic enthalpy case when using TabProps.
37 lines of code changed in 5 files:
1) Density should not be treated differently on boundaries. Now always interpolated with 2nd order interpolant.
2) Because of 1), there is no longer a need to have a special getDensityOnFace function.
3) Indexing was incorrect on construting the Boundary face iterator.
24 lines of code changed in 3 files:
Removing old TabProps directory.
0 lines of code changed in 7 files:
Add the ability to call getModifiable(gridVar) with ghost cells. Users should be able to write to these ghost cells but any data written to them will be lost when the task exits. This is useful for computing data locally instead of communicating it (for example a node entered value that is computed from a cell value which is required with ghost cells).
5 lines of code changed in 3 files:
Making the restart with new BC's an option for now until the regression tester differences can be sorted out.
19 lines of code changed in 2 files:
Fixing the scalar equations to be able to handle a recompiled task graph.
7 lines of code changed in 1 file:
Recomputing boundary conditions on restart. This will allow the user to modify ARCHES bc's from input.xml in the restarting uda.
30 lines of code changed in 2 files:
Removed
# ifdef _WIN32
code
#endif
0 lines of code changed in 27 files:
set the min/max grid level in the constructor. The user no longer needs to specify it.
2 lines of code changed in 1 file:
Added an additional field to selectPatches which specifies if the query should included extra cells or not.
Fixed lineextract on extracells
13 lines of code changed in 4 files:
Fixed a #ifdef HAVE_TABPROPS that was removing non-tabprops code.
Removed a "computeProps" that wasn't being used.
0 lines of code changed in 2 files:
removed Windows based exceptions.
0 lines of code changed in 4 files:
Changed some more logic
19 lines of code changed in 1 file:
Removed cout statements
2 lines of code changed in 1 file:
Added Cracking to DDT1 including all code enhancements DDT0 has undergone in recent commits
456 lines of code changed in 2 files:
Extend the bounding box passed in instead of replacing it.
2 lines of code changed in 1 file:
problemSetup()
added bulletproofing. User must have
<useLockStep> true </useLockStep>
in AMR section of input file.
11 lines of code changed in 1 file:
Real fix for TabProps for Static Builds.
1 lines of code changed in 1 file:
TabProps fix for static builds
3 lines of code changed in 1 file:
Making Arches TabProps optional. (For now.)
M configure
M configure.ac
M configVars.mk.in
M include/sci_defs/uintah_testdefs.h.in
Set up the #define and Make variables to be used for checking to see
if TabProps exists. You must #include <sci_defs/uintah_defs.h> to ge
the appropiate HAVE_TABPROPS variable.
M CCA/Components/Arches/ChemMix/sub.mk
White space fix.
M CCA/Components/Arches/sub.mk
Only build the ChemMix subdir if TabProps is enabled.
M CCA/Components/Arches/Properties.cc
M CCA/Components/Arches/Properties.h
#if out TabProps stuff when TabProps is not enabled.
54 lines of code changed in 9 files:
Removing print statement.
0 lines of code changed in 1 file:
Print statement was incorrect.
0 lines of code changed in 2 files:
Removing the TabProps lib from Arches. It's now an external lib.
6 lines of code changed in 11 files:
More cleanup of the scalar clamp.
37 lines of code changed in 1 file:
Actually click the scalar. For some reason the clipping was left out when this was cleaned up....
2 lines of code changed in 1 file:
Check that HDF5 exists only if TabProps is requested.
8 lines of code changed in 2 files:
Update --with-tabprops configure check. Note, use of HDF5 now requries the C++ hdf5 library.
110 lines of code changed in 2 files:
Compiler warning.
0 lines of code changed in 1 file:
Removed the *.clear() functions -- I don't *think* they were needed.
Using the getAllIndepVars() function in getState to ensure that the ordering is preserved when passing things into TabProps.
14 lines of code changed in 1 file:
Cleaned out some trash from TabPropsInterface.
Updated TabProps to allow for non-adiabatic boundary and initial conditions.
Added spec for non-adiabatic conditions for pressure, outlet and scalar init.
58 lines of code changed in 6 files:
Change the logic for determining the range that particles exist within.
Previously the computation was done using two different methods.
The first method mapped
the particle position to a cell index and then compared that index to the low and high indices.
The second method would map the low an dhigh indices to a position and then compare it to the
particle position.
In very rare cases these would not give the same answers due to floating point error causing
a critical failure.
We now use exclusively the first method for this calculation.
5 lines of code changed in 1 file:
Use containsIndex() function. This changes the + face to be exclusive (as it should have been).
2 lines of code changed in 1 file:
Removed static from a function call that shouldn't have been static.
0 lines of code changed in 2 files:
added
IntVector getCellIndex(const Point& pos) const
which really just maps to the same function in level.
8 lines of code changed in 1 file:
Added a static member containsIndex(low,high,idx).
This is useful for doing a patch intersection when you don't actually have a patch. I have also utilized this function throughout the patch class in order to reduce code duplication.
17 lines of code changed in 1 file: