Skip to content

Commit

Permalink
Merge branch 'master' of github.com:Microsoft/AirSim
Browse files Browse the repository at this point in the history
  • Loading branch information
lovettchris committed Apr 3, 2017
2 parents 6ba69e7 + 72e3aa8 commit 7db2348
Show file tree
Hide file tree
Showing 17 changed files with 139 additions and 45 deletions.
8 changes: 4 additions & 4 deletions AirLib/include/controllers/rosflight/AirSimRosFlightBoard.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -102,7 +102,7 @@ class AirSimRosFlightBoard : public rosflight::Board {
if (index < OutputMotorCount)
motors_pwm_[index] = value;
else
throw std::exception("cannot write motor output for index > motor count");
throw std::runtime_error("cannot write motor output for index > motor count");
}

virtual void set_led(uint8_t index, bool is_on) override
Expand Down Expand Up @@ -172,12 +172,12 @@ class AirSimRosFlightBoard : public rosflight::Board {

virtual void read_diff_pressure(float& differential_pressure, float& temp, float& velocity) override
{
throw std::exception("Diff pressure sensor is not available");
throw std::runtime_error("Diff pressure sensor is not available");
}

virtual float read_sonar() override
{
throw std::exception("Sonar sensor is not available");
throw std::runtime_error("Sonar sensor is not available");
}

virtual void read_mag(int16_t mag_adc[3]) override
Expand Down Expand Up @@ -256,7 +256,7 @@ class AirSimRosFlightBoard : public rosflight::Board {
const float kAccelScale = 1.0; //as set in PARAM_ACCEL_SCALE in ROSFlight
const float kAccelG = 9.80665f; //as set in ROSFlight sensors.c init_sensors() function

// 16.4 dps/lsb scalefactor for all Invensense devices
// 16.4 dps/lsb scalefactor for all Invensense devices
const float kGyroScale = (1.0f / 16.4f) * (M_PIf / 180.0f);

static constexpr uint OutputMotorCount = 16;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -74,8 +74,8 @@ class RosFlightDroneController : public DroneControllerBase {
case 1: index_quadx = 2; break;
case 2: index_quadx = 3; break;
case 3: index_quadx = 0; break;
default:
throw std::exception("Rotor index beyond 3 is not supported yet in ROSFlight firmware");
default:
throw std::runtime_error("Rotor index beyond 3 is not supported yet in ROSFlight firmware");
}

auto control_signal = board_->getMotorControlSignal(index_quadx);
Expand Down
2 changes: 1 addition & 1 deletion AirLib/include/controllers/rosflight/firmware/mixer.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ class Mixer {

private:
void write_motor(uint8_t index, int32_t value);
void Mixer::write_servo(uint8_t index, int32_t value);
void write_servo(uint8_t index, int32_t value);

private:
typedef enum
Expand Down
2 changes: 1 addition & 1 deletion AirLib/include/controllers/rosflight/firmware/sensors.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ class Sensors {
vector_t calib_gyro_sum = { 0.0f, 0.0f, 0.0f };
uint16_t calib_accel_count = 0;
vector_t calib_accel_sum = { 0.0f, 0.0f, 0.0f };
static constexpr vector_t gravity = { 0.0f, 0.0f, 9.80665f };
vector_t gravity = { 0.0f, 0.0f, 9.80665f };
float acc_temp_sum = 0.0f;
};

Expand Down
15 changes: 13 additions & 2 deletions AirLib/include/vehicles/MultiRotor.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -99,13 +99,24 @@ class MultiRotor : public PhysicsBody {

getController()->update(dt);

float throttle_boost = params_->getParams().rotor_params.throttle_boost;

//transfer new input values from controller to rotors
for (uint rotor_index = 0; rotor_index < rotors_.size(); ++rotor_index) {
rotors_.at(rotor_index).setControlSignal(
getController()->getVertexControlSignal(rotor_index));
rotors_.at(rotor_index).setControlSignal(boost(
getController()->getVertexControlSignal(rotor_index), throttle_boost));
}
}

float boost(float signal, float amount) {
if (amount > 0 && amount < 0.7) {
float top = 1 - amount;
return Utils::clip(top * signal + amount, 0.0f, 1.0f);
}
return signal;
}


//sensor getter
const SensorCollection& getSensors() const
{
Expand Down
3 changes: 3 additions & 0 deletions AirLib/include/vehicles/RotorParams.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,9 @@ namespace msr {
real_T max_thrust = 4.179446268f; //computed from above formula for the given constants
real_T max_torque = 0.055562f; //computed from above formula

// set this to zero for more accurate simulation to match playback from real drone.
real_T throttle_boost = 0.2f; // boost the normal throttle control signal to make it more fun to fly

// call this method to recaculate thrust if you want to use different numbers for C_T, C_P, max_rpm, etc.
void calculateMaxThrust() {
revolutions_per_second = max_rpm / 60;
Expand Down
1 change: 1 addition & 0 deletions AirLib/include/vehicles/configs/BlacksheepQuadX.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ namespace msr {
params.rotor_params.C_P = 0.047;
params.rotor_params.max_rpm = 9500;
params.rotor_params.calculateMaxThrust();
params.rotor_params.throttle_boost = 0;

//set up dimensions of core body box or abdomen (not including arms).
params.body_box.x = 0.20f; params.body_box.y = 0.12f; params.body_box.z = 0.04f;
Expand Down
4 changes: 3 additions & 1 deletion AirLib/include/vehicles/configs/FlamewheelQuadX.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,14 +28,16 @@ class FlamewheelQuadX : public MultiRotorParams {
std::vector<real_T> arm_angles(params.rotor_count, 45);

//set up mass
params.mass = 1.885f;
params.mass = 1.635f;
real_T motor_assembly_weight = 0.052f;
real_T box_mass = params.mass - params.rotor_count * motor_assembly_weight;

params.rotor_params.C_T = 0.11f;
params.rotor_params.C_P = 0.047f;
params.rotor_params.max_rpm = 9500;
params.rotor_params.calculateMaxThrust();
params.linear_drag_coefficient *= 4; // make top speed more real.
params.rotor_params.throttle_boost = 0;

//set up dimensions of core body box or abdomen (not including arms).
params.body_box.x = 0.16f; params.body_box.y = 0.10f; params.body_box.z = 0.14f;
Expand Down
7 changes: 1 addition & 6 deletions AirLib/src/controllers/MavLinkDroneController.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -111,12 +111,6 @@ struct MavLinkDroneController::impl {
rotor_controls_[i] = (rotor_controls_[i] + 1.0f) / 2.0f;
}
}
else { // we have 0 to 1
//TODO: make normalization vehicle independent?
for (size_t i = 0; i < Utils::length(rotor_controls_); ++i) {
rotor_controls_[i] = Utils::clip(0.8f * rotor_controls_[i] + 0.20f, 0.0f, 1.0f);
}
}
}

void initializeMavSubscriptions()
Expand Down Expand Up @@ -308,6 +302,7 @@ struct MavLinkDroneController::impl {
hil_node_ = std::make_shared<MavLinkNode>(connection_info_.sim_sysid, connection_info_.sim_compid);
hil_node_->connect(connection_);
mav_vehicle_->connect(connection_); // in this case we can use the same connection.
mav_vehicle_->startHeartbeat();
}

mavlinkcom::MavLinkHilSensor getLastSensorMessage()
Expand Down
10 changes: 10 additions & 0 deletions LogViewer/LogViewer/Controls/ChartStack.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,15 @@ public void ClearCharts()

public UIElementCollection Charts { get { return theStack.Children; } }

protected override void OnKeyDown(KeyEventArgs e)
{
if (e.Key == Key.Escape)
{
selecting = false;
Selection.Visibility = Visibility.Collapsed;
e.Handled = true;
}
}

protected override void OnMouseLeftButtonDown(MouseButtonEventArgs e)
{
Expand All @@ -85,6 +94,7 @@ protected override void OnMouseLeftButtonDown(MouseButtonEventArgs e)
Selection.Width = 1;
Selection.Height = this.ActualHeight;
Selection.Margin = new Thickness(pos.X, 0, 0, 0);
Focus();
this.CaptureMouse();
base.OnMouseLeftButtonDown(e);
}
Expand Down
26 changes: 16 additions & 10 deletions LogViewer/LogViewer/Controls/SimpleLineChart.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -626,9 +626,9 @@ public Color LineColor

const double TooltipThreshold = 20;

DataValue FindNearestValue(Point pos, bool ignoreY)
int FindNearestValue(Point pos, bool ignoreY)
{
DataValue found = null;
int found = -1;

// transform top Graph coordinates (which could be constantly changing because of zoom and scrolling.
pos = this.TransformToDescendant(Graph).Transform(pos);
Expand Down Expand Up @@ -658,7 +658,7 @@ DataValue FindNearestValue(Point pos, bool ignoreY)
if (distance < minDistance)
{
minDistance = distance;
found = d;
found = i;
}
}
}
Expand All @@ -674,7 +674,7 @@ DataValue FindNearestValue(Point pos, bool ignoreY)
if (distance < minDistance)
{
minDistance = distance;
found = d;
found = i;
}
}
}
Expand All @@ -685,9 +685,10 @@ DataValue FindNearestValue(Point pos, bool ignoreY)

void UpdatePointer(Point pos)
{
DataValue found = FindNearestValue(pos, false);
if (found != null)
int i = FindNearestValue(pos, false);
if (i >= 0)
{
DataValue found = series.Values[i];
double availableHeight = this.ActualHeight;
double value = found.Y;
Point scaled = scaleTransform.Transform(new Point(found.X, found.Y));
Expand All @@ -709,14 +710,19 @@ internal void HandleZoomTooltip(ChartStack stack, Point mouseDownPos, Point pos)
Point localEndPos = stack.TransformToDescendant(this).Transform(pos);
if (localEndPos.X >= 0 && localEndPos.Y >= 0 && localEndPos.X < this.ActualWidth && localEndPos.Y < this.ActualHeight)
{
DataValue startData = FindNearestValue(localStartPos, true);
DataValue endData = FindNearestValue(localEndPos, true);
if (startData != null && endData != null)
int s = FindNearestValue(localStartPos, true);
int e = FindNearestValue(localEndPos, true);
if (s >= 0 && e >= 0)
{
DataValue startData = series.Values[s];
DataValue endData = series.Values[e];
Point tipPosition = this.TransformToDescendant(Graph).Transform(localEndPos);
double microseconds = endData.X - startData.X;
TimeSpan span = new TimeSpan((long)microseconds * 10);
ShowTip(span.ToString(), tipPosition);
double seconds = span.TotalSeconds;
double diff = endData.Y - startData.Y;
string msg = string.Format("{0:N3} sec, dist={1:N3}, rate={2:N3}, samples={3:N3}", seconds, diff, diff / seconds, e - s);
ShowTip(msg, tipPosition);
}
else
{
Expand Down
4 changes: 2 additions & 2 deletions LogViewer/LogViewer/LogViewer.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@
<SuiteName>PX4 Log Viewer</SuiteName>
<CreateWebPageOnPublish>true</CreateWebPageOnPublish>
<WebPage>publish.htm</WebPage>
<ApplicationRevision>32</ApplicationRevision>
<ApplicationRevision>34</ApplicationRevision>
<ApplicationVersion>1.0.0.%2a</ApplicationVersion>
<UseApplicationTrust>false</UseApplicationTrust>
<PublishWizardCompleted>true</PublishWizardCompleted>
Expand Down Expand Up @@ -61,7 +61,7 @@
<SignAssembly>true</SignAssembly>
</PropertyGroup>
<PropertyGroup>
<SignManifests>true</SignManifests>
<SignManifests>false</SignManifests>
</PropertyGroup>
<PropertyGroup>
<AssemblyOriginatorKeyFile>$(MyKeyFile)</AssemblyOriginatorKeyFile>
Expand Down
79 changes: 72 additions & 7 deletions MavLinkCom/MavLinkTest/Commands.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -490,21 +490,66 @@ bool PlayLogCommand::Parse(const std::vector<std::string>& args)
{
if (args.size() <= 0)
return false;


this->_syncParams = false;
this->_fileName = "";

std::string cmd = args[0];
if (cmd == "playlog") {
if (args.size() > 1) {
_fileName = args.at(1);
log_.openForReading(_fileName);
for (size_t i = 1; i < args.size(); i++)
{
std::string arg = args.at(i);
if (arg == "-sync") {
this->_syncParams = true;
}
else if (_fileName == "") {
_fileName = args.at(1);
log_.openForReading(_fileName);
}
else {
printf("Usage: playlog <mavlink_logfile>\n");
return false;
}
return true;
}
else {
printf("Usage: playlog <mavlink_logfile>\n");
}
if (_fileName == "") {
printf("Usage: playlog <mavlink_logfile>\n");
return false;
}
}
return false;
}

void SyncParamValue(std::shared_ptr<MavLinkVehicle> com, std::vector<MavLinkParameter>& params, MavLinkParamValue& param)
{
MavLinkParameter p;
p.index = param.param_index;
p.type = param.param_type;
char buf[17];
std::memset(buf, 0, 17);
std::memcpy(buf, param.param_id, 16);
p.name = buf;
p.value = param.param_value;

for (auto iter = params.begin(), end = params.end(); iter != end; iter++)
{
MavLinkParameter q = *iter;
if (q.name == p.name) {
if (q.value != p.value) {
printf("Parameter %s has different value %f, recorded value was %f\n",
p.name.c_str(), q.value, p.value);
if (p.name.substr(0, 3) == "MC_") {
// these PID values are important, so set these to match
bool r;
if (!com->setParameter(p).wait(1000, &r) || !r) {
printf("error setting parameter %s\n", p.name.c_str());
}
}
}
}
}
}

void PlayLogCommand::Execute(std::shared_ptr<MavLinkVehicle> com)
{
MavLinkMessage msg;
Expand All @@ -516,6 +561,17 @@ void PlayLogCommand::Execute(std::shared_ptr<MavLinkVehicle> com)
bool armed = false;
playback_timestamp = playback_start_timestamp = MavLinkLog::getTimeStamp();
uint16_t last_basemode = -1, last_custommode = -1;

std::vector<MavLinkParameter> params;
if (this->_syncParams) {
printf("Comparing parameters with recorded log...\n");
try {
params = com->getParamList();
}
catch (std::exception e) {
printf("%s\n", e.what());
}
}
printf("loading log...\n");

while (log_.read(msg, log_timestamp)) {
Expand Down Expand Up @@ -613,6 +669,15 @@ void PlayLogCommand::Execute(std::shared_ptr<MavLinkVehicle> com)

break;
}
case MavLinkParamValue::kMessageId:
{
if (this->_syncParams) {
MavLinkParamValue param;
param.decode(msg);
SyncParamValue(com, params, param);
}
break;
}
default:
break;
}
Expand Down
3 changes: 2 additions & 1 deletion MavLinkCom/MavLinkTest/Commands.h
Original file line number Diff line number Diff line change
Expand Up @@ -378,7 +378,7 @@ class PlayLogCommand : public Command
{
public:
PlayLogCommand() {
this->Name = "playlog filename";
this->Name = "playlog filename";
}

virtual bool Parse(const std::vector<std::string>& args);
Expand All @@ -394,6 +394,7 @@ class PlayLogCommand : public Command
float quaternion_[4];
float x, y, z;
std::string _fileName;
bool _syncParams;
};


Expand Down
Loading

0 comments on commit 7db2348

Please sign in to comment.