Wednesday, 27 August 2014

AP_HAL::UARTDriver* _uartA, // console
        AP_HAL::UARTDriver* _uartB, // 1st GPS
        AP_HAL::UARTDriver* _uartC, // telem1
        AP_HAL::UARTDriver* _uartD, // telem2
        AP_HAL::UARTDriver* _uartE, // 2nd GPS
As near as I can tell from looking at the numbers, the primary advantage of the MR props over the SF props is the difference in the APC Suggested RPM Limits or Safety Limits for MR and SF props. 

The MR prop RPM limit is 105,000 RPM / dia. in Inches, the SF limit is 65,000 RPM / dia. in Inches. That gives the MR props some advantage in that they can be run with confidence at an RPM that is up to 40% higher than the SF props. And I say "with confidence" because the APC RPM limits appear to be conservative. They can be used up to their limits and even a little over without shedding blades. 

The SF prop will do better on less power at lower RPM and then, as the RPM increases, the MR prop will come into the zone where it is better. So this is like arguing that apples are better than oranges. 

The recommended RPM limits on the 10" and 12" APC SF props in the comparison testing summary charts posted above would 6,500 and 5,416 RPM. The MR 10" and 12" props would be good up to 10,500 and 8,750 by the maker's recommendations. 

When the SF props do appear to be holding their or with or even outperforming the MR props on thrust, it is when they are being used beyond their recommended limits. Not a good idea at all. 

The thrust from a prop comes with the RPM. And the input power required to attain a specific RPM will be fairly constant. Any motor that is fairly well matched to the prop as far as the Kv and battery voltage, and that can handle the input power without overheating, will give you about the same thrust with a given prop. So using one specific motor and trying to compare the performance 10" and 12" props and slow fly and non-slow props is going to have some combos that are not as well matched as others and some points in the RPM range where one cannot do as well as the other. 

And then how you fly the props will change things again. You can't really expect to take a motor and prop combo that works well for a lower energy type of flying (photo, FPV, etc.) and expect it to do as well in higher energy types of flying. 

Essential Parameters

GPS/Positioning related
Default
Current
Remark
GPSGLITCH_RADIUS
200
100
GPS refresh rate is 5hz. 1m deviation per 0.2 sec should be a reasonable range
GPSGLITCH_ACCEL
1000
1000
to 900?
GPSGLITCH_ENABLE
1
1
FS_GPS_ENABLE
1(land)
2(althold)
FENCE_ENABLED
0
0
NOT used currently
AHRS_EKF_USE
0
0
EKF is in beta stage still, do not try to use it

Monday, 18 August 2014

Pixhawk LED and sound AC3.2

EKF / InertialNav Failsafe

EKF / InertialNav Failsafe

ArduCopter 3.2 adds an EKF (Extended Kalman Filter – Pixhawk only) and Inertial Nav (Pixhawk and APM2) check to catch flyaways caused by bad position estimates.


When will it trigger?


Once the vehicle is armed with GPS lock, the EKF / InertialNav check runs 10 times per second and checks the health of the EKF (if using Pixhawk with AHRS_EKF_USE = 1) or the InertialNav system (APM2 or Pixhawk with AHRS_EKF_USE = 0).
  • the EKF’s health is checked using it’s compass and velocity “variance”.  This “variance” increases as the estimates become untrustworthy.  0 = very trustworthy, >1.0 = very untrustworthy.  If both variances climb above the EKF_CHECK_THRESH parameter (default is 0.6) the EKF/Inav failsafe triggers.
  • the Inertial Nav’s (i.e. 3rd order complementary filter) health is checked using it’s horizontal acceleration corrections.  These corrections grow large (above 1m/s/s) when the filter is having trouble reconciling the GPS and accelerometer data so when they grow above the EKF_CHECK_THRESH the failsafe is triggered.


related commits:


Sunday, 17 August 2014

Color Detection & Object Tracking [reference]

Color Detection & Object Tracking



Mat imgThresholded;

inRange(imgHSV, Scalar(iLowH, iLowS, iLowV), Scalar(iHighH, iHighS, iHighV), imgThresholded); //Threshold the image


