本文整理汇总了C++中EXPECT_LT函数的典型用法代码示例。如果您正苦于以下问题:C++ EXPECT_LT函数的具体用法?C++ EXPECT_LT怎么用?C++ EXPECT_LT使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了EXPECT_LT函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: TEST
TEST(RigidBody, Integration) {
float h = 0.01f;
const int N = 120;
float thresh_theta = 0.5f;
float thresh_vel = 0.1f;
EulerIntegration integratorE;
AdamsBashforthIntegration integratorAB;
AdamsBashforthIntegration5 integratorAB5;
int schedule[] = {10, 30, 60, 80, 100, 1000};
float torques[] = {1.0f, 0.0f, -0.5f, 2.5f, -0.1f, 0.0f};
int ptr = 0;
for (int i = 0; i < N; i++) {
for (; i > schedule[ptr] && schedule[ptr] < 1000; ptr++) { }
integratorE.torque = integratorAB.torque = integratorAB5.torque = torques[ptr];
integratorE.update(h);
integratorAB.update(h);
integratorAB5.update(h);
}
bool passed = true;
math::matrix2x1<float> states[] = { integratorE.state, integratorAB.state, integratorAB5.state };
float thresh[] = { thresh_theta, thresh_vel };
float math::matrix2x1<float>:: *elements[] = { & math::matrix2x1<float>::_0, & math::matrix2x1<float>::_1 };
for (int i = 0; i < 2; i++) {
for (int j = 0; j < 2; j++) {
EXPECT_LT(std::abs((states[i]).*(elements[j]) - (states[i+1]).*(elements[j])), thresh[j]);
}
}
}
示例2: TEST
TEST(InterfacesTest, OdomPoseBasicIO)
{
stateUpdated_ = false;
ros::NodeHandle nh;
ros::Publisher odomPub = nh.advertise<nav_msgs::Odometry>("/odom_input0", 5);
ros::Subscriber filteredSub = nh.subscribe("/odometry/filtered", 1, &filterCallback);
nav_msgs::Odometry odom;
odom.pose.pose.position.x = 20.0;
odom.pose.pose.position.y = 10.0;
odom.pose.pose.position.z = -40.0;
odom.pose.covariance[0] = 2.0;
odom.pose.covariance[7] = 2.0;
odom.pose.covariance[14] = 2.0;
odom.header.frame_id = "odom";
odom.child_frame_id = "base_link";
ros::Rate loopRate(50);
for (size_t i = 0; i < 50; ++i)
{
odom.header.stamp = ros::Time::now();
odomPub.publish(odom);
ros::spinOnce();
loopRate.sleep();
odom.header.seq++;
}
// Now check the values from the callback
EXPECT_LT(::fabs(filtered_.pose.pose.position.x - odom.pose.pose.position.x), 0.01);
EXPECT_LT(::fabs(filtered_.pose.pose.position.y), 0.01); // Configuration for this variable for this sensor is false
EXPECT_LT(::fabs(filtered_.pose.pose.position.z - odom.pose.pose.position.z), 0.01);
EXPECT_LT(filtered_.pose.covariance[0], 0.5);
EXPECT_LT(filtered_.pose.covariance[7], 0.25); // Configuration for this variable for this sensor is false
EXPECT_LT(filtered_.pose.covariance[14], 0.6);
resetFilter();
}
示例3: TEST_F
TEST_F(QuotaTest, usage)
{
// put quota
MojObject obj;
MojAssertNoErr( obj.fromJson(_T("{\"owner\":\"com.foo.bar\",\"size\":1000}")) );
MojAssertNoErr( db.putQuotas(&obj, &obj + 1) );
// empty
MojInt64 kindUsage = -1;
EXPECT_NO_FATAL_FAILURE( getKindUsage(db, _T("Test:1"), kindUsage) );
EXPECT_EQ( 0, kindUsage )
<< "Kind without objects should have zero usage";
MojInt64 quotaUsage = -1;
EXPECT_NO_FATAL_FAILURE( getQuotaUsage(db, _T("com.foo.bar"), quotaUsage) );
EXPECT_EQ( 0, quotaUsage )
<< "Quota without matching objects should have zero usage";
// new obj
EXPECT_NO_FATAL_FAILURE( put(db, MojTestKind1Objects[0]) );
MojInt64 kindUsage1 = -1;
EXPECT_NO_FATAL_FAILURE( getKindUsage(db, _T("Test:1"), kindUsage1) );
EXPECT_LT( 0, kindUsage1 )
<< "Adding new object into kind should increase kind usage";
MojInt64 quotaUsage1 = -1;
EXPECT_NO_FATAL_FAILURE( getQuotaUsage(db, _T("com.foo.bar"), quotaUsage1) );
EXPECT_LT( 0, quotaUsage1 )
<< "Adding new object matching quota should increase quota usage";
// add prop to existing obj
MojAssertNoErr( obj.fromJson(MojTestKind1Objects[0]) );
MojAssertNoErr( obj.put(_T("bar"), 2) );
MojAssertNoErr( db.put(obj, MojDb::FlagForce) );
MojInt64 kindUsage2 = -1;
EXPECT_NO_FATAL_FAILURE( getKindUsage(db, _T("Test:1"), kindUsage2) );
EXPECT_LE( 0, kindUsage2 );
EXPECT_LT( kindUsage1, kindUsage2 )
<< "Adding property to existing object should increase kind usage";
MojInt64 quotaUsage2 = -1;
EXPECT_NO_FATAL_FAILURE( getQuotaUsage(db, _T("com.foo.bar"), quotaUsage2) );
EXPECT_LE( 0, quotaUsage2 );
EXPECT_LT( quotaUsage1, quotaUsage2 )
<< "Adding property to existing object that matches quota should increase usage";
// add 2nd obj
EXPECT_NO_FATAL_FAILURE( put(db, MojTestKind1Objects[1]) );
MojInt64 kindUsage3 = -1;
EXPECT_NO_FATAL_FAILURE( getKindUsage(db, _T("Test:1"), kindUsage3) );
EXPECT_LE( 0, kindUsage3 );
EXPECT_LT( kindUsage2, kindUsage3 )
<< "Adding another object should increase kind usage";
MojInt64 quotaUsage3 = -1;
EXPECT_NO_FATAL_FAILURE( getQuotaUsage(db, _T("com.foo.bar"), quotaUsage3) );
EXPECT_LE( 0, quotaUsage3 );
EXPECT_LT( quotaUsage2, quotaUsage3 )
<< "Adding another object matching to quota should increase usage";
// del first obj
bool found = false;
MojExpectNoErr( db.del(1, found, MojDb::FlagPurge) );
EXPECT_TRUE( found ) << "Object should be deleted";
MojInt64 kindUsage4 = -1;
EXPECT_NO_FATAL_FAILURE( getKindUsage(db, _T("Test:1"), kindUsage4) );
EXPECT_LE( 0, kindUsage4 );
EXPECT_EQ( kindUsage3 - kindUsage2, kindUsage4 )
<< "Deletion of object should bring kind usage to expected value";
MojInt64 quotaUsage4 = -1;
EXPECT_NO_FATAL_FAILURE( getQuotaUsage(db, _T("com.foo.bar"), quotaUsage4) );
EXPECT_LE( 0, quotaUsage4 );
EXPECT_EQ( quotaUsage3 - quotaUsage2, quotaUsage4 )
<< "Deletion of object should bring quota usage to expected value";
// add index
MojAssertNoErr( obj.fromJson(MojTestKind1Str2) );
MojExpectNoErr( db.putKind(obj) );
MojInt64 kindUsage5 = -1;
EXPECT_NO_FATAL_FAILURE( getKindUsage(db, _T("Test:1"), kindUsage5) );
EXPECT_LE( 0, kindUsage5 );
EXPECT_LT( kindUsage4, kindUsage5 )
<< "Adding new index should increase kind usage";
MojInt64 quotaUsage5 = -1;
EXPECT_NO_FATAL_FAILURE( getQuotaUsage(db, _T("com.foo.bar"), quotaUsage5) );
EXPECT_LE( 0, quotaUsage5 );
EXPECT_LT( quotaUsage4, quotaUsage5 )
<< "Adding new index should increase quota usage";
// update locale
MojExpectNoErr( db.updateLocale(_T("FR_fr")) );
MojExpectNoErr( db.updateLocale(_T("EN_us")) );
MojInt64 kindUsage6 = -1;
EXPECT_NO_FATAL_FAILURE( getKindUsage(db, _T("Test:1"), kindUsage6) );
EXPECT_LE( 0, kindUsage6 );
EXPECT_EQ( kindUsage5, kindUsage6 )
<< "Switching locale forth and back shouldn't affect kind usage";
MojInt64 quotaUsage6 = -1;
EXPECT_NO_FATAL_FAILURE( getQuotaUsage(db, _T("com.foo.bar"), quotaUsage6) );
EXPECT_LE( 0, kindUsage6 );
EXPECT_EQ( quotaUsage5, quotaUsage6 )
<< "Switching locale forth and back shouldn't affect quota usage";
// drop index
//.........这里部分代码省略.........
示例4: TEST
TEST(String, LessOnDiffCase)
{
String s1("Hello"), s2("hello");
EXPECT_LT(s1, s2);
EXPECT_FALSE(s2 < s1);
}
示例5: TEST_F
// Tests that the Variant::operator< method works for string-float comparison
TEST_F(TestVariant, OperatorLTStringFloat) {
Variant v1("124.08");
Variant v2((float) 124.09);
EXPECT_LT(v1, v2);
}
示例6: TEST
TEST(ControlSystem, depth)
{
double test_depth = -3;
double overshoot_allowed = 0.3;
double average_threshold = 0.1;
double std_dev_allowed = 0.05;
rs::SubscriberAnalyzer<robosub_msgs::Float32Stamped> analyzer;
analyzer.Init("depth", &get_depth_data);
robosub_msgs::control msg;
//keep the sub steady
msg.forward_state = robosub_msgs::control::STATE_ERROR;
msg.forward = 0;
msg.strafe_state = robosub_msgs::control::STATE_ERROR;
msg.strafe_left = 0;
msg.yaw_state = robosub_msgs::control::STATE_RELATIVE;
msg.yaw_left = 0;
msg.roll_state = robosub_msgs::control::STATE_ABSOLUTE;
msg.roll_right = 0;
msg.pitch_state = robosub_msgs::control::STATE_ABSOLUTE;
msg.pitch_down = 0;
//just go to depth
msg.dive_state = robosub_msgs::control::STATE_ABSOLUTE;
msg.dive = test_depth;
//fill out a control message to stay level and go to depth
pub.publish(msg);
analyzer.Start();
ROS_INFO("diving to depth");
//wait for the sub to reach its depth
ros::Time exit_time = ros::Time::now() + ros::Duration(10);
while (ros::Time::now() < exit_time)
{
ros::spinOnce();
ros::Duration(0.01).sleep();
}
analyzer.Stop();
//confirm we didn't dive too deep
EXPECT_LT(test_depth - overshoot_allowed, analyzer.GetMin());
ROS_INFO("maintaining depth to check steady-state oscillation...");
analyzer.ClearData();
analyzer.Start();
//wait for 10 seconds to measure wiggle
exit_time = ros::Time::now() + ros::Duration(10);
while (ros::Time::now() < exit_time)
{
ros::spinOnce();
ros::Duration(0.01).sleep();
}
analyzer.Stop();
//confirm depth is stable
EXPECT_NEAR(test_depth, analyzer.GetAverage(), average_threshold);
EXPECT_LT(analyzer.GetStandardDeviation(), std_dev_allowed);
}
示例7: TEST_F
TEST_F(MatMultTests, SIFT) {
string fileName("mat-sift");
int m = 898790;
int n = 128;
int k = 256;
/* allocate data */
float * data = (float *)malloc(m*n*sizeof(float));
float * centers = (float *)malloc(k*n*sizeof(float));
float * result = (float *)malloc(m*k*sizeof(float));
float * resultCublas = (float *)malloc(m*k*sizeof(float));
/* read matrix from file */
FILE * fid = fopen(fileName.c_str(), "rb");
int nread = fread(data, sizeof(float), m*n, fid);
ASSERT_EQ(nread, m*n);
fclose(fid);
/* initialize centers to 1 */
for (int i = 0; i<k*n; ++i) centers[i] = (float)1;
/* allocate device space for the various arrays */
float * dev_data, *dev_centers, *dev_result;
int factor = TILESIZE*N_UNROLL_FLOAT;
int m_padded = ((m + factor - 1) / factor)*factor;
int nBytes = m_padded*n*sizeof(float);
cudaMalloc((void**)&dev_data, nBytes);
cudaMemset(dev_data, 0, nBytes);
cudaMemcpy(dev_data, data, m*n*sizeof(float), cudaMemcpyHostToDevice);
nBytes = n*k*sizeof(float);
cudaMalloc((void**)&dev_centers, nBytes);
cudaMemcpy(dev_centers, centers, nBytes, cudaMemcpyHostToDevice);
nBytes = m*k*sizeof(float);
cudaMalloc((void**)&dev_result, nBytes);
cudaMemset(dev_result, 0, nBytes);
/* run MatMatMultF */
int err = MatMatMultF(m, n, dev_data, k, dev_centers, dev_result);
if (err) printf("Error int MatMatMultF for mat-sift\n");
cudaMemcpy(result, dev_result, nBytes, cudaMemcpyDeviceToHost);
/* run CUBLAS SGEMM */
float one = 1.f;
float zero = 0.f;
cublasHandle_t handle;
cublasCreate(&handle);
cublasSgemm(handle, CUBLAS_OP_N, CUBLAS_OP_N,
k, m, n, (const float *)&one,
(const float *)dev_centers, k,
(const float *)dev_data, n,
(const float *)&zero, (float *)dev_result, k);
cudaMemcpy(resultCublas, dev_result, nBytes, cudaMemcpyDeviceToHost);
#if 1
/* check results */
int maxPrintErrors=10;
int numPrintErrors=0;
for (int i = 0; i < m; ++i) {
for (int j = 0; j < k; ++j) {
int index = i*k + j;
if (result[index] == 0 && resultCublas[index] == 0) continue;
else {
float err = fabs(result[index] - resultCublas[index]) / fabs(result[index]);
if (err >= 1.e-6 || result[index] == 0) {
printf("i=%d, j=%d : %1.5g, %1.5g, err=%1.5g\n", i, j, result[index], resultCublas[index], err);
if (numPrintErrors<maxPrintErrors) {
numPrintErrors++;
EXPECT_LT(err, 1.e-6);
} else {
ASSERT_LT(err, 1.e-6);
}
}
}
}
}
#endif
/* free data */
if (dev_data) cudaFree(dev_data);
if (dev_centers) cudaFree(dev_centers);
if (dev_result) cudaFree(dev_result);
if (data) free(data);
if (centers) free(centers);
if (result) free(result);
if (resultCublas) free(resultCublas);
cublasDestroy(handle);
}
示例8: checkMonotone
void checkMonotone(const T *ary, size_t size)
{
for (size_t i = 1; i < size; ++i) {
EXPECT_LT(ary[i-1], ary[i]);
}
}
示例9: TEST_F
TEST_F(MidiControllerTest, ReceiveMessage_PotMeterCO_14BitCC) {
ConfigKey key("[Channel1]", "playposition");
const double kMinValue = -1234.5;
const double kMaxValue = 678.9;
const double kMiddleValue = (kMinValue + kMaxValue) * 0.5;
ControlPotmeter potmeter(key, kMinValue, kMaxValue);
potmeter.set(0);
unsigned char channel = 0x01;
unsigned char lsb_control = 0x10;
unsigned char msb_control = 0x11;
MidiOptions lsb;
lsb.fourteen_bit_lsb = true;
MidiOptions msb;
msb.fourteen_bit_msb = true;
addMapping(MidiInputMapping(MidiKey(MIDI_CC | channel, lsb_control),
lsb, key));
addMapping(MidiInputMapping(MidiKey(MIDI_CC | channel, msb_control),
msb, key));
loadPreset(m_preset);
// If kMinValue or kMaxValue are such that the middle value is 0 then the
// set(0) commands below allow us to hide failures.
ASSERT_NE(0.0, kMiddleValue);
// Receive a 0x0000 (lsb-first), MIDI parameter should map to the min value.
potmeter.set(0);
receive(MIDI_CC | channel, lsb_control, 0x00);
receive(MIDI_CC | channel, msb_control, 0x00);
EXPECT_DOUBLE_EQ(kMinValue, potmeter.get());
// Receive a 0x0000 (msb-first), MIDI parameter should map to the min value.
potmeter.set(0);
receive(MIDI_CC | channel, msb_control, 0x00);
receive(MIDI_CC | channel, lsb_control, 0x00);
EXPECT_DOUBLE_EQ(kMinValue, potmeter.get());
// Receive a 0x3FFF (lsb-first), MIDI parameter should map to the max value.
potmeter.set(0);
receive(MIDI_CC | channel, lsb_control, 0x7F);
receive(MIDI_CC | channel, msb_control, 0x7F);
EXPECT_DOUBLE_EQ(kMaxValue, potmeter.get());
// Receive a 0x3FFF (msb-first), MIDI parameter should map to the max value.
potmeter.set(0);
receive(MIDI_CC | channel, msb_control, 0x7F);
receive(MIDI_CC | channel, lsb_control, 0x7F);
EXPECT_DOUBLE_EQ(kMaxValue, potmeter.get());
// Receive a 0x2000 (lsb-first), MIDI parameter should map to the middle
// value.
potmeter.set(0);
receive(MIDI_CC | channel, lsb_control, 0x00);
receive(MIDI_CC | channel, msb_control, 0x40);
EXPECT_DOUBLE_EQ(kMiddleValue, potmeter.get());
// Receive a 0x2000 (msb-first), MIDI parameter should map to the middle
// value.
potmeter.set(0);
receive(MIDI_CC | channel, msb_control, 0x40);
receive(MIDI_CC | channel, lsb_control, 0x00);
EXPECT_DOUBLE_EQ(kMiddleValue, potmeter.get());
// Check the 14-bit resolution is actually present. Receive a 0x2001
// (msb-first), MIDI parameter should map to the middle value plus a tiny
// amount. Scaling is not quite linear for MIDI parameters so just check
// that incrementing the LSB by 1 is greater than the middle value.
potmeter.set(0);
receive(MIDI_CC | channel, msb_control, 0x40);
receive(MIDI_CC | channel, lsb_control, 0x01);
EXPECT_LT(kMiddleValue, potmeter.get());
// Check the 14-bit resolution is actually present. Receive a 0x2001
// (lsb-first), MIDI parameter should map to the middle value plus a tiny
// amount. Scaling is not quite linear for MIDI parameters so just check
// that incrementing the LSB by 1 is greater than the middle value.
potmeter.set(0);
receive(MIDI_CC | channel, lsb_control, 0x01);
receive(MIDI_CC | channel, msb_control, 0x40);
EXPECT_LT(kMiddleValue, potmeter.get());
}
示例10: TEST
TEST(ErrorBlockTests, error_blocks_maxwell)
{
ros::NodeHandle nh("~");
robot_calibration::Optimizer opt(robot_description);
std::vector<robot_calibration_msgs::CalibrationData> data;
robot_calibration_msgs::CalibrationData msg;
// Match expected output from chain manager
msg.joint_states.name.resize(10);
msg.joint_states.name[0] = "arm_lift_joint";
msg.joint_states.name[1] = "arm_shoulder_pan_joint";
msg.joint_states.name[2] = "arm_shoulder_lift_joint";
msg.joint_states.name[3] = "arm_upperarm_roll_joint";
msg.joint_states.name[4] = "arm_elbow_flex_joint";
msg.joint_states.name[5] = "arm_wrist_flex_joint";
msg.joint_states.name[6] = "arm_wrist_roll_joint";
msg.joint_states.name[7] = "head_pan_joint";
msg.joint_states.name[8] = "head_tilt_joint";
msg.joint_states.name[9] = "arm_lift_joint";
msg.joint_states.position.resize(10);
msg.joint_states.position[0] = -0.05; // Add some error
msg.joint_states.position[1] = -0.814830;
msg.joint_states.position[2] = -0.00022290000000002586;
msg.joint_states.position[3] = 0.0;
msg.joint_states.position[4] = -0.7087341;
msg.joint_states.position[5] = 0.0;
msg.joint_states.position[6] = 0.0;
msg.joint_states.position[7] = -0.8280187999999999;
msg.joint_states.position[8] = 0.6358500000000002;
msg.joint_states.position[9] = 0.0;
// Expectect output from led finder
msg.observations.resize(2);
msg.observations[0].sensor_name = "camera";
msg.observations[1].sensor_name = "arm";
msg.observations[0].features.resize(1);
msg.observations[0].features[0].header.frame_id = "head_camera_rgb_optical_frame";
msg.observations[0].features[0].point.x = -0.0143163670728;
msg.observations[0].features[0].point.y = 0.111304592065;
msg.observations[0].features[0].point.z = 0.522079317365;
msg.observations[0].ext_camera_info.camera_info.P[0] = 100.0; // fx
msg.observations[0].ext_camera_info.camera_info.P[5] = 100.0; // fy
msg.observations[0].ext_camera_info.camera_info.P[2] = 320.0; // cx
msg.observations[0].ext_camera_info.camera_info.P[6] = 240.0; // cy
msg.observations[0].ext_camera_info.parameters.resize(2);
msg.observations[0].ext_camera_info.parameters[0].name = "z_offset";
msg.observations[0].ext_camera_info.parameters[0].value = 0.0;
msg.observations[0].ext_camera_info.parameters[1].name = "z_scaling";
msg.observations[0].ext_camera_info.parameters[1].value = 1.0;
msg.observations[1].features.resize(1);
msg.observations[1].features[0].header.frame_id = "gripper_led_frame";
msg.observations[1].features[0].point.x = 0.0;
msg.observations[1].features[0].point.y = 0.0;
msg.observations[1].features[0].point.z = 0.0;
// Add first data point
data.push_back(msg);
// Add a second data point that is just a little different
msg.joint_states.position[1] = -0.019781999999999966;
msg.joint_states.position[7] = 0.0;
msg.observations[0].features[0].point.x = 0.0365330705881;
msg.observations[0].features[0].point.y = 0.102609552493;
msg.observations[0].features[0].point.z = 0.536061220027;
data.push_back(msg);
// And a third data point
msg.joint_states.position[1] = 0.883596;
msg.joint_states.position[7] = 0.9442135999999999;
msg.observations[0].features[0].point.x = 0.0942445346646;
msg.observations[0].features[0].point.y = 0.11409172323;
msg.observations[0].features[0].point.z = 0.517497963716;
data.push_back(msg);
// Setup params
robot_calibration::OptimizationParams params;
params.LoadFromROS(nh);
// Optimize
opt.optimize(params, data, false);
EXPECT_GT(opt.summary()->initial_cost, 0.001);
EXPECT_LT(opt.summary()->final_cost, 1e-18);
EXPECT_GT(opt.summary()->iterations.size(), static_cast<size_t>(1)); // expect more than 1 iteration
// The -0.05 we added above should be calibrated off
EXPECT_LT(fabs(0.05 - opt.getOffsets()->get("arm_lift_joint")), 0.001);
// 1 joint
EXPECT_EQ(1, opt.getNumParameters());
// 3 CalibrationData, each with chain3d with a single observed point (3 residuals)
EXPECT_EQ(9, opt.getNumResiduals());
}
示例11: run_test
std::pair<double, double>
run_test(barrier_inserter& insert_barrier,
bool prefill,
uint64_t tasks_per_queue,
unsigned num_queues,
unsigned num_threads,
uint64_t delay_us,
unsigned idle_queues)
{
EXPECT_LT(0U, tasks_per_queue);
EXPECT_LT(0U, num_queues);
EXPECT_LE(0U, idle_queues);
boost::property_tree::ptree pt;
PARAMETER_TYPE(ip::perf_threadpool_test_threads)(num_threads).persist(pt);
pt.put("version", 1);
std::unique_ptr<threadpool_type> tp(new threadpool_type(pt));
BOOST_SCOPE_EXIT_TPL((&tp))
{
EXPECT_NO_THROW(tp->stop()) << "Failed to stop threadpool";
}
BOOST_SCOPE_EXIT_END;
{
blocker_ptr_vec blockers(idle_queues);
for (size_t i = 0; i < idle_queues; ++i)
{
blockers[i] = blocker_ptr(new Blocker(*tp, num_queues + i));
}
}
callback_ptr_vec callbacks(num_queues);
for (size_t i = 0; i < callbacks.size(); ++i)
{
callbacks[i] = callback_ptr(new Callback(tasks_per_queue, delay_us));
}
youtils::wall_timer t;
double post_time;
if (prefill)
{
blocker_ptr_vec blockers(num_queues);
for (size_t i = 0; i < blockers.size(); ++i)
{
blockers[i] = blocker_ptr(new Blocker(*tp, i));
}
post_time = post_tasks_(insert_barrier, *tp, callbacks, tasks_per_queue);
t.restart();
}
else
{
post_time = post_tasks_(insert_barrier, *tp, callbacks, tasks_per_queue);
}
for (size_t i = 0; i < callbacks.size(); ++i)
{
callback_ptr cb = callbacks[i];
std::unique_lock<Callback::lock_type> u(cb->lock_);
while (cb->count_ > 0)
{
ASSERT(cb->count_ <= tasks_per_queue);
cb->cond_.wait(u);
}
}
const double proc_time = t.elapsed();
std::cout <<
"# queues: " << num_queues <<
", tasks per queue: " << tasks_per_queue <<
", # idle queues: " << idle_queues <<
", threads in pool: " << tp->getNumThreads() <<
", delay per task (us): " << delay_us <<
", processing duration (s): " << proc_time <<
std::endl;
return std::make_pair(post_time, proc_time);
}
示例12: verify_tpcb_task
/** Verify TPC-B results. */
ErrorStack verify_tpcb_task(const proc::ProcArguments& args) {
thread::Thread* context = args.context_;
xct::XctManager* xct_manager = context->get_engine()->get_xct_manager();
CHECK_ERROR(xct_manager->begin_xct(context, xct::kSerializable));
int64_t expected_branch[kBranches];
int64_t expected_teller[kBranches * kTellers];
int64_t expected_account[kBranches * kAccounts];
for (int i = 0; i < kBranches; ++i) {
expected_branch[i] = kInitialAccountBalance * kAccounts;
}
for (int i = 0; i < kBranches * kTellers; ++i) {
expected_teller[i] = kInitialAccountBalance * kAccountsPerTellers;
}
for (int i = 0; i < kBranches * kAccounts; ++i) {
expected_account[i] = kInitialAccountBalance;
}
// we don't have scanning API yet, so manually do it.
std::set<uint64_t> observed_history_ids;
WRAP_ERROR_CODE(sequential::SequentialStoragePimpl(
context->get_engine(), histories.get_control_block()).for_every_page(
[&](SequentialPage* page){
uint16_t record_count = page->get_record_count();
const char* record_pointers[kMaxSlots];
uint16_t payload_lengthes[kMaxSlots];
page->get_all_records_nosync(&record_count, record_pointers, payload_lengthes);
for (uint16_t rec = 0; rec < record_count; ++rec) {
EXPECT_EQ(payload_lengthes[rec], sizeof(HistoryData));
const HistoryData& history = *reinterpret_cast<const HistoryData*>(
record_pointers[rec] + kRecordOverhead);
EXPECT_GE(history.amount_, kAmountRangeFrom);
EXPECT_LE(history.amount_, kAmountRangeTo);
EXPECT_LT(history.branch_id_, kBranches);
EXPECT_LT(history.teller_id_, kBranches * kTellers);
EXPECT_LT(history.account_id_, kBranches * kAccounts);
EXPECT_EQ(history.branch_id_, history.teller_id_ / kTellers);
EXPECT_EQ(history.branch_id_, history.account_id_ / kAccounts);
EXPECT_EQ(history.teller_id_, history.account_id_ / kAccountsPerTellers);
expected_branch[history.branch_id_] += history.amount_;
expected_teller[history.teller_id_] += history.amount_;
expected_account[history.account_id_] += history.amount_;
EXPECT_EQ(observed_history_ids.end(), observed_history_ids.find(history.history_id_))
<< history.history_id_;
observed_history_ids.insert(history.history_id_);
}
return kErrorCodeOk;
}));
EXPECT_EQ(kXctsPerThread * thread_count, observed_history_ids.size());
for (int i = 0; i < kXctsPerThread * thread_count; ++i) {
EXPECT_NE(observed_history_ids.end(), observed_history_ids.find(i)) << i;
}
for (int i = 0; i < kBranches; ++i) {
BranchData data;
CHECK_ERROR(branches.get_record(context, i, &data));
EXPECT_EQ(expected_branch[i], data.branch_balance_) << "branch-" << i;
}
for (int i = 0; i < kBranches * kTellers; ++i) {
TellerData data;
CHECK_ERROR(tellers.get_record(context, i, &data));
EXPECT_EQ(i / kTellers, data.branch_id_) << i;
EXPECT_EQ(expected_teller[i], data.teller_balance_) << "teller-" << i;
}
for (int i = 0; i < kBranches * kAccounts; ++i) {
AccountData data;
CHECK_ERROR(accounts.get_record(context, i, &data));
EXPECT_EQ(i / kAccounts, data.branch_id_) << i;
EXPECT_EQ(expected_account[i], data.account_balance_) << "account-" << i;
}
for (uint32_t i = 0; i < context->get_current_xct().get_read_set_size(); ++i) {
xct::ReadXctAccess& access = context->get_current_xct().get_read_set()[i];
EXPECT_FALSE(access.observed_owner_id_.is_being_written()) << i;
EXPECT_FALSE(access.observed_owner_id_.is_deleted()) << i;
EXPECT_FALSE(access.observed_owner_id_.is_moved()) << i;
}
CHECK_ERROR(xct_manager->abort_xct(context));
return foedus::kRetOk;
}
示例13: TEST
TEST(logd, statistics) {
size_t len;
char *buf;
alloc_statistics(&buf, &len);
#ifdef TARGET_USES_LOGD
ASSERT_TRUE(NULL != buf);
#else
if (!buf) {
return;
}
#endif
// remove trailing FF
char *cp = buf + len - 1;
*cp = '\0';
bool truncated = *--cp != '\f';
if (!truncated) {
*cp = '\0';
}
// squash out the byte count
cp = buf;
if (!truncated) {
while (isdigit(*cp) || (*cp == '\n')) {
++cp;
}
}
fprintf(stderr, "%s", cp);
EXPECT_LT((size_t)64, strlen(cp));
EXPECT_EQ(0, truncated);
#ifdef TARGET_USES_LOGD
char *main_logs = strstr(cp, "\nmain:");
EXPECT_TRUE(NULL != main_logs);
char *radio_logs = strstr(cp, "\nradio:");
EXPECT_TRUE(NULL != radio_logs);
char *system_logs = strstr(cp, "\nsystem:");
EXPECT_TRUE(NULL != system_logs);
char *events_logs = strstr(cp, "\nevents:");
EXPECT_TRUE(NULL != events_logs);
#endif
// Parse timing stats
cp = strstr(cp, "Minimum time between log events per dgram_qlen:");
if (cp) {
while (*cp && (*cp != '\n')) {
++cp;
}
if (*cp == '\n') {
++cp;
}
char *list_of_spans = cp;
EXPECT_NE('\0', *list_of_spans);
unsigned short number_of_buckets = 0;
unsigned short *dgram_qlen = NULL;
unsigned short bucket = 0;
while (*cp && (*cp != '\n')) {
bucket = 0;
while (isdigit(*cp)) {
bucket = bucket * 10 + *cp - '0';
++cp;
}
while (*cp == ' ') {
++cp;
}
if (!bucket) {
break;
}
unsigned short *new_dgram_qlen = new unsigned short[number_of_buckets + 1];
EXPECT_TRUE(new_dgram_qlen != NULL);
if (dgram_qlen) {
memcpy(new_dgram_qlen, dgram_qlen, sizeof(*dgram_qlen) * number_of_buckets);
delete [] dgram_qlen;
}
dgram_qlen = new_dgram_qlen;
dgram_qlen[number_of_buckets++] = bucket;
}
char *end_of_spans = cp;
EXPECT_NE('\0', *end_of_spans);
EXPECT_LT(5, number_of_buckets);
unsigned long long *times = new unsigned long long [number_of_buckets];
ASSERT_TRUE(times != NULL);
memset(times, 0, sizeof(*times) * number_of_buckets);
//.........这里部分代码省略.........
示例14: TEST_F
TEST_F(PIDControllerTest, basicVerificationTest)
{
int loops = 0;
int onTargetLoops = 0;
// Check that position mode works as expected
printf("Setting PIDF values to [ 1 0.001 0.01 0 ]\n");
pidController->setConstants(1, 0.001, .01, 0);
printf("Setting setpoint to 10 revolutions\n");
pidController->setSetpoint(10);
pidController->setMode(POSITION_REV);
pidController->enable();
while(onTargetLoops < 10)
{
pidController->update();
if(pidController->onTarget())
{
onTargetLoops++;
}
else if(onTargetLoops > 0)
{
onTargetLoops--;
}
loops++;
}
printf("Verifying that PID took 97 loops to settle\n");
EXPECT_EQ(97, loops);
printf("Verifying that encoder position is within tolerance\n");
EXPECT_LT(10 - POSITION_REV_TOLERANCE, encoder->getPosition());
EXPECT_GT(10 + POSITION_REV_TOLERANCE, encoder->getPosition());
printf("Resetting PIDController and encoder for next test\n");
pidController->reset();
encoder->reset(true);
encoder->setRandSeed(0);
loops = 0;
onTargetLoops = 0;
// Check that raw position mode works as expected
printf("Setting PIDF values to [ 0.001 0.000001 0.001 0 ]\n");
pidController->setConstants(.001, 0.000001, .001, 0);
printf("Setting setpoint to 10240 ticks\n");
pidController->setSetpoint(10240);
pidController->setMode(POSITION_RAW);
pidController->enable();
while(onTargetLoops < 10)
{
pidController->update();
if(pidController->onTarget())
{
onTargetLoops++;
}
else if(onTargetLoops > 0)
{
onTargetLoops--;
}
loops++;
}
printf("Verifying that PID took 104 loops to settle\n");
EXPECT_EQ(104, loops);
printf("Verifying that encoder position is within tolerance\n");
EXPECT_LT(10240 - POSITION_RAW_TOLERANCE, encoder->getRaw());
EXPECT_GT(10240 + POSITION_RAW_TOLERANCE, encoder->getRaw());
printf("Resetting PIDController and encoder for next test\n");
pidController->reset();
encoder->reset(true);
encoder->setRandSeed(0);
loops = 0;
onTargetLoops = 0;
// Check that speed mode works as expected
printf("Setting PIDF values to [ 0.01 0.1 0.00001 0.01 ]\n");
pidController->setConstants(.01, 0.1, .00001, 0.01);
printf("Setting setpoint to 10 revolutions per second\n");
pidController->setSetpoint(10);
pidController->setMode(SPEED);
pidController->enable();
while(onTargetLoops < 10)
{
pidController->update();
if(pidController->onTarget())
{
onTargetLoops++;
}
else if(onTargetLoops > 0)
{
onTargetLoops--;
}
//.........这里部分代码省略.........
示例15: TEST
//.........这里部分代码省略.........
"logcat -v time -b radio -b events -b system -b main -d 2>/dev/null",
"r")));
class timestamp {
private:
int month;
int day;
int hour;
int minute;
int second;
int millisecond;
bool ok;
public:
void init(const char *buffer)
{
ok = false;
if (buffer != NULL) {
ok = sscanf(buffer, "%d-%d %d:%d:%d.%d ",
&month, &day, &hour, &minute, &second, &millisecond) == 6;
}
}
timestamp(const char *buffer)
{
init(buffer);
}
bool operator< (timestamp &T)
{
return !ok || !T.ok
|| (month < T.month)
|| ((month == T.month)
&& ((day < T.day)
|| ((day == T.day)
&& ((hour < T.hour)
|| ((hour == T.hour)
&& ((minute < T.minute)
|| ((minute == T.minute)
&& ((second < T.second)
|| ((second == T.second)
&& (millisecond < T.millisecond))))))))));
}
bool valid(void)
{
return ok;
}
} last(NULL);
char *last_buffer = NULL;
char buffer[5120];
int count = 0;
int next_lt_last = 0;
while (fgets(buffer, sizeof(buffer), fp)) {
if (!strncmp(begin, buffer, sizeof(begin) - 1)) {
continue;
}
if (!last.valid()) {
free(last_buffer);
last_buffer = strdup(buffer);
last.init(buffer);
}
timestamp next(buffer);
if (next < last) {
if (last_buffer) {
fprintf(stderr, "<%s", last_buffer);
}
fprintf(stderr, ">%s", buffer);
++next_lt_last;
}
if (next.valid()) {
free(last_buffer);
last_buffer = strdup(buffer);
last.init(buffer);
}
++count;
}
free(last_buffer);
pclose(fp);
static const int max_ok = 2;
// Allow few fails, happens with readers active
fprintf(stderr, "%s: %d/%d out of order entries\n",
(next_lt_last)
? ((next_lt_last <= max_ok)
? "WARNING"
: "ERROR")
: "INFO",
next_lt_last, count);
EXPECT_GE(max_ok, next_lt_last);
// sample statistically too small
EXPECT_LT(100, count);
}