本文整理匯總了C++中GMX_ASSERT函數的典型用法代碼示例。如果您正苦於以下問題:C++ GMX_ASSERT函數的具體用法?C++ GMX_ASSERT怎麽用?C++ GMX_ASSERT使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了GMX_ASSERT函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: context_
SessionImpl::SessionImpl(std::shared_ptr<ContextImpl> context,
gmx::MdrunnerBuilder &&runnerBuilder,
const gmx::SimulationContext &simulationContext,
gmx::LogFilePtr fplog,
gmx_multisim_t * multiSim) :
context_(std::move(context)),
mpiContextManager_(std::make_unique<MpiContextManager>()),
simulationContext_(simulationContext),
logFilePtr_(std::move(fplog)),
multiSim_(multiSim)
{
GMX_ASSERT(context_, "SessionImpl invariant implies valid ContextImpl handle.");
GMX_ASSERT(mpiContextManager_, "SessionImpl invariant implies valid MpiContextManager guard.");
GMX_ASSERT(simulationContext_.communicationRecord_, "SessionImpl invariant implies valid commrec.");
GMX_UNUSED_VALUE(multiSim_);
GMX_UNUSED_VALUE(simulationContext_);
// \todo Session objects can have logic specialized for the runtime environment.
auto stopHandlerBuilder = std::make_unique<gmx::StopHandlerBuilder>();
signalManager_ = std::make_unique<SignalManager>(stopHandlerBuilder.get());
GMX_ASSERT(signalManager_, "SessionImpl invariant includes a valid SignalManager.");
runnerBuilder.addStopHandlerBuilder(std::move(stopHandlerBuilder));
runner_ = std::make_unique<gmx::Mdrunner>(runnerBuilder.build());
GMX_ASSERT(runner_, "SessionImpl invariant implies valid Mdrunner handle.");
// For the libgromacs context, a session should explicitly reset global variables that could
// have been set in a previous simulation during the same process.
gmx_reset_stop_condition();
}
示例2: gmx_ana_pos_copy
/*!
* \param[in,out] dest Destination positions.
* \param[in] src Source positions.
* \param[in] bFirst If true, memory is allocated for \p dest and a full
* copy is made; otherwise, only variable parts are copied, and no memory
* is allocated.
*
* \p dest should have been initialized somehow (calloc() is enough).
*/
void
gmx_ana_pos_copy(gmx_ana_pos_t *dest, gmx_ana_pos_t *src, bool bFirst)
{
if (bFirst)
{
gmx_ana_pos_reserve(dest, src->count(), 0);
if (src->v)
{
gmx_ana_pos_reserve_velocities(dest);
}
if (src->f)
{
gmx_ana_pos_reserve_forces(dest);
}
}
memcpy(dest->x, src->x, src->count()*sizeof(*dest->x));
if (dest->v)
{
GMX_ASSERT(src->v, "src velocities should be non-null if dest velocities are allocated");
memcpy(dest->v, src->v, src->count()*sizeof(*dest->v));
}
if (dest->f)
{
GMX_ASSERT(src->f, "src forces should be non-null if dest forces are allocated");
memcpy(dest->f, src->f, src->count()*sizeof(*dest->f));
}
gmx_ana_indexmap_copy(&dest->m, &src->m, bFirst);
}
示例3: nbnxn_ocl_clear_e_fshift
/*! \brief Clears nonbonded shift force output array and energy outputs on the GPU.
*/
static void
nbnxn_ocl_clear_e_fshift(gmx_nbnxn_ocl_t *nb)
{
cl_int cl_error;
cl_atomdata_t * adat = nb->atdat;
cl_command_queue ls = nb->stream[eintLocal];
size_t local_work_size[3] = {1, 1, 1};
size_t global_work_size[3] = {1, 1, 1};
cl_int shifts = SHIFTS*3;
cl_int arg_no;
cl_kernel zero_e_fshift = nb->kernel_zero_e_fshift;
local_work_size[0] = 64;
// Round the total number of threads up from the array size
global_work_size[0] = ((shifts + local_work_size[0] - 1)/local_work_size[0])*local_work_size[0];
arg_no = 0;
cl_error = clSetKernelArg(zero_e_fshift, arg_no++, sizeof(cl_mem), &(adat->fshift));
cl_error |= clSetKernelArg(zero_e_fshift, arg_no++, sizeof(cl_mem), &(adat->e_lj));
cl_error |= clSetKernelArg(zero_e_fshift, arg_no++, sizeof(cl_mem), &(adat->e_el));
cl_error |= clSetKernelArg(zero_e_fshift, arg_no++, sizeof(cl_uint), &shifts);
GMX_ASSERT(cl_error == CL_SUCCESS, ocl_get_error_string(cl_error).c_str());
cl_error = clEnqueueNDRangeKernel(ls, zero_e_fshift, 3, nullptr, global_work_size, local_work_size, 0, nullptr, nullptr);
GMX_ASSERT(cl_error == CL_SUCCESS, ocl_get_error_string(cl_error).c_str());
}
示例4: header_
AnalysisDataPointSetRef::AnalysisDataPointSetRef(
const AnalysisDataPointSetRef &points, int firstColumn, int columnCount)
: header_(points.header()), dataSetIndex_(points.dataSetIndex()),
firstColumn_(0)
{
GMX_ASSERT(firstColumn >= 0, "Invalid first column");
GMX_ASSERT(columnCount >= 0, "Invalid column count");
if (points.lastColumn() < firstColumn
|| points.firstColumn() >= firstColumn + columnCount
|| columnCount == 0)
{
return;
}
AnalysisDataValuesRef::const_iterator begin = points.values().begin();
int pointsOffset = firstColumn - points.firstColumn();
if (pointsOffset > 0)
{
// Offset pointer if the first column is not the first in points.
begin += pointsOffset;
}
else
{
// Take into account if first column is before the first in points.
firstColumn_ = -pointsOffset;
columnCount -= -pointsOffset;
}
// Decrease column count if there are not enough columns in points.
AnalysisDataValuesRef::const_iterator end = begin + columnCount;
if (pointsOffset + columnCount > points.columnCount())
{
end = points.values().end();
}
values_ = AnalysisDataValuesRef(begin, end);
}
示例5: GMX_ASSERT
void
AnalysisDataModuleManager::notifyPointsAdd(const AnalysisDataPointSetRef &points) const
{
GMX_ASSERT(impl_->state_ == Impl::eInFrame, "notifyFrameStart() not called");
// TODO: Add checks for column spans (requires passing the information
// about the column counts from somewhere).
//GMX_ASSERT(points.lastColumn() < columnCount(points.dataSetIndex()),
// "Invalid columns");
GMX_ASSERT(points.frameIndex() == impl_->currIndex_,
"Points do not correspond to current frame");
if (impl_->bSerialModules_)
{
if (!impl_->bAllowMissing_ && !points.allPresent())
{
GMX_THROW(APIError("Missing data not supported by a module"));
}
Impl::ModuleList::const_iterator i;
for (i = impl_->modules_.begin(); i != impl_->modules_.end(); ++i)
{
if (!i->bParallel)
{
i->module->pointsAdded(points);
}
}
}
}
示例6: GMX_ASSERT
static gmx_pme_t *gmx_pmeonly_switch(std::vector<gmx_pme_t *> *pmedata,
const ivec grid_size,
real ewaldcoeff_q, real ewaldcoeff_lj,
const t_commrec *cr, const t_inputrec *ir)
{
GMX_ASSERT(pmedata, "Bad PME tuning list pointer");
for (auto &pme : *pmedata)
{
GMX_ASSERT(pme, "Bad PME tuning list element pointer");
if (pme->nkx == grid_size[XX] &&
pme->nky == grid_size[YY] &&
pme->nkz == grid_size[ZZ])
{
/* Here we have found an existing PME data structure that suits us.
* However, in the GPU case, we have to reinitialize it - there's only one GPU structure.
* This should not cause actual GPU reallocations, at least (the allocated buffers are never shrunk).
* So, just some grid size updates in the GPU kernel parameters.
* TODO: this should be something like gmx_pme_update_split_params()
*/
gmx_pme_reinit(&pme, cr, pme, ir, grid_size, ewaldcoeff_q, ewaldcoeff_lj);
return pme;
}
}
const auto &pme = pmedata->back();
gmx_pme_t *newStructure = nullptr;
// Copy last structure with new grid params
gmx_pme_reinit(&newStructure, cr, pme, ir, grid_size, ewaldcoeff_q, ewaldcoeff_lj);
pmedata->push_back(newStructure);
return newStructure;
}
示例7: ddCloseBalanceRegionGpu
void ddCloseBalanceRegionGpu(const gmx_domdec_t *dd,
float waitGpuCyclesInCpuRegion,
DdBalanceRegionWaitedForGpu waitedForGpu)
{
BalanceRegion *reg = getBalanceRegion(dd);
if (reg->isOpen)
{
GMX_ASSERT(reg->isOpenOnGpu, "Can not close a non-open GPU balance region");
GMX_ASSERT(!reg->isOpenOnCpu, "The GPU region should be closed after closing the CPU region");
float waitGpuCyclesEstimate = gmx_cycles_read() - reg->cyclesLastCpu;
if (waitedForGpu == DdBalanceRegionWaitedForGpu::no)
{
/* The actual time could be anywhere between 0 and
* waitCyclesEstimate. Using half is the best we can do.
*/
const float unknownWaitEstimateFactor = 0.5f;
waitGpuCyclesEstimate *= unknownWaitEstimateFactor;
}
float cyclesCpu = reg->cyclesLastCpu - reg->cyclesOpenCpu;
dd_cycles_add(dd, cyclesCpu + waitGpuCyclesEstimate, ddCyclF);
/* Register the total GPU wait time, to redistribute with GPU sharing */
dd_cycles_add(dd, waitGpuCyclesInCpuRegion + waitGpuCyclesEstimate, ddCyclWaitGPU);
/* Close the region */
reg->isOpenOnGpu = false;
reg->isOpen = false;
}
}
示例8: GMX_ASSERT
void
AbstractAnalysisData::notifyPointsAdd(int firstcol, int n,
const real *y, const real *dy,
const bool *present) const
{
GMX_ASSERT(_impl->_bInData, "notifyDataStart() not called");
GMX_ASSERT(_impl->_bInFrame, "notifyFrameStart() not called");
GMX_ASSERT(firstcol >= 0 && n > 0 && firstcol + n <= _ncol, "Invalid column");
if (present && !_impl->_bAllowMissing)
{
for (int i = 0; i < n; ++i)
{
if (!present[i])
{
GMX_THROW(APIError("Missing data not supported by a module"));
}
}
}
Impl::ModuleList::const_iterator i;
for (i = _impl->_modules.begin(); i != _impl->_modules.end(); ++i)
{
(*i)->pointsAdded(_impl->_currx, _impl->_currdx, firstcol, n,
y, dy, present);
}
}
示例9: GMX_ASSERT
/*! \brief Returns the pointer to the balance region.
*
* This should be replaced by a properly managed BalanceRegion class,
* but that requires a lot of refactoring in domdec.cpp.
*/
static BalanceRegion *getBalanceRegion(const gmx_domdec_t *dd)
{
GMX_ASSERT(dd != nullptr && dd->comm != nullptr, "Balance regions should only be used with DD");
BalanceRegion *region = dd->comm->balanceRegion;
GMX_ASSERT(region != nullptr, "Balance region should be initialized before use");
return region;
}
示例10: ColumnData
ColumnData(const char *title, int width, bool bWrap)
: title_(title != NULL ? title : ""),
width_(width), bWrap_(bWrap), firstLine_(0)
{
GMX_ASSERT(width >= 0, "Negative width not possible");
GMX_ASSERT(title_.length() <= static_cast<size_t>(width),
"Title too long for column width");
}
示例11: header_
AnalysisDataPointSetRef::AnalysisDataPointSetRef(
const AnalysisDataFrameHeader &header, int firstColumn,
const AnalysisDataValuesRef &values)
: header_(header), firstColumn_(firstColumn), values_(values)
{
GMX_ASSERT(header_.isValid(),
"Invalid point set reference should not be constructed");
GMX_ASSERT(firstColumn >= 0, "Invalid first column");
}
示例12: GMX_ASSERT
void HistogramSize::setHistogramSize(double histogramSize,
double weightHistogramScalingFactor)
{
GMX_ASSERT(histogramSize > 0, "The histogram should not be empty");
GMX_ASSERT(weightHistogramScalingFactor > 0, "The histogram scaling factor should be positive");
histogramSize_ = histogramSize;
/* The weight of new samples relative to previous ones change
* when the histogram is rescaled. We keep the log since this number
* can become very large.
*/
logScaledSampleWeight_ -= std::log(weightHistogramScalingFactor);
};
示例13: pme_gpu_launch_spread
void pme_gpu_launch_spread(gmx_pme_t *pme,
const rvec *x,
gmx_wallcycle *wcycle)
{
GMX_ASSERT(pme_gpu_active(pme), "This should be a GPU run of PME but it is not enabled.");
PmeGpu *pmeGpu = pme->gpu;
// The only spot of PME GPU where LAUNCH_GPU counter increases call-count
wallcycle_start(wcycle, ewcLAUNCH_GPU);
// The only spot of PME GPU where ewcsLAUNCH_GPU_PME subcounter increases call-count
wallcycle_sub_start(wcycle, ewcsLAUNCH_GPU_PME);
pme_gpu_copy_input_coordinates(pmeGpu, x);
wallcycle_sub_stop(wcycle, ewcsLAUNCH_GPU_PME);
wallcycle_stop(wcycle, ewcLAUNCH_GPU);
const unsigned int gridIndex = 0;
real *fftgrid = pme->fftgrid[gridIndex];
if (pmeGpu->settings.currentFlags & GMX_PME_SPREAD)
{
/* Spread the coefficients on a grid */
const bool computeSplines = true;
const bool spreadCharges = true;
wallcycle_start_nocount(wcycle, ewcLAUNCH_GPU);
wallcycle_sub_start_nocount(wcycle, ewcsLAUNCH_GPU_PME);
pme_gpu_spread(pmeGpu, gridIndex, fftgrid, computeSplines, spreadCharges);
wallcycle_sub_stop(wcycle, ewcsLAUNCH_GPU_PME);
wallcycle_stop(wcycle, ewcLAUNCH_GPU);
}
}
示例14: GMX_RELEASE_ASSERT
void TopologyManager::loadTopology(const char *filename)
{
bool fullTopology;
int ePBC;
rvec *xtop = nullptr;
matrix box;
GMX_RELEASE_ASSERT(mtop_ == nullptr, "Topology initialized more than once");
mtop_ = gmx::compat::make_unique<gmx_mtop_t>();
readConfAndTopology(
gmx::test::TestFileManager::getInputFilePath(filename).c_str(),
&fullTopology, mtop_.get(), &ePBC, frame_ != nullptr ? &xtop : nullptr,
nullptr, box);
if (frame_ != nullptr)
{
GMX_ASSERT(xtop != nullptr, "Keep the static analyzer happy");
frame_->natoms = mtop_->natoms;
frame_->bX = TRUE;
snew(frame_->x, frame_->natoms);
std::memcpy(frame_->x, xtop, sizeof(*frame_->x) * frame_->natoms);
frame_->bBox = TRUE;
copy_mat(box, frame_->box);
}
sfree(xtop);
}
示例15: next_group_index
/*! \brief
* Helper for splitting a sequence of atom indices into groups.
*
* \param[in] atomIndex Index of the next atom in the sequence.
* \param[in] top Topology structure.
* \param[in] type Type of group to split into.
* \param[in,out] id Variable to receive the next group id.
* \returns `true` if \p atomIndex starts a new group in the sequence, i.e.,
* if \p *id was changed.
*
* \p *id should be initialized to `-1` before first call of this function, and
* then each atom index in the sequence passed to the function in turn.
*
* \ingroup module_selection
*/
static bool
next_group_index(int atomIndex, t_topology *top, e_index_t type, int *id)
{
int prev = *id;
switch (type)
{
case INDEX_ATOM:
*id = atomIndex;
break;
case INDEX_RES:
*id = top->atoms.atom[atomIndex].resind;
break;
case INDEX_MOL:
if (*id >= 0 && top->mols.index[*id] > atomIndex)
{
*id = 0;
}
while (*id < top->mols.nr && atomIndex >= top->mols.index[*id+1])
{
++*id;
}
GMX_ASSERT(*id < top->mols.nr, "Molecules do not span all the atoms");
break;
case INDEX_UNKNOWN:
case INDEX_ALL:
*id = 0;
break;
}
return prev != *id;
}