The function checks the range as follows:
  • For every element of a single-channel input array:
    \texttt{dst} (I)= \texttt{lowerb} (I)_0  \leq \texttt{src} (I)_0 \leq  \texttt{upperb} (I)_0
  • For two-channel arrays:
    \texttt{dst} (I)= \texttt{lowerb} (I)_0  \leq \texttt{src} (I)_0 \leq  \texttt{upperb} (I)_0  \land \texttt{lowerb} (I)_1  \leq \texttt{src} (I)_1 \leq  \texttt{upperb} (I)_1
  • and so forth.
That is, dst (I) is set to 255 (all 1 -bits) if src (I) is within the specified 1D, 2D, 3D, ... box and 0 otherwise.


//morphological opening (remove small objects from the foreground)
erode(imgThresholded, imgThresholded, getStructuringElement(MORPH_ELLIPSE, Size(5, 5)) );
dilate( imgThresholded, imgThresholded, getStructuringElement(MORPH_ELLIPSE, Size(5, 5)) ); 

//morphological closing (fill small holes in the foreground)
dilate( imgThresholded, imgThresholded, getStructuringElement(MORPH_ELLIPSE, Size(5, 5)) ); 
erode(imgThresholded, imgThresholded, getStructuringElement(MORPH_ELLIPSE, Size(5, 5)) );



Saturday, 16 August 2014

MinAreaRect angles

MinAreaRect angles - Unsure about the angle returned



I'm going to assume you're using C++, but the answer should be the same if you're using C or Python.
The function minAreaRect seems to give angles ranging from -90 to 0 degrees, not including zero, so an interval of [-90, 0).
The function gives -90 degrees if the rectangle it outputs isn't rotated, i.e. the rectangle has two sides exactly horizontal and two sides exactly vertical. As the rectangle rotates clockwise, the angle increases (goes towards zero). When zero is reached, the angle given by the function ticks back over to -90 degrees again.
So if you have a long rectangle from minAreaRect, and it's lying down flat, minAreaRect will call the angle -90 degrees. If you rotate the image until the rectangle given by minAreaRect is perfectly upright, then the angle will say -90 degrees again.
I didn't actually know any of this (I procrastinated from my OpenCV project to find out how it works :/). Anyway, here's an OpenCV program that demonstrates minAreaRect if I haven't explained it clear enough already:

Tesseract - change language file location

http://stackoverflow.com/questions/6950977/tesseract-change-language-file-location

Yes, you can, by setting the TESSDATA_PREFIX environment variable

tesseract-ocr parameters in 3.02 version

„Tesseract is extremely flexible, if you know how to control it. There is a large number of control parameters to modify its behaviour. While these change from time to time, most of them are fairly stable.“ (Tesseract ControlParams wiki)
If you want to get all list of parameters (variables) with its description and default values, you have to search tesseract code. Or continue reading… ;-)
There are two way how to set parameter:
  • config file
  • Tesseract-OCR API

Contours : Getting Started



Tuesday, 12 August 2014

Fine tune of new frame - YAWING issue

Parameter:

new V type :


  • during yaw, front motor gain 0.5, rear gain 0.68. This is supposed to cancelled any rolling moment in steady yawing (but not during acceleration)
  • pitch gain (1.0) is higher than roll gain (0.71), compensating shorter longitudinal length, compared to span.
result:
yaw rate is limited drastically, but it is still reasonably fast
  • roll/pitch:
  • yaw:

test RC_FEEL_RP:

  • 100
  • 90
  • 80 feels much smoother
  • 50
test ATC_ACCEL_Y_MAX:

test ATC_RATE_FF_ENABLE

Sunday, 10 August 2014

Performance Measurement and Improvement Techniques

Performance Measurement and Improvement Techniques


Measuring Performance with OpenCV


Default Optimization in OpenCV

Many of the OpenCV functions are optimized using SSE2, AVX etc. It contains unoptimized code also. So if our system support these features, we should exploit them (almost all modern day processors support them). It is enabled by default while compiling. So OpenCV runs the optimized code if it is enabled, else it runs the unoptimized code. You can use cv2.useOptimized() to check if it is enabled/disabled and cv2.setUseOptimized() to enable/disable it. Let’s see a simple example.
# check if optimization is enabled
In [5]: cv2.useOptimized()
Out[5]: True

In [6]: %timeit res = cv2.medianBlur(img,49)
10 loops, best of 3: 34.9 ms per loop

# Disable it
In [7]: cv2.setUseOptimized(False)

In [8]: cv2.useOptimized()
Out[8]: False

