Skip to content

Commit

Permalink
Calculate x+u automatically inside slice
Browse files Browse the repository at this point in the history
  • Loading branch information
streeve committed Oct 4, 2023
1 parent 6b303fd commit 2af18d7
Showing 1 changed file with 21 additions and 0 deletions.
21 changes: 21 additions & 0 deletions src/CabanaPD_Particles.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,7 @@ class Particles<DeviceType, PMB, Dimension>
using self_type = Particles<DeviceType, PMB, Dimension>;
using device_type = DeviceType;
using memory_space = typename device_type::memory_space;
using execution_space = typename memory_space::execution_space;
static constexpr int dim = Dimension;

// Per particle.
Expand Down Expand Up @@ -308,10 +309,14 @@ class Particles<DeviceType, PMB, Dimension>
}
auto sliceCurrentPosition()
{
// Update before returning data.
updateCurrentPosition();
return Cabana::slice<0>( _aosoa_y, "current_positions" );
}
auto sliceCurrentPosition() const
{
// Update before returning data.
updateCurrentPosition();
return Cabana::slice<0>( _aosoa_y, "current_positions" );
}
auto sliceDisplacement()
Expand Down Expand Up @@ -373,6 +378,22 @@ class Particles<DeviceType, PMB, Dimension>
return Cabana::slice<0>( _aosoa_nofail, "no_fail_region" );
}

void updateCurrentPosition()
{
// Not using slice function because this is called inside.
auto y = Cabana::slice<0>( _aosoa_y, "current_positions" );
auto x = sliceReferencePosition();
auto u = sliceDisplacement();
Kokkos::RangePolicy<execution_space> policy( 0, n_local + n_ghost );
auto sum_x_u = KOKKOS_LAMBDA( const std::size_t pid )
{
for ( int d = 0; d < 3; d++ )
y( pid, d ) = x( pid, d ) + u( pid, d );
};
Kokkos::parallel_for( "CabanaPD::CalculateCurrentPositions", policy,
sum_x_u );
}

void resize( int new_local, int new_ghost )
{
n_local = new_local;
Expand Down

0 comments on commit 2af18d7

Please sign in to comment.