本文整理汇总了C++中EngngModel::restoreContext方法的典型用法代码示例。如果您正苦于以下问题:C++ EngngModel::restoreContext方法的具体用法?C++ EngngModel::restoreContext怎么用?C++ EngngModel::restoreContext使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类EngngModel
的用法示例。
在下文中一共展示了EngngModel::restoreContext方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: main
//.........这里部分代码省略.........
}
#if defined ( __PETSC_MODULE ) || defined ( __SLEPC_MODULE )
int modulesArgc = modulesArgs.size();
char **modulesArgv = const_cast< char ** >(& modulesArgs [ 0 ]);
#endif
#ifdef __PETSC_MODULE
PetscInitialize(& modulesArgc, & modulesArgv, PETSC_NULL, PETSC_NULL);
#endif
#ifdef __SLEPC_MODULE
SlepcInitialize(& modulesArgc, & modulesArgv, PETSC_NULL, PETSC_NULL);
#endif
#ifdef __PYTHON_MODULE
Py_Initialize();
// Adding . to the system path allows us to run Python functions stored in the working directory.
PyRun_SimpleString("import sys");
PyRun_SimpleString("sys.path.append(\".\")");
#endif
#ifdef __PARALLEL_MODE
if ( parallelFlag ) {
inputFileName << "." << rank;
outputFileName << "." << rank;
errOutputFileName << "." << rank;
}
#endif
if ( outputFileFlag ) {
oofem_logger.appendLogTo( outputFileName.str() );
}
if ( errOutputFileFlag ) {
oofem_logger.appendErrorTo( errOutputFileName.str() );
}
// print header to redirected output
OOFEM_LOG_FORCED(PRG_HEADER_SM);
OOFEMTXTDataReader dr( inputFileName.str() );
EngngModel *problem = :: InstanciateProblem(dr, _processor, contextFlag, NULL, parallelFlag);
dr.finish();
if ( !problem ) {
OOFEM_LOG_ERROR("Couldn't instanciate problem, exiting");
exit(EXIT_FAILURE);
}
problem->checkProblemConsistency();
problem->init();
if ( renumberFlag ) {
problem->setRenumberFlag();
}
if ( restartFlag ) {
try {
FileDataStream stream(problem->giveContextFileName(restartStep, 0), false);
problem->restoreContext(stream, CM_State | CM_Definition);
} catch ( const FileDataStream::CantOpen & e ) {
printf("%s", e.what());
exit(1);
} catch ( ContextIOERR & c ) {
c.print();
exit(1);
}
problem->initStepIncrements();
} else if ( adaptiveRestartFlag ) {
problem->initializeAdaptive(adaptiveRestartFlag);
problem->saveStepContext(problem->giveCurrentStep(),CM_State);
// exit (1);
}
if ( debugFlag ) {
oofem_debug(problem);
}
try {
problem->solveYourself();
} catch(OOFEM_Terminate & c) {
delete problem;
oofem_finalize_modules();
return 1;
}
problem->terminateAnalysis();
#ifdef __PARALLEL_MODE
if ( parallelFlag ) {
DynamicCommunicationBuffer :: printInfo();
}
#endif
oofem_logger.printStatistics();
delete problem;
oofem_finalize_modules();
return 0;
}