In [9]: %timeit res = cv2.medianBlur(img,49)
10 loops, best of 3: 64.1 ms per loop
See, optimized median filtering is ~2x faster than unoptimized version. If you check its source, you can see median filtering is SIMD optimized. So you can use this to enable optimization at the top of your code (remember it is enabled by default).

Friday, 8 August 2014

  • Stabilize Roll/Pitch P controls the responsiveness of the copter’s roll and pitch to pilot input and errors between the desired and actual roll and pitch angles.  The default of 4.5 will command a 4.5deg/sec rotation rate for each 1 degree of error in the angle.
      • The higher the P the faster the copter will be asked to turn to get to the desired angle.
      • A high P will cause the copter to oscillate back and forth like a seesaw a few times a second.
      • A low P will cause the copter to move very slowly. A very low P will cause the copter to feel unresponsive and could cause a crash if the wind disturbs it.
  • Rate Roll/Pitch P, I and D terms control the output to the motors based on the desired rotation rate from the upper Stabilize (i.e. angular) controller.  These terms are generally related to the power-to-weight ratio of the copter with more powerful copters requiring lower rate PID values.  For example a copter that accelerates very quickly might have Rate Roll/Pitch P number of 0.08 while a more sluggish copter might use 0.18.
      • Rate Roll/Pitch P is the single most important value to tune correctly for your copter.
      • The higher the P the higher the motor response to achieve the desired turn rate.
      • Default is P = 0.15 for standard Arducopter.
      • Rate Roll/Pitch I is used to compensate for outside forces that would make your copter not maintain the desired rate for a longer period of time
      • A high I term will ramp quickly to hold the desired rate, and will ramp down quickly to avoid overshoot.
      • Rate Roll/Pitch D is used to dampen the response of the copter to accelerations toward the desired set point.
      • A high D can cause very unusual vibrations and a “memory” effect where the controls feel like they are slow or unresponsive.
      • Values as low as 0.001 and as high as .02 have all been used depending upon the vehicle

Thursday, 7 August 2014

Ardu Pirate's Motor Mixing Guidelines

Hi Pirates, based on Hein's comments, I'm going to try to explain how is the mixing of the motors done, depending on the layout/position of your ship's motors.
All mixing depends directly on the motor's positions and layout proportions. Depending on it's position each motor needs to apply different strength to pitch and roll axles. In other words, the farthest a motor is from a axle, the stronger it will have to pull.
This strength is set for each motor in the motor mixing (motors.pde) as meanings of a percentual value, that will multiply pitch and roll values used to calculate the final value for each motor.
When the percentage is 100%, it is not necessary to add any value, as we would be multiplying by 1.

Pitch and Roll Axles

Pitch and Roll axles will be used as reference to find the needed strength for each motor:
The axles layout will help to understand and locate what will the values for each motor be, and it's sign.
As for the Yaw, things are simpler, as it just depends on the rotation direction of the motor:
If Motor turns ClockWise (CW) Yaw is Negative.
If Motor turns CounterClockWise (CCW) Yaw is Positive.
I will try to explain it using exampes for the frames we commonly use:

Quad + mode

Ok, let's start with a simple Quad in + mode:
As all 4 motors are on the axles, they all will have 100% and 0% as strength values, in more detail:
MotorPitchRollYaw
0 Right CCW-0%-100%+
1 Left CCW+0%+100%+
2 Front CW+100%0%-
3 Back CW-100%0%-
Thus the resulting pseudo-code would have these signs and values:
rightCCW = - (0 * Pitch) - (1 * Roll) + Yaw
leftCCW = + (0 * Pitch) + (1 * Roll) + Yaw
frontCW = + (1 * Pitch) + (0 * Roll) - Yaw
backCW = - (1 * Pitch) - (0 * Roll) - Yaw
and the final code in Motors.pde, adding throttle and controlling total motor value not to get out of bounds, would be:
rightCCW = constrain(throttle - control_roll + control_yaw, minThrottle, 2000);
leftCCW = constrain(throttle + control_roll + control_yaw, minThrottle, 2000);
frontCW = constrain(throttle + control_pitch - control_yaw, minThrottle, 2000);
backCW = constrain(throttle - control_pitch - control_yaw, minThrottle, 2000);

