2009-01-13 04:40:13 +05:00
|
|
|
#include <mystdlib.h>
|
|
|
|
#include "meshing.hpp"
|
|
|
|
|
2009-01-18 22:36:38 +05:00
|
|
|
|
2009-01-13 04:40:13 +05:00
|
|
|
namespace netgen
|
|
|
|
{
|
2017-08-28 21:19:20 +05:00
|
|
|
|
|
|
|
class TraceGlobal
|
|
|
|
{
|
|
|
|
string name;
|
|
|
|
public:
|
|
|
|
TraceGlobal(string _name) : name(_name) { cout << "init global " << name << endl; }
|
|
|
|
~TraceGlobal() { cout << "exit global " << name << endl; }
|
|
|
|
};
|
|
|
|
|
2009-01-18 22:36:38 +05:00
|
|
|
// stringstream emptystr;
|
|
|
|
// ostream * testout = &emptystr;
|
|
|
|
// testout -> clear(ios::failbit);
|
2009-01-24 18:35:44 +05:00
|
|
|
|
|
|
|
// ostream * testout = &cout;
|
|
|
|
ostream * testout = new ostream(0);
|
|
|
|
|
|
|
|
// NetgenOutStream * testout = new NetgenOutStream;
|
2009-01-13 04:40:13 +05:00
|
|
|
|
|
|
|
ostream * mycout = &cout;
|
|
|
|
ostream * myerr = &cerr;
|
|
|
|
|
2017-08-28 21:19:20 +05:00
|
|
|
// some functions (visualization) still need a global mesh
|
|
|
|
// TraceGlobal glob1("global1");
|
2015-10-19 13:08:30 +05:00
|
|
|
DLL_HEADER shared_ptr<Mesh> mesh;
|
|
|
|
DLL_HEADER shared_ptr<NetgenGeometry> ng_geometry;
|
2017-08-28 21:19:20 +05:00
|
|
|
// TraceGlobal glob2("global2");
|
2009-01-13 04:40:13 +05:00
|
|
|
|
2019-01-29 20:10:02 +05:00
|
|
|
// global communicator for netgen
|
2019-02-12 01:37:00 +05:00
|
|
|
DLL_HEADER MyMPI_Comm ng_comm = MPI_COMM_WORLD;
|
2019-01-29 20:10:02 +05:00
|
|
|
|
2015-01-09 02:18:33 +05:00
|
|
|
weak_ptr<Mesh> global_mesh;
|
2015-12-22 00:21:24 +05:00
|
|
|
void SetGlobalMesh (shared_ptr<Mesh> m)
|
|
|
|
{
|
|
|
|
PrintMessage(5, "set global mesh");
|
|
|
|
global_mesh = m;
|
|
|
|
}
|
|
|
|
|
2017-05-08 19:42:49 +05:00
|
|
|
// true if netgen was started using the netgen executable
|
|
|
|
// false if netgen.gui was imported from python
|
|
|
|
DLL_HEADER bool netgen_executable_started = false;
|
2015-12-22 00:21:24 +05:00
|
|
|
|
2011-01-11 01:18:01 +05:00
|
|
|
// Flags parameters;
|
2009-01-13 04:40:13 +05:00
|
|
|
int silentflag = 0;
|
|
|
|
int testmode = 0;
|
|
|
|
|
|
|
|
volatile multithreadt multithread;
|
|
|
|
|
|
|
|
string ngdir = ".";
|
|
|
|
|
2014-08-30 06:15:59 +06:00
|
|
|
void Ng_PrintDest(const char * s)
|
|
|
|
{
|
|
|
|
if (id == 0)
|
|
|
|
(*mycout) << s << flush;
|
|
|
|
}
|
|
|
|
|
|
|
|
DLL_HEADER void MyError(const char * ch)
|
|
|
|
{
|
|
|
|
cout << ch;
|
|
|
|
(*testout) << "Error !!! " << ch << endl << flush;
|
|
|
|
}
|
|
|
|
|
|
|
|
static clock_t starttimea;
|
|
|
|
void ResetTime ()
|
|
|
|
{
|
|
|
|
starttimea = clock();
|
|
|
|
}
|
|
|
|
|
|
|
|
double GetTime ()
|
|
|
|
{
|
|
|
|
return double(clock() - starttimea) / CLOCKS_PER_SEC;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2009-01-25 17:35:25 +05:00
|
|
|
Array<int> tets_in_qualclass;
|
2009-01-13 04:40:13 +05:00
|
|
|
|
2016-02-22 22:43:51 +05:00
|
|
|
mutex tcl_todo_mutex;
|
|
|
|
|
2012-07-06 13:49:05 +06:00
|
|
|
int h_argc = 0;
|
|
|
|
char ** h_argv = NULL;
|
2009-01-13 04:40:13 +05:00
|
|
|
|
|
|
|
multithreadt :: multithreadt()
|
|
|
|
{
|
|
|
|
pause =0;
|
|
|
|
testmode = 0;
|
|
|
|
redraw = 0;
|
|
|
|
drawing = 0;
|
|
|
|
terminate = 0;
|
|
|
|
running = 0;
|
|
|
|
percent = 0;
|
|
|
|
task = "";
|
|
|
|
}
|
|
|
|
|
|
|
|
DebugParameters debugparam;
|
|
|
|
bool verbose = 0;
|
|
|
|
|
2017-04-11 13:45:11 +05:00
|
|
|
size_t timestamp = 0;
|
|
|
|
/*
|
2009-01-13 04:40:13 +05:00
|
|
|
int GetTimeStamp()
|
|
|
|
{
|
|
|
|
return timestamp;
|
|
|
|
}
|
|
|
|
|
|
|
|
int NextTimeStamp()
|
|
|
|
{
|
|
|
|
timestamp++;
|
|
|
|
return timestamp;
|
|
|
|
}
|
2017-04-11 13:45:11 +05:00
|
|
|
*/
|
2009-01-13 04:40:13 +05:00
|
|
|
}
|