void gpResQueue::ShowTreeDetail(ctlTree *browser, frmMain *form, ctlListView *properties, ctlSQLBox *sqlPane) { if (!expandedKids) { expandedKids = true; wxString queuesquery; queuesquery = wxT("SELECT rolname,\n") wxT(" pg_catalog.shobj_description(r.oid, 'pg_authid') AS description\n"); queuesquery += wxT(" FROM pg_roles r\n") wxT(" JOIN pg_resqueue q ON rolresqueue=q.oid\n") wxT(" WHERE rolresqueue=") + GetOidStr() + wxT("\n") wxT(" ORDER BY rolname"); pgSetIterator queues(GetConnection(), queuesquery); while (queues.RowsLeft()) { wxString queue = queues.GetVal(wxT("rolname")); queuesIn.Add(queue); } } if (properties) { CreateListColumns(properties); properties->AppendItem(_("Name"), GetName()); properties->AppendItem(_("OID"), GetOid()); properties->AppendItem(_("Active threshold"), GetCountLimit()); properties->AppendItem(_("Cost threshold"), GetCostLimit()); properties->AppendItem(_("Ignore threshold"), GetIgnoreCostLimit()); properties->AppendItem(_("Over commit?"), BoolToYesNo(GetOvercommit())); wxString roleList; size_t index; for (index = 0 ; index < queuesIn.GetCount() ; index++) { if (!roleList.IsEmpty()) roleList += wxT(", "); roleList += queuesIn.Item(index); } properties->AppendItem(_("Roles using this"), roleList); properties->AppendItem(_("Comment"), firstLineOnly(GetComment())); } }
bool Context::createQueues() { // Get selected devices from the dev manager const auto devs= devMgr().devices(); const int devCount= devs.count(); if(!devCount) return false; QVector<cl_command_queue> queues(devCount); cl_int err; for(int i=0; i<devCount; i++) { queues[i]= clCreateCommandQueue(_context, devs[i], CL_QUEUE_PROFILING_ENABLE, &err); if(checkCLError(err, "clCreateCommandQueue")) return false; } // Pass the queues to the DeviceManager devMgr().setQueues(queues); return true; }
MojErr ActivityManager::InfoToJson(MojObject& rep) const { MojLogTrace(s_log); MojErr err = MojErrNone; /* Scan the various run queues of the Activity Manager */ MojObject queues(MojObject::TypeArray); for (int i = 0; i < RunQueueMax; i++) { if (!m_runQueue[i].empty()) { MojObject activities(MojObject::TypeArray); std::for_each(m_runQueue[i].begin(), m_runQueue[i].end(), boost::bind(&Activity::PushIdentityJson, _1, boost::ref(activities))); MojObject queue; err = queue.putString(_T("name"), RunQueueNames[i]); MojErrCheck(err); err = queue.put(_T("activities"), activities); MojErrCheck(err); err = queues.push(queue); MojErrCheck(err); } } if (!queues.empty()) { err = rep.put(_T("queues"), queues); MojErrCheck(err); } std::vector<boost::shared_ptr<const Activity> > leaked; std::set_difference( boost::make_transform_iterator(m_idTable.cbegin(), boost::bind<boost::shared_ptr<const Activity> > (&Activity::shared_from_this, _1)), boost::make_transform_iterator(m_idTable.cend(), boost::bind<boost::shared_ptr<const Activity> > (&Activity::shared_from_this, _1)), boost::make_transform_iterator(m_activities.begin(), boost::bind(&ActivityMap::value_type::second, _1)), boost::make_transform_iterator(m_activities.end(), boost::bind(&ActivityMap::value_type::second, _1)), std::back_inserter(leaked)); if (!leaked.empty()) { MojObject leakedActivities(MojObject::TypeArray); std::for_each(leaked.begin(), leaked.end(), boost::bind(&Activity::PushIdentityJson, _1, boost::ref(leakedActivities))); err = rep.put(_T("leakedActivities"), leakedActivities); MojErrCheck(err); } return MojErrNone; }
/** * Takes a subgraph of the given graph (all nodes in the graph with the given label), * partitions this subgraph into even smaller subgraphs (using something similar to k-means), * and gives all small subgraphs a unique label (using the given min_label). * * @param graph * @param label_of_connected_component * @param size_of_largest_partition * @param min_label_for_partition_labeling * @return the number of generated partitions */ std::size_t partition_connected_component(UniGraph * graph, std::size_t label_of_connected_component, std::size_t partition_size, std::size_t min_label_for_partition_labeling) { typedef std::size_t Node; typedef std::size_t Label; typedef std::vector<Node> Nodes; Nodes nodes; for (Node node = 0; node < graph->num_nodes(); ++node) if (graph->get_label(node) == label_of_connected_component) nodes.push_back(node); const std::size_t num_partitions = (nodes.size() + partition_size - 1) / partition_size; // division and rounding up /********* k-means clustering *******/ const std::size_t num_kmeans_iterations = 100; Nodes centroids; /* Draw centroids randomly. */ std::default_random_engine generator; std::uniform_int_distribution<std::size_t> distribution(0, nodes.size() - 1); for(std::size_t partition = 0; partition < num_partitions; ++partition) { Node centroid = std::numeric_limits<Node>::max(); while (std::find(centroids.begin(), centroids.end(), centroid) != centroids.end()) centroid = nodes.at(distribution(generator)); centroids.push_back(centroid); } for (std::size_t kmeans_iteration = 0; kmeans_iteration < num_kmeans_iterations; ++kmeans_iteration) { const Label unvisited = std::numeric_limits<Label>::max(); for (Node const & node : nodes) graph->set_label(node, unvisited); /* Put centroids into queues. */ std::vector<Nodes> queues(num_partitions); for (std::size_t i = 0; i < num_partitions; ++i) queues.at(i).push_back(centroids.at(i)); /* Grow regions starting from centroids */ while (std::any_of(queues.begin(), queues.end(), [](Nodes const & queue){return !queue.empty();})) { #pragma omp parallel for for (std::size_t queue_id = 0; queue_id < queues.size(); ++queue_id) { Nodes & old_queue = queues.at(queue_id); std::unordered_set<Node> new_queue; for (Node node : old_queue) graph->set_label(node, min_label_for_partition_labeling + queue_id); // there is a race condition for partition boundary nodes but we don't care for (Node node : old_queue) { /* Copy all unvisited (and not yet inserted) neighbors into new queue. */ for (Node neighbor : graph->get_adj_nodes(node)) if (graph->get_label(neighbor) == unvisited) new_queue.insert(neighbor); } old_queue.clear(); old_queue.insert(old_queue.begin(), new_queue.begin(), new_queue.end()); } } /* If we are in the final iteration we stop here to keep the graph labels * (they would be removed in the following region shrinking step). */ if (kmeans_iteration == num_kmeans_iterations - 1) break; /* Put partition boundary nodes into queues. */ for (Node const node : nodes) { Label const cur_label = graph->get_label(node); std::size_t const cur_queue = cur_label - min_label_for_partition_labeling; Nodes const & neighbors = graph->get_adj_nodes(node); /* Each node, where any of its neighbors has a different label, is a boundary node. */ if (std::any_of(neighbors.begin(), neighbors.end(), [graph, cur_label] (Node const neighbor) { return graph->get_label(neighbor) != cur_label; } )) queues.at(cur_queue).push_back(node); } /* Shrink regions starting from boundaries to obtain new centroids. */ #pragma omp parallel for for (std::size_t queue_id = 0; queue_id < queues.size(); ++queue_id) { Nodes & old_queue = queues.at(queue_id); while (!old_queue.empty()){ std::unordered_set<Node> new_queue; for (Node node : old_queue) graph->set_label(node, unvisited); for (Node node : old_queue) { /* Copy all neighbors that have not yet been marked (and have not yet been inserted) into new queue. */ for (Node neighbor : graph->get_adj_nodes(node)) if (graph->get_label(neighbor) == min_label_for_partition_labeling + queue_id) new_queue.insert(neighbor); } /* If the new queue is empty we are (almost) finished and use a random node from the old queue as new centroid. */ if (new_queue.empty()) { std::uniform_int_distribution<std::size_t> distribution(0, old_queue.size() - 1); centroids.at(queue_id) = old_queue.at(distribution(generator)); } /* Replace old queue with new one. */ old_queue.clear(); old_queue.insert(old_queue.begin(), new_queue.begin(), new_queue.end()); } } } return num_partitions; }
/** * With this let us go right to main(): **/ int main() { typedef float ScalarType; /** * <h2>Part 1: Set up a custom context</h2> * * The following is rather lengthy because OpenCL is a fairly low-level framework. * For comparison, the subsequent code explicitly performs the OpenCL setup that is done * in the background within the 'custom_kernels'-tutorial **/ //manually set up a custom OpenCL context: std::vector<cl_device_id> device_id_array; //get all available devices viennacl::ocl::platform pf; std::cout << "Platform info: " << pf.info() << std::endl; std::vector<viennacl::ocl::device> devices = pf.devices(CL_DEVICE_TYPE_DEFAULT); std::cout << devices[0].name() << std::endl; std::cout << "Number of devices for custom context: " << devices.size() << std::endl; //set up context using all found devices: for (std::size_t i=0; i<devices.size(); ++i) { device_id_array.push_back(devices[i].id()); } std::cout << "Creating context..." << std::endl; cl_int err; cl_context my_context = clCreateContext(0, cl_uint(device_id_array.size()), &(device_id_array[0]), NULL, NULL, &err); VIENNACL_ERR_CHECK(err); //create two Vectors: unsigned int vector_size = 10; std::vector<ScalarType> vec1(vector_size); std::vector<ScalarType> vec2(vector_size); std::vector<ScalarType> result(vector_size); // // fill the operands vec1 and vec2: // for (unsigned int i=0; i<vector_size; ++i) { vec1[i] = static_cast<ScalarType>(i); vec2[i] = static_cast<ScalarType>(vector_size-i); } // // create memory in OpenCL context: // cl_mem mem_vec1 = clCreateBuffer(my_context, CL_MEM_READ_WRITE | CL_MEM_COPY_HOST_PTR, vector_size * sizeof(ScalarType), &(vec1[0]), &err); VIENNACL_ERR_CHECK(err); cl_mem mem_vec2 = clCreateBuffer(my_context, CL_MEM_READ_WRITE | CL_MEM_COPY_HOST_PTR, vector_size * sizeof(ScalarType), &(vec2[0]), &err); VIENNACL_ERR_CHECK(err); cl_mem mem_result = clCreateBuffer(my_context, CL_MEM_READ_WRITE | CL_MEM_COPY_HOST_PTR, vector_size * sizeof(ScalarType), &(result[0]), &err); VIENNACL_ERR_CHECK(err); // // create a command queue for each device: // std::vector<cl_command_queue> queues(devices.size()); for (std::size_t i=0; i<devices.size(); ++i) { queues[i] = clCreateCommandQueue(my_context, devices[i].id(), 0, &err); VIENNACL_ERR_CHECK(err); } // // create and build a program in the context: // std::size_t source_len = std::string(my_compute_program).length(); cl_program my_prog = clCreateProgramWithSource(my_context, 1, &my_compute_program, &source_len, &err); err = clBuildProgram(my_prog, 0, NULL, NULL, NULL, NULL); /* char buffer[1024]; cl_build_status status; clGetProgramBuildInfo(my_prog, devices[1].id(), CL_PROGRAM_BUILD_STATUS, sizeof(cl_build_status), &status, NULL); clGetProgramBuildInfo(my_prog, devices[1].id(), CL_PROGRAM_BUILD_LOG, sizeof(char)*1024, &buffer, NULL); std::cout << "Build Scalar: Err = " << err << " Status = " << status << std::endl; std::cout << "Log: " << buffer << std::endl;*/ VIENNACL_ERR_CHECK(err); // // create a kernel from the program: // const char * kernel_name = "elementwise_prod"; cl_kernel my_kernel = clCreateKernel(my_prog, kernel_name, &err); VIENNACL_ERR_CHECK(err); // // Execute elementwise_prod kernel on first queue: result = vec1 .* vec2; // err = clSetKernelArg(my_kernel, 0, sizeof(cl_mem), (void*)&mem_vec1); VIENNACL_ERR_CHECK(err); err = clSetKernelArg(my_kernel, 1, sizeof(cl_mem), (void*)&mem_vec2); VIENNACL_ERR_CHECK(err); err = clSetKernelArg(my_kernel, 2, sizeof(cl_mem), (void*)&mem_result); VIENNACL_ERR_CHECK(err); err = clSetKernelArg(my_kernel, 3, sizeof(unsigned int), (void*)&vector_size); VIENNACL_ERR_CHECK(err); std::size_t global_size = vector_size; std::size_t local_size = vector_size; err = clEnqueueNDRangeKernel(queues[0], my_kernel, 1, NULL, &global_size, &local_size, 0, NULL, NULL); VIENNACL_ERR_CHECK(err); // // Read and output result: // err = clEnqueueReadBuffer(queues[0], mem_vec1, CL_TRUE, 0, sizeof(ScalarType)*vector_size, &(vec1[0]), 0, NULL, NULL); VIENNACL_ERR_CHECK(err); err = clEnqueueReadBuffer(queues[0], mem_result, CL_TRUE, 0, sizeof(ScalarType)*vector_size, &(result[0]), 0, NULL, NULL); VIENNACL_ERR_CHECK(err); std::cout << "vec1 : "; for (std::size_t i=0; i<vec1.size(); ++i) std::cout << vec1[i] << " "; std::cout << std::endl; std::cout << "vec2 : "; for (std::size_t i=0; i<vec2.size(); ++i) std::cout << vec2[i] << " "; std::cout << std::endl; std::cout << "result: "; for (std::size_t i=0; i<result.size(); ++i) std::cout << result[i] << " "; std::cout << std::endl; /** * <h2>Part 2: Reuse Custom OpenCL Context with ViennaCL</h2> * * To let ViennaCL reuse the previously created context, we need to make it known to ViennaCL \em before any ViennaCL objects are created. * We inject the custom context as the context with default id '0' when using viennacl::ocl::switch_context(). **/ viennacl::ocl::setup_context(0, my_context, device_id_array, queues); viennacl::ocl::switch_context(0); //activate the new context (only mandatory with context-id not equal to zero) /** * Check that ViennaCL really uses the new context: **/ std::cout << "Existing context: " << my_context << std::endl; std::cout << "ViennaCL uses context: " << viennacl::ocl::current_context().handle().get() << std::endl; /** * Wrap existing OpenCL objects into ViennaCL: **/ viennacl::vector<ScalarType> vcl_vec1(mem_vec1, vector_size); viennacl::vector<ScalarType> vcl_vec2(mem_vec2, vector_size); viennacl::vector<ScalarType> vcl_result(mem_result, vector_size); viennacl::scalar<ScalarType> vcl_s = 2.0; std::cout << "Standard vector operations within ViennaCL:" << std::endl; vcl_result = vcl_s * vcl_vec1 + vcl_vec2; std::cout << "vec1 : "; std::cout << vcl_vec1 << std::endl; std::cout << "vec2 : "; std::cout << vcl_vec2 << std::endl; std::cout << "result: "; std::cout << vcl_result << std::endl; /** * We can also reuse the existing elementwise_prod kernel. * Therefore, we first have to make the existing program known to ViennaCL * For more details on the three lines, see tutorial 'custom-kernels' **/ std::cout << "Using existing kernel within the OpenCL backend of ViennaCL:" << std::endl; viennacl::ocl::program & my_vcl_prog = viennacl::ocl::current_context().add_program(my_prog, "my_compute_program"); viennacl::ocl::kernel & my_vcl_kernel = my_vcl_prog.add_kernel(my_kernel, "elementwise_prod"); viennacl::ocl::enqueue(my_vcl_kernel(vcl_vec1, vcl_vec2, vcl_result, static_cast<cl_uint>(vcl_vec1.size()))); //Note that std::size_t might differ between host and device. Thus, a cast to cl_uint is necessary here. std::cout << "vec1 : "; std::cout << vcl_vec1 << std::endl; std::cout << "vec2 : "; std::cout << vcl_vec2 << std::endl; std::cout << "result: "; std::cout << vcl_result << std::endl; /** * Since a linear piece of memory can be interpreted in several ways, * we will now create a 3x3 row-major matrix out of the linear memory in mem_vec1/ * The first three entries in vcl_vec2 and vcl_result are used to carry out matrix-vector products: **/ viennacl::matrix<ScalarType> vcl_matrix(mem_vec1, 3, 3); vcl_vec2.resize(3); //note that the resize operation leads to new memory, thus vcl_vec2 is now at a different memory location (values are copied) vcl_result.resize(3); //note that the resize operation leads to new memory, thus vcl_vec2 is now at a different memory location (values are copied) vcl_result = viennacl::linalg::prod(vcl_matrix, vcl_vec2); std::cout << "result of matrix-vector product: "; std::cout << vcl_result << std::endl; /** * Any further operations can be carried out in the same way. * Just keep in mind that any resizing of vectors or matrices leads to a reallocation of the underlying memory buffer, through which the 'wrapper' is lost. **/ std::cout << "!!!! TUTORIAL COMPLETED SUCCESSFULLY !!!!" << std::endl; return EXIT_SUCCESS; }