mirror of
https://github.com/PhasicFlow/phasicFlow.git
synced 2025-06-12 16:26:23 +00:00
corrections for coupling
This commit is contained in:
@ -21,81 +21,98 @@ Licence:
|
||||
#include "domainDistribute.hpp"
|
||||
|
||||
|
||||
|
||||
pFlow::coupling::domainDistribute::domainDistribute(
|
||||
int32 numDomains,
|
||||
const Vector<box>& domains_,
|
||||
real maxBoundingBox)
|
||||
:
|
||||
numDomains_(numDomains),
|
||||
extDomains_("extDomains", numDomains),
|
||||
particlesInDomains_("particlesInDomains", numDomains),
|
||||
numParInDomain_("numParInDomain", numDomains, 0),
|
||||
maxBoundingBoxSize_(maxBoundingBox)
|
||||
void pFlow::domainDistribute::clcDomains(const std::vector<box>& domains)
|
||||
{
|
||||
|
||||
realx3 dl = domainExtension_ * maxBoundingBoxSize_;
|
||||
|
||||
for(int32 i=0; i<numDomains_; i++)
|
||||
{
|
||||
extDomains_[i] = extendBox(domains_[i], dl);
|
||||
extDomains_[i] = extendBox(domains[i], dl);
|
||||
}
|
||||
}
|
||||
|
||||
bool pFlow::coupling::domainDistribute::locateParticles(
|
||||
|
||||
pFlow::domainDistribute::domainDistribute(
|
||||
const Vector<box>& domains,
|
||||
real maxBoundingBox)
|
||||
:
|
||||
numDomains_(domains.size()),
|
||||
extDomains_("extDomains", numDomains_),
|
||||
particlesInDomains_("particlesInDomains", numDomains_),
|
||||
numParInDomain_("numParInDomain", numDomains_, 0),
|
||||
maxBoundingBoxSize_(maxBoundingBox)
|
||||
{
|
||||
|
||||
clcDomains(domains);
|
||||
}
|
||||
|
||||
bool pFlow::domainDistribute::locateParticles(
|
||||
ViewType1D<realx3,HostSpace> points, includeMask mask)
|
||||
{
|
||||
range active = mask.activeRange();
|
||||
auto numInDomain = numParInDomain_.deviceVectorAll();
|
||||
auto numDomains = numDomains_;
|
||||
|
||||
using policy = Kokkos::RangePolicy<
|
||||
DefaultHostExecutionSpace,
|
||||
Kokkos::IndexType<int32> >;
|
||||
|
||||
Kokkos::parallel_for("locateParticles",
|
||||
policy(active.first, active.second),
|
||||
LAMBDA_HD(int32 i){
|
||||
if(mask(i))
|
||||
{
|
||||
for(int32 di=0; di<numDomains; di++)
|
||||
{
|
||||
if(extDomains_[i].isInside(points[i]))
|
||||
Kokkos::atomic_add(&numInDomain[di],1);
|
||||
}
|
||||
}
|
||||
});
|
||||
Kokkos::fence();
|
||||
|
||||
|
||||
for(int32 i=0; i<numDomains_; i++)
|
||||
{
|
||||
range active = mask.activeRange();
|
||||
auto numInDomain = numParInDomain_.deviceVectorAll();
|
||||
auto numDomains = numDomains_;
|
||||
particlesInDomains_[i].resize(numParInDomain_[i]);
|
||||
}
|
||||
|
||||
using policy = Kokkos::RangePolicy<
|
||||
DefaultHostExecutionSpace,
|
||||
Kokkos::IndexType<int32> >;
|
||||
numParInDomain_.fill(0);
|
||||
|
||||
Kokkos::parallel_for("locateParticles",
|
||||
policy(active.first, active.second),
|
||||
LAMBDA_HD(int32 i){
|
||||
if(mask(i))
|
||||
auto particlesInDomainsPtr = particlesInDomains_.data();
|
||||
|
||||
Kokkos::parallel_for("locateParticles",
|
||||
policy(active.first, active.second),
|
||||
LAMBDA_HD(int32 i){
|
||||
if(mask(i))
|
||||
{
|
||||
for(int32 di=0; di<numDomains; di++)
|
||||
{
|
||||
for(int32 di=0; di<numDomains; di++)
|
||||
if(extDomains_[i].isInside(points[i]))
|
||||
{
|
||||
if(extDomains_[i].isInside(points[i]))
|
||||
Kokkos::atomic_add(&numInDomain[di],1);
|
||||
|
||||
particlesInDomainsPtr[di][numInDomain[di]] = i;
|
||||
Kokkos::atomic_add(&numInDomain[di],1);
|
||||
|
||||
}
|
||||
}
|
||||
});
|
||||
Kokkos::fence();
|
||||
|
||||
|
||||
for(int32 i=0; i<numDomains_; i++)
|
||||
{
|
||||
particlesInDomains_[i].resize(numParInDomain_[i]);
|
||||
}
|
||||
|
||||
numParInDomain_.fill(0);
|
||||
|
||||
auto particlesInDomainsPtr = particlesInDomains_.data();
|
||||
|
||||
Kokkos::parallel_for("locateParticles",
|
||||
policy(active.first, active.second),
|
||||
LAMBDA_HD(int32 i){
|
||||
if(mask(i))
|
||||
{
|
||||
for(int32 di=0; di<numDomains; di++)
|
||||
{
|
||||
if(extDomains_[i].isInside(points[i]))
|
||||
{
|
||||
|
||||
particlesInDomainsPtr[di][numInDomain[di]] = i;
|
||||
Kokkos::atomic_add(&numInDomain[di],1);
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
Kokkos::fence();
|
||||
}
|
||||
});
|
||||
Kokkos::fence();
|
||||
|
||||
|
||||
return true;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
bool pFlow::domainDistribute::changeDomainsSize(
|
||||
const std::vector<box>& domains)
|
||||
{
|
||||
if(domains.size()!= numDomains_)
|
||||
{
|
||||
fatalErrorInFunction<<"number of new domians differs"<<endl;
|
||||
return false;
|
||||
}
|
||||
|
||||
clcDomains(domains);
|
||||
return true;
|
||||
}
|
@ -26,7 +26,7 @@ Licence:
|
||||
#include "VectorSingles.hpp"
|
||||
#include "pointStructure.hpp"
|
||||
|
||||
namespace pFlow::coupling
|
||||
namespace pFlow
|
||||
{
|
||||
|
||||
class domainDistribute
|
||||
@ -46,20 +46,17 @@ protected:
|
||||
|
||||
real maxBoundingBoxSize_;
|
||||
|
||||
int32 lastUpdateIter_ = 0;
|
||||
|
||||
int32 updateInterval_ = 1;
|
||||
|
||||
real domainExtension_ = 1.0;
|
||||
|
||||
using includeMask = typename pointStructure::activePointsHost;
|
||||
|
||||
void clcDomains(const std::vector<box>& domains);
|
||||
|
||||
public:
|
||||
|
||||
domainDistribute(
|
||||
int32 numDomains,
|
||||
const Vector<box>& domains_,
|
||||
real maxBoundinBox);
|
||||
const Vector<box>& domains,
|
||||
real maxBoundingBox);
|
||||
|
||||
~domainDistribute()=default;
|
||||
|
||||
@ -77,6 +74,18 @@ public:
|
||||
return numParInDomain_[di];
|
||||
}
|
||||
|
||||
span<const int32> particlesInDomain(int32 di)const
|
||||
{
|
||||
return
|
||||
span<const int32>(
|
||||
particlesInDomains_[di].hostVectorAll().data(),
|
||||
numParInDomain_[di]
|
||||
);
|
||||
}
|
||||
|
||||
bool changeDomainsSize(const std::vector<box>& domains);
|
||||
|
||||
|
||||
//template<typename includeMask>
|
||||
bool locateParticles(
|
||||
ViewType1D<realx3,HostSpace> points, includeMask mask);
|
||||
|
Reference in New Issue
Block a user