本文整理汇总了C++中variables_map::count方法的典型用法代码示例。如果您正苦于以下问题:C++ variables_map::count方法的具体用法?C++ variables_map::count怎么用?C++ variables_map::count使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类variables_map
的用法示例。
在下文中一共展示了variables_map::count方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: load_As_and_T
/// \brief Load a tree and a collection of alignments based on command line parameters.
///
/// \param args The command line parameters.
/// \param alignments The alignments.
/// \param T The leaf-labelled tree.
/// \param internal_sequences Should each resulting alignment have sequences for internal nodes on the tree?
///
void load_As_and_T(const variables_map& args,vector<alignment>& alignments,RootedSequenceTree& T,const vector<bool>& internal_sequences)
{
alignments = load_As(args);
T = load_T(args);
link(alignments,T,internal_sequences);
for(int i=0;i<alignments.size();i++)
{
//---------------- Randomize alignment? -----------------//
if (args.count("randomize-alignment"))
alignments[i] = randomize(alignments[i],T.n_leaves());
//------------------ Analyze 'internal'------------------//
if ((args.count("internal") and args["internal"].as<string>() == "+")
or args.count("randomize-alignment"))
for(int column=0;column< alignments[i].length();column++) {
for(int j=T.n_leaves();j<alignments[i].n_sequences();j++)
alignments[i](column,j) = alphabet::not_gap;
}
//---- Check that internal sequence satisfy constraints ----//
check_alignment(alignments[i],T,internal_sequences[i]);
}
}
示例2: load_As_and_random_T
/// \brief Load a collection of alignments based on command line parameters and generate a random tree.
///
/// \param args The command line parameters.
/// \param alignments The alignments.
/// \param T The leaf-labelled tree.
/// \param internal_sequences Should each resulting alignment have sequences for internal nodes on the tree?
///
void load_As_and_random_T(const variables_map& args,vector<alignment>& alignments,SequenceTree& T,const vector<bool>& internal_sequences)
{
alignments = load_As(args);
//------------- Load random tree ------------------------//
SequenceTree TC = star_tree(sequence_names(alignments[0]));
if (args.count("t-constraint"))
TC = load_constraint_tree(args["t-constraint"].as<string>(),sequence_names(alignments[0]));
T = TC;
RandomTree(T,1.0);
//-------------- Link --------------------------------//
link(alignments,T,internal_sequences);
//---------------process----------------//
for(int i=0;i<alignments.size();i++)
{
//---------------- Randomize alignment? -----------------//
if (args.count("randomize-alignment"))
alignments[i] = randomize(alignments[i],T.n_leaves());
//------------------ Analyze 'internal'------------------//
if ((args.count("internal") and args["internal"].as<string>() == "+")
or args.count("randomize-alignment"))
for(int column=0;column< alignments[i].length();column++) {
for(int j=T.n_leaves();j<alignments[i].n_sequences();j++)
alignments[i](column,j) = alphabet::not_gap;
}
//---- Check that internal sequence satisfy constraints ----//
check_alignment(alignments[i],T,internal_sequences[i]);
}
}
示例3: hpx_main
int hpx_main(variables_map& vm)
{
std::size_t pxthreads = 0;
if (vm.count("pxthreads"))
pxthreads = vm["pxthreads"].as<std::size_t>();
std::size_t iterations = 0;
if (vm.count("iterations"))
iterations = vm["iterations"].as<std::size_t>();
for (std::size_t i = 0; i < iterations; ++i)
{
// create a barrier waiting on 'count' threads
barrier b(pxthreads + 1);
boost::atomic<std::size_t> c(0);
// create the threads which will wait on the barrier
for (std::size_t i = 0; i < pxthreads; ++i)
register_work(hpx::util::bind
(&local_barrier_test, std::ref(b), std::ref(c)));
b.wait(); // wait for all threads to enter the barrier
HPX_TEST_EQ(pxthreads, c);
}
// initiate shutdown of the runtime system
finalize();
return 0;
}
示例4: hpx_main
int hpx_main(variables_map& vm)
{
std::size_t pxthreads = 0;
if (vm.count("pxthreads"))
pxthreads = vm["pxthreads"].as<std::size_t>();
std::size_t iterations = 0;
if (vm.count("iterations"))
iterations = vm["iterations"].as<std::size_t>();
std::size_t suspend_duration = 0;
if (vm.count("suspend-duration"))
suspend_duration = vm["suspend-duration"].as<std::size_t>();
{
barrier b(pxthreads + 1);
// Create the hpx-threads.
for (std::size_t i = 0; i < pxthreads; ++i)
register_work(boost::bind
(&suspend_test, boost::ref(b), iterations, suspend_duration));
b.wait(); // Wait for all hpx-threads to enter the barrier.
}
// Initiate shutdown of the runtime system.
return finalize();
}
示例5: check_options
// checks options for sanity; returns true if papi component is needed
bool check_options(variables_map const& vm)
{
bool needed = need_papi_component(vm);
if (vm.count("hpx:papi-event-info"))
{
std::string v = vm["hpx:papi-event-info"].as<std::string>();
if (v != "preset" && v != "native" && v != "all")
HPX_THROW_EXCEPTION(hpx::commandline_option_error,
NS_STR "check_options()",
"unsupported mode "+v+" in --hpx:papi-event-info");
}
if (vm.count("hpx:papi-domain"))
{
std::string v = vm["hpx:papi-domain"].as<std::string>();
int dom = map_domain(v); // throws if not found
papi_call(PAPI_set_domain(dom),
"could not switch to \""+v+"\" domain monitoring",
NS_STR "check_options()");
needed = true;
}
// FIXME: implement multiplexing properly and uncomment below when done
if (vm.count("hpx:papi-multiplex"))
HPX_THROW_EXCEPTION(hpx::not_implemented,
NS_STR "check_options()",
"counter multiplexing is currently not supported");
#if 0
if (vm.count("hpx:papi-multiplex") && vm["hpx:papi-multiplex"].as<long>() < 0)
HPX_THROW_EXCEPTION(hpx::commandline_option_error,
NS_STR "check_options()",
"argument to --hpx:papi-multiplex must be positive");
#endif
return needed;
}
示例6: load_A_and_random_T
/// \brief Load an alignment based on command line parameters and generate a random tree.
///
/// \param args The command line parameters.
/// \param alignments The alignments.
/// \param T The leaf-labelled tree.
/// \param internal_sequences Should each resulting alignment have sequences for internal nodes on the tree?
///
void load_A_and_random_T(const variables_map& args,alignment& A,SequenceTree& T,bool internal_sequences)
{
// NO internal sequences, yet!
A = load_A(args,internal_sequences);
//------------- Load random tree ------------------------//
SequenceTree TC = star_tree(sequence_names(A));
if (args.count("t-constraint"))
TC = load_constraint_tree(args["t-constraint"].as<string>(),sequence_names(A));
T = TC;
RandomTree(T,1.0);
//------------- Link Alignment and Tree -----------------//
link(A,T,internal_sequences);
//---------------- Randomize alignment? -----------------//
if (args.count("randomize-alignment"))
A = randomize(A,T.n_leaves());
//------------------ Analyze 'internal'------------------//
if ((args.count("internal") and args["internal"].as<string>() == "+")
or args.count("randomize-alignment"))
for(int column=0;column< A.length();column++) {
for(int i=T.n_leaves();i<A.n_sequences();i++)
A(column,i) = alphabet::not_gap;
}
//---- Check that internal sequence satisfy constraints ----//
check_alignment(A,T,internal_sequences);
}
示例7: callback
void callback(const sensor_msgs::ImageConstPtr& msg)
{
cv_bridge::CvImageConstPtr cv_ptr;
try
{
// convert to OpenCV Mat
cv_ptr=cv_bridge::toCvShare(msg,"bgr8");
// compute new size
if (!variablesMap.count("aw"))
abWidth=cv_ptr->image.size().width*scWidth+0.5;
if (!variablesMap.count("ah"))
abHeight=cv_ptr->image.size().height*scHeight+0.5;
// resize
cv::resize(cv_ptr->image,resize, cv::Size(abWidth,abHeight));
// convert to Ros image
cv_bridge::CvImage resizeRos;
resizeRos.encoding = "bgr8";
resizeRos.image = resize;
// republish image
imagePub->publish(resizeRos.toImageMsg());
}
catch (cv_bridge::Exception& e)
{
ROS_ERROR("cv_bridge exception: %s", e.what());
return;
}
}
示例8: conflicting_options
/* Function used to check that 'opt1' and 'opt2' are not specified
at the same time. */
void conflicting_options(const variables_map& vm,
const char* opt1, const char* opt2)
{
if (vm.count(opt1) && !vm[opt1].defaulted()
&& vm.count(opt2) && !vm[opt2].defaulted())
throw logic_error(string("Conflicting options '")
+ opt1 + "' and '" + opt2 + "'.");
}
示例9: logic_error
void Configuration::Configuration_Impl::conflicting_options(const variables_map& vm,
const string& opt1, const string& opt2)
{
if (vm.count(opt1) && !vm[opt1].defaulted()
&& vm.count(opt2) && !vm[opt2].defaulted())
throw logic_error(string("Conflicting options '")
+ opt1 + "' and '" + opt2 + "'.");
}
示例10: option_dependency
/* Function used to check that of 'for_what' is specified, then
'required_option' is specified too. */
void option_dependency(const variables_map& vm,
const char* for_what, const char* required_option)
{
if (vm.count(for_what) && !vm[for_what].defaulted())
if (vm.count(required_option) == 0 || vm[required_option].defaulted())
throw logic_error(string("Option '") + for_what
+ "' requires option '" + required_option + "'.");
}
示例11: hpx_main
int hpx_main(variables_map& vm){
uint64_t num = vm["number-spawned"].as<uint64_t>();
bool rtype = (vm.count("result-action") ? true : false);
string atype = vm["arg-type"].as<string>();
int c = vm["argc"].as<int>();
csv = (vm.count("csv") ? true : false);
parse_arg(atype, rtype, num, c);
return hpx::finalize();
}
示例12: hpx_main
int hpx_main(variables_map& vm)
{
try {
std::cout << ( boost::format("prefix: %d")
% hpx::naming::get_locality_id_from_id(hpx::find_here()))
<< std::endl;
// Try to connect to existing throttle instance, create a new one if
// this fails.
char const* throttle_component_name = "/throttle/0";
hpx::naming::id_type gid;
hpx::agas::resolve_name(throttle_component_name, gid);
throttle::throttle t;
if (!t.get_gid()) {
std::vector<hpx::naming::id_type> localities =
hpx::find_remote_localities();
// create throttle on the console, register the instance with AGAS
// and add an additional reference count to keep it alive
if (!localities.empty()) {
// use AGAS client to get the component type as we do not
// register any factories
hpx::components::component_type type =
get_agas_client().get_component_id("throttle_throttle_type");
std::cout << "throttle component type: " << (int)type << std::endl;
t.create(localities[0], type);
hpx::agas::register_name(throttle_component_name, t.get_gid());
}
else {
std::cerr << "Can't find throttle component." << std::endl;
}
}
// handle commands
if (t.get_gid()) {
if (vm.count("suspend")) {
t.suspend(vm["suspend"].as<int>());
}
else if (vm.count("resume")) {
t.resume(vm["resume"].as<int>());
}
else if (vm.count("release")) {
// unregister from AGAS, remove additional reference count which
// will allow for the throttle instance to be released
hpx::agas::unregister_name(throttle_component_name);
}
}
}
catch (hpx::exception const& e) {
std::cerr << "throttle_client: caught exception: " << e.what() << std::endl;
}
hpx::disconnect();
return 0;
}
示例13:
config::stitching_options program_options_parser::
transform_options(const variables_map& vm) const {
config::stitching_options r;
r.verbose(vm.count(verbose_arg));
if (!vm.count(target_arg))
throw_missing_target();
r.target(vm[target_arg].as<std::string>());
r.force_write(vm.count(force_write_arg));
return r;
}
示例14: if
vector<shared_ptr<const alphabet> > load_alphabets(const variables_map& args)
{
vector<shared_ptr<const alphabet> > alphabets;
if (not args.count("alphabet")) {
alphabets.push_back(shared_ptr<const alphabet>(new DNA));
alphabets.push_back(shared_ptr<const alphabet>(new RNA));
alphabets.push_back(shared_ptr<const alphabet>(new AminoAcids));
alphabets.push_back(shared_ptr<const alphabet>(new AminoAcidsWithStop));
return alphabets;
}
const string name = args["alphabet"].as<string>();
if (name == "Codons" or name == "Codons+stop") {
shared_ptr<const AminoAcids> AA;
if (name == "Codons")
AA = shared_ptr<const AminoAcids>(new AminoAcids);
else
AA = shared_ptr<const AminoAcids>(new AminoAcidsWithStop);
string genetic_code_filename = "standard-code.txt";
if (args.count("genetic-code"))
genetic_code_filename = args["genetic-code"].as<string>();
genetic_code_filename = args["data-dir"].as<string>() + "/" + genetic_code_filename;
alphabets.push_back(shared_ptr<const alphabet>(new Codons(DNA(),*AA,genetic_code_filename)));
alphabets.push_back(shared_ptr<const alphabet>(new Codons(RNA(),*AA,genetic_code_filename)));
}
else if (name == "Triplets") {
alphabets.push_back(shared_ptr<const alphabet>(new Triplets(DNA())));
alphabets.push_back(shared_ptr<const alphabet>(new Triplets(RNA())));
}
else if (name == "DNA")
alphabets.push_back(shared_ptr<const alphabet>(new DNA()));
else if (name == "RNA")
alphabets.push_back(shared_ptr<const alphabet>(new RNA()));
else if (name == "Amino-Acids")
alphabets.push_back(shared_ptr<const alphabet>(new AminoAcids()));
else if (name == "Amino-Acids+stop")
alphabets.push_back(shared_ptr<const alphabet>(new AminoAcidsWithStop()));
else
throw myexception()<<"I don't recognize alphabet '"<<name<<"'";
return alphabets;
}
示例15: qthreads_main
int qthreads_main(
variables_map& vm
)
{
if (vm.count("no-header"))
header = false;
{
// Validate command line.
if (0 == tasks)
throw std::invalid_argument("count of 0 tasks specified\n");
// Start the clock.
high_resolution_timer t;
for (boost::uint64_t i = 0; i < tasks; ++i)
{
void* const ptr = &delay;
qthread_fork(&worker_func, ptr, NULL);
}
// Yield until all our null qthreads are done.
do {
qthread_yield();
} while (donecount != tasks);
print_results(qthread_num_workers(), t.elapsed());
}
return 0;
}