当前位置: 首页>>代码示例>>C++>>正文


C++ QThreadPool::setExpiryTimeout方法代码示例

本文整理汇总了C++中QThreadPool::setExpiryTimeout方法的典型用法代码示例。如果您正苦于以下问题:C++ QThreadPool::setExpiryTimeout方法的具体用法?C++ QThreadPool::setExpiryTimeout怎么用?C++ QThreadPool::setExpiryTimeout使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在QThreadPool的用法示例。


在下文中一共展示了QThreadPool::setExpiryTimeout方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: expiryTimeout

void tst_QThreadPool::expiryTimeout()
{
    ExpiryTimeoutTask task;

    QThreadPool threadPool;
    threadPool.setMaxThreadCount(1);

    int expiryTimeout = threadPool.expiryTimeout();
    threadPool.setExpiryTimeout(1000);
    QCOMPARE(threadPool.expiryTimeout(), 1000);

    // run the task
    threadPool.start(&task);
    QVERIFY(task.semaphore.tryAcquire(1, 10000));
    QCOMPARE(task.runCount, 1);
    QVERIFY(!task.thread->wait(100));
    // thread should expire
    QThread *firstThread = task.thread;
    QVERIFY(task.thread->wait(10000));

    // run task again, thread should be restarted
    threadPool.start(&task);
    QVERIFY(task.semaphore.tryAcquire(1, 10000));
    QCOMPARE(task.runCount, 2);
    QVERIFY(!task.thread->wait(100));
    // thread should expire again
    QVERIFY(task.thread->wait(10000));

    // thread pool should have reused the expired thread (instead of
    // starting a new one)
    QCOMPARE(firstThread, task.thread);

    threadPool.setExpiryTimeout(expiryTimeout);
    QCOMPARE(threadPool.expiryTimeout(), expiryTimeout);
}
开发者ID:,项目名称:,代码行数:35,代码来源:

示例2: trainMulticlass

  void MultithreadedRandomForest::trainMulticlass(boost::shared_ptr<DataFrame> data,
    unsigned int numTrees, unsigned int numFactors, unsigned int nodeSize, double retrain,
    bool balanced)
  {
    try
    {
      std::cerr << "DEBUG MTRF TRAINMULTI" << std::endl;

      data->validateData();

      _trainInputs.data = data;
      _trainInputs.numFactors = numFactors;
      _trainInputs.nodeSize = nodeSize;
      _trainInputs.balanced = balanced;

      _factorLabels = data->getFactorLabels();
      _forest.clear();
      numFactors = std::min<size_t>(data->getActiveFactorCount(), numFactors);
      _numSplitFactors = numFactors;

      if(!data->empty())
      {
        _forest.reserve(numTrees);

        //Initialize the thread pool
        QThreadPool pool;
        pool.setExpiryTimeout(-1);

        QList<boost::shared_ptr<RandomTree> > mapTrees;
        for(unsigned int i = 0; i < numTrees; i++)
        {
          mapTrees.append(boost::shared_ptr<RandomTree>(new RandomTree()));
        }

        QList<boost::shared_ptr<RandomTree> > forestList =
          QtConcurrent::blockingMapped(mapTrees, train);

        for(unsigned int i = 0; i < numTrees; i++)
        {
          _forest.push_back(forestList[i]);
        }

        if(retrain >= 0 && retrain < 1.0)
        {
          std::cout << "Retraining model on top " << (retrain * 100) << "% of factors" << std::endl;
          std::map<std::string, double> topFactors;
          std::map<std::string, double>::iterator mapItr;

          getFactorImportance(data, topFactors);

          std::vector<std::string> badFactors;

          unsigned int cutOffIdx =
            topFactors.size() - (unsigned int)((double)topFactors.size() * retrain);

          std::multimap<double, std::string> sortedFactors;
          std::multimap<double, std::string>::iterator mMapItr;

          //Create a map from lowest to highest of important mapped to factor type
          for(mapItr = topFactors.begin(); mapItr != topFactors.end(); ++mapItr)
          {
            sortedFactors.insert(std::pair<double, std::string>(mapItr->second, mapItr->first));
          }

          unsigned int cutOffCtr = 0;

          for(mMapItr = sortedFactors.begin(); mMapItr != sortedFactors.end(); ++mMapItr)
          {
            if(cutOffCtr <  cutOffIdx)
            {
              badFactors.push_back(mMapItr->second);
              cutOffCtr++;
            }
            else
            {
              break;
            }
          }

          for(unsigned int i = 0; i < badFactors.size(); i++)
          {
            data->deactivateFactor(badFactors[i]);
          }

          _forest.clear();

          _forest.reserve(numTrees);

          _trainInputs.numFactors = (unsigned int)sqrt((double)(topFactors.size() - cutOffIdx));
          _trainInputs.nodeSize = 1;

          QList<boost::shared_ptr<RandomTree> > mapRetrainingTrees;
          for(unsigned int i = 0; i < numTrees; i++)
          {
             mapRetrainingTrees.append(boost::shared_ptr<RandomTree>(new RandomTree()));
          }

          QList<boost::shared_ptr<RandomTree> > forestRetrainList =
            QtConcurrent::blockingMapped(mapRetrainingTrees, train);

//.........这里部分代码省略.........
开发者ID:Nanonid,项目名称:hootenanny,代码行数:101,代码来源:MultithreadedRandomForest.cpp


注:本文中的QThreadPool::setExpiryTimeout方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。