openEMS/FDTD/engine_multithread.h

119 lines
3.1 KiB
C
Raw Normal View History

2010-03-26 11:57:52 +00:00
/*
* Copyright (C) 2010 Sebastian Held (sebastian.held@gmx.de)
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef ENGINE_MULTITHREAD_H
#define ENGINE_MULTITHREAD_H
#include "operator_multithread.h"
#include "engine_sse_compressed.h"
2010-03-26 11:57:52 +00:00
#include <boost/thread.hpp>
2010-03-27 21:57:25 +00:00
#include <boost/fusion/include/list.hpp>
#include <boost/fusion/container/list/list_fwd.hpp>
#include <boost/fusion/include/list_fwd.hpp>
2010-04-28 09:15:59 +00:00
#ifdef WIN32
#include <Winsock2.h> // for struct timeval
#endif
#include <sys/time.h>
#ifdef MPI_SUPPORT
#define ENGINE_MULTITHREAD_BASE Engine_MPI
#include "engine_mpi.h"
#else
#define ENGINE_MULTITHREAD_BASE Engine_SSE_Compressed
#endif
class Engine_Multithread;
namespace NS_Engine_Multithread
{
class DBG // debug
{
public:
DBG() {}
~DBG() { std::cout << os.str();}
std::ostringstream& cout() {return os;}
protected:
std::ostringstream os;
};
class Timer //debug
{
public:
Timer() {gettimeofday(&t1,NULL);}
double elapsed() {gettimeofday(&t2,NULL); return (t2.tv_sec-t1.tv_sec) + (t2.tv_usec-t1.tv_usec)*1e-6;}
protected:
timeval t1,t2;
};
class thread
{
public:
thread( Engine_Multithread* ptr, unsigned int start, unsigned int stop, unsigned int stop_h, unsigned int threadID );
void operator()();
protected:
unsigned int m_start, m_stop, m_stop_h, m_threadID;
Engine_Multithread *m_enginePtr;
};
} // namespace
class Engine_Multithread : public ENGINE_MULTITHREAD_BASE
2010-03-26 11:57:52 +00:00
{
friend class NS_Engine_Multithread::thread;
friend class Engine_CylinderMultiGrid;
2010-03-26 11:57:52 +00:00
public:
static Engine_Multithread* New(const Operator_Multithread* op, unsigned int numThreads = 0);
virtual ~Engine_Multithread();
2010-03-26 11:57:52 +00:00
2010-03-30 11:13:00 +00:00
virtual void setNumThreads( unsigned int numThreads );
2010-03-26 11:57:52 +00:00
virtual void Init();
virtual void Reset();
2010-07-16 08:41:12 +00:00
//! Iterate \a iterTS number of timesteps
2010-03-26 11:57:52 +00:00
virtual bool IterateTS(unsigned int iterTS);
virtual void DoPreVoltageUpdates(int threadID);
virtual void DoPostVoltageUpdates(int threadID);
virtual void Apply2Voltages(int threadID);
virtual void DoPreCurrentUpdates(int threadID);
virtual void DoPostCurrentUpdates(int threadID);
virtual void Apply2Current(int threadID);
2010-03-26 11:57:52 +00:00
protected:
2010-09-02 20:16:37 +00:00
Engine_Multithread(const Operator_Multithread* op);
const Operator_Multithread* m_Op_MT;
boost::thread_group m_thread_group;
2010-05-09 18:27:17 +00:00
boost::barrier *m_startBarrier, *m_stopBarrier;
boost::barrier *m_IterateBarrier;
volatile unsigned int m_iterTS;
unsigned int m_numThreads; //!< number of worker threads
volatile bool m_stopThreads;
2010-03-27 21:57:25 +00:00
2010-03-28 11:10:16 +00:00
#ifdef ENABLE_DEBUG_TIME
2010-03-27 21:57:25 +00:00
std::map<boost::thread::id, std::vector<double> > m_timer_list;
2010-03-28 11:10:16 +00:00
#endif
};
2010-03-26 11:57:52 +00:00
#endif // ENGINE_MULTITHREAD_H