I plan to do what is called a "pull" to made changes to the custom code regarding custom shaped copters.  
This change in code would only impacts irregular shaped quads, hexas, and octas when the pilot specifically opts to go custom versus the default (the standard X or +).  You have a custom quad if the:
o aspect ratio <> 1 (length is different than width).
o rotors are non symmetric around the
   - forward axis (y) going through the center of gravity (CG)
   - sideways axis (x) going through the CG
   - vertical axis (z) going through the CG
o has a front that is more open for a camera
o deviates from the pictures of a a + or X for the quad, hexa, or octa
o this includes ships described as spider, V, H, U, 88--88, C, etc.
o motor spin direction(s) are different than the pictures
o your CG is pushed somewhere else besides the centroid of the motors.
The advantages of going custom is that the motor factors will be tuned to the coordinate/spin system of your copter versus the coordinate/spin system of the regular copter.  They will fly better.  Pilots will probably not notice small deviations nor would they see significantly improved flight times.  Large deviations might be noticed and provide noticeable changes in flight duration.
Please reply with the motor number (the out-pin number on the APM), coordinates of the motor, and rotation direction of each rotor.  For example,
the owner of this copter would reply (motor number, x, y, CCW/CW):
o 1 (400, 200) CCW 
o 2 (-250, -200) CCW
o 3 (-400, 200), CW
o 4 (250, -200 CW
[note:  no need to tell us your units of measure just so long as you are consistent in measuring; say mm or inches]
Please note:
o The center of gravity of any quad spider or V is not necessarily where the bars cross.  The bars typically cross behind the CG.  .
o The CG is the center of the coordinates or (0,0) where x=0 and y=0
If you decide to participate by replying, the idea is that you will be able to access your custom motor factors without having to compile firmware.  No promises at this point.  First we see what's out there.  But if you do reply, it's far more likely that your design will be implemented in the library.  
If you have any questions or difficulties in doing this, let me know so I can help.

Monday, 28 July 2014

Saturday, 26 July 2014

How to build your own Quadcopter Autopilot / Flight Controller

Back to my home page
How to build your own Quadcopter Autopilot / Flight ControllerBy Dr Gareth Owen (drgowen@gmail.com)3DR QuadcopterFig 1: 3DR Quadcopter

Friday, 25 July 2014

Pseudovector

Physical examples of pseudovectors include magnetic fieldtorquevorticity, and the angular momentum.
Each wheel of a car driving away from an observer has an angular momentum pseudovector pointing left. The same is true for the mirror image of the car.
Consider the pseudovector angular momentum L = r × p. Driving in a car, and looking forward, each of the wheels has an angular momentum vector pointing to the left. If the world is reflected in a mirror which switches the left and right side of the car, the "reflection" of this angular momentum "vector" (viewed as an ordinary vector) points to the right, but the actual angular momentum vector of the wheel (which is still turning forward in the reflection) still points to the left, corresponding to the extra minus sign in the reflection of a pseudovector.
The distinction between vectors and pseudovectors becomes important in understanding the effect of symmetry on the solution to physical systems. Consider an electrical current loop in the z = 0 plane that inside the loop generates a magnetic field oriented in the z direction. This system is symmetric (invariant) under mirror reflections through this plane, with the magnetic field unchanged by the reflection. But reflecting the magnetic field as a vector through that plane would be expected to reverse it; this expectation is corrected by realizing that the magnetic field is a pseudovector, with the extra sign flip leaving it unchanged.
http://www.altdev.co/2013/03/15/what-is-gimbal-lock-and-why-do-we-still-have-to-worry-about-it/
In linear algebra, an orthogonal matrix is a square matrix with real entries whose columns and rows are orthogonal unit vectors (i.e., orthonormal vectors), i.e.
Q^\mathrm{T} Q = Q Q^\mathrm{T} = I,


In mathematics, a linear map (also called a linear mapping, linear transformation or, in some contexts, linear function) is a mapping V ↦ W between two modules (includingvector spaces) that preserves (in the sense defined below) the operations of addition and scalar multiplication. 


In mathematics, the orthogonal group of dimension n, denoted O(n), is the group of distance-preserving transformations of aEuclidean space of dimension n that preserve a fixed point, where the group operation is given by composing transformations. 
Equivalently, it is the group of n×n orthogonal matrices of a given dimension, where the group operation is given by matrix multiplication, and an orthogonal matrix is a real matrix whose inverse equals its transpose.

The determinant of an orthogonal matrix being either 1 or −1, an important subgroup of O(n) is the special orthogonal group, denoted SO(n), of the orthogonal matrices of determinant 1