Skip to content

Commit

Permalink
Merge pull request #20 from Xaunther/do-not-include-tableau-in-state
Browse files Browse the repository at this point in the history
Do not include tableau in state
  • Loading branch information
Alejandro Alfonso authored Dec 4, 2023
2 parents 555d059 + f3de31a commit 42f891e
Show file tree
Hide file tree
Showing 7 changed files with 108 additions and 123 deletions.
6 changes: 1 addition & 5 deletions include/CResult.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,18 +16,14 @@ class CResult

explicit CResult( const CTableauState& aInitialTableauState );

const history& GetHistory() const;
const CTableauState& GetTableauState() const;
const std::atomic_ulong& GetCounter() const;

void FindBest( const unsigned int& aNTries, std::mt19937_64& aRNG, const bool aSpeed );
void FindBest( const unsigned int& aNTries, const CTableau& aTableau, std::mt19937_64& aRNG, const bool aSpeed );

bool IsBetterResult( const history::size_type& aCountHits, const unsigned short& aScore ) const;

void SaveHistory( std::string_view aOutputFileName, const CTableau& aInitialTableau ) const;

private:
history mHistory;
CTableauState mTableauState;
std::mutex mMutex;
std::atomic_ulong mCounter;
Expand Down
2 changes: 0 additions & 2 deletions include/CTableau.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,6 @@ class CTableau

const index& GetRows() const;

void HitPiece( const index& aRowIndex, const index& aColIndex );

bool IsInside( const index& aRowIndex, const index& aColIndex ) const;

index CountPieces() const;
Expand Down
27 changes: 15 additions & 12 deletions include/CTableauState.h
Original file line number Diff line number Diff line change
Expand Up @@ -51,35 +51,38 @@ class CTableauState
using coordinates = std::pair<CTableau::index, CTableau::index>;
using coordinates_vector = std::vector<coordinates>;
using piece_type = CTableau::piece_type;
using history = std::vector<coordinates>;

explicit CTableauState( const CTableau& aTableau, const std::optional<coordinates>& aCurrentPosition );
explicit CTableauState( const std::optional<coordinates>& aCurrentPosition );

const CTableau& GetTableau() const;
const history& GetHistory() const;
const std::optional<coordinates>& GetCurrentPosition() const;
const unsigned short& GetScore() const;

// Updates set and multi states with the piece hit. Returrns score for hitting such piece
unsigned short Update( const piece_type& aPiece );

const coordinates& SetCurrentPositionAtRandom( std::mt19937_64& aRNG );
const coordinates& SetCurrentPositionAtRandom( const CTableau& aTableau, std::mt19937_64& aRNG );

std::optional<coordinates> Move( std::mt19937_64& aRNG );
std::optional<coordinates> Move( const CTableau& aTableau, std::mt19937_64& aRNG );

void SaveHistory( std::string_view aOutputFileName, const CTableau& aTableau ) const;

private:
void MoveDiagonal( coordinates_vector& aDestinations ) const;
void MoveDiagonal( coordinates_vector& aDestinations, int aSteps ) const;
void MoveStraight( coordinates_vector& aDestinations ) const;
void MoveStraight( coordinates_vector& aDestinations, int aSteps ) const;
void MoveKnight( coordinates_vector& aDestinations ) const;
void MoveWildcard( coordinates_vector& aDestinations ) const;
void MoveDiagonal( const CTableau& aTableau, coordinates_vector& aDestinations ) const;
void MoveDiagonal( const CTableau& aTableau, coordinates_vector& aDestinations, int aSteps ) const;
void MoveStraight( const CTableau& aTableau, coordinates_vector& aDestinations ) const;
void MoveStraight( const CTableau& aTableau, coordinates_vector& aDestinations, int aSteps ) const;
void MoveKnight( const CTableau& aTableau, coordinates_vector& aDestinations ) const;
void MoveWildcard( const CTableau& aTableau, coordinates_vector& aDestinations ) const;

void AppendDestination( coordinates_vector& aDestinations, const coordinates& aDestination ) const;
void AppendDestination( const CTableau& aTableau, coordinates_vector& aDestinations, const coordinates& aDestination ) const;

static constexpr unsigned short NUMERIC_DESTINATIONS_COUNT();
static constexpr unsigned short KQ_DESTINATIONS_COUNT();
static constexpr unsigned short RB_DESTINATIONS_COUNT();

CTableau mTableau;
history mHistory;
std::optional<coordinates> mCurrentPosition;
CSetState mSetState;
CMultiState mMultiState;
Expand Down
42 changes: 6 additions & 36 deletions src/CResult.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,6 @@ CResult::CResult( const CTableauState& aInitialTableauState ) :
{
}

const CResult::history& CResult::GetHistory() const
{
return mHistory;
}

const CTableauState& CResult::GetTableauState() const
{
return mTableauState;
Expand All @@ -25,50 +20,25 @@ const std::atomic_ulong& CResult::GetCounter() const
return mCounter;
}

void CResult::FindBest( const unsigned int& aNTries, std::mt19937_64& aRNG, const bool aSpeed )
void CResult::FindBest( const unsigned int& aNTries, const CTableau& aTableau, std::mt19937_64& aRNG, const bool aSpeed )
{
const auto initialTableauState = mTableauState;
const auto& targetPieces = initialTableauState.GetTableau().CountPieces() + ( aSpeed ? 0 : 1 );
for( ; mCounter < aNTries && mHistory.size() < targetPieces; mCounter++ ) // Iterate many times
const auto& targetPieces = aTableau.CountPieces() + ( aSpeed ? 0 : 1 );
for( ; mCounter < aNTries && mTableauState.GetHistory().size() < targetPieces; mCounter++ ) // Iterate many times
{
auto tableauState = initialTableauState;
history posHistory{ initialTableauState.GetCurrentPosition().value_or( tableauState.SetCurrentPositionAtRandom( aRNG ) ) };
while( const auto& nextPosition = tableauState.Move( aRNG ) )
history posHistory{ initialTableauState.GetCurrentPosition().value_or( tableauState.SetCurrentPositionAtRandom( aTableau, aRNG ) ) };
while( const auto& nextPosition = tableauState.Move( aTableau, aRNG ) )
posHistory.emplace_back( *nextPosition );
std::lock_guard lock( mMutex );
if( IsBetterResult( posHistory.size(), tableauState.GetScore() ) ) // New record!
{
mHistory = std::move( posHistory );
mTableauState = std::move( tableauState );
}
}
}

bool CResult::IsBetterResult( const history::size_type& aCountHits, const unsigned short& aScore ) const
{
return ( aCountHits > mHistory.size() ) || ( aCountHits == mHistory.size() && aScore > mTableauState.GetScore() );
}

void CResult::SaveHistory( std::string_view aOutputFileName, const CTableau& aInitialTableau ) const
{
std::ofstream outfile;
outfile.open( aOutputFileName.data() );
outfile << "Step # (i,j) Piece" << std::endl;
outfile << "----------------------" << std::endl;

unsigned int index = 0;
for( const auto& epoch : mHistory )
outfile << std::setw( 4 ) << index++ << " (" << epoch.first << "," << epoch.second << ") " << std::setw( 1 ) << CTableau::PieceToString( aInitialTableau.GetPiece( epoch.first, epoch.second ) ) << std::endl;
// Write also remaining pieces
outfile << "----------------------" << std::endl;
outfile << " Remaining Pieces " << std::endl;
outfile << "----------------------" << std::endl;
for( CTableau::index i = 0; i < aInitialTableau.GetRows(); i++ )
for( CTableau::index j = 0; j < aInitialTableau.GetRows(); j++ )
if( mTableauState.GetTableau().GetPiece( i, j ) != CTableau::E_PIECE_TYPE::EMPTY )
outfile << "(" << i << "," << j << "): " << CTableau::PieceToString( mTableauState.GetTableau().GetPiece( i, j ) ) << std::endl;
outfile.close();
return ( aCountHits > mTableauState.GetHistory().size() ) || ( aCountHits == mTableauState.GetHistory().size() && aScore > mTableauState.GetScore() );
}


};
5 changes: 0 additions & 5 deletions src/CTableau.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -53,11 +53,6 @@ const CTableau::index& CTableau::GetRows() const
return mRows;
}

void CTableau::HitPiece( const index& aRowIndex, const index& aColIndex )
{
mPieces[ aRowIndex * mRows + aColIndex ] = E_PIECE_TYPE::EMPTY;
}

bool CTableau::IsInside( const index& aRowIndex, const index& aColIndex ) const
{
return aRowIndex < mRows && aColIndex < mRows;
Expand Down
Loading

0 comments on commit 42f891e

Please sign in to comment.