8834
Kommentar:
|
20141
Features in the pipeline
|
Gelöschter Text ist auf diese Art markiert. | Hinzugefügter Text ist auf diese Art markiert. |
Zeile 1: | Zeile 1: |
[[TableOfContents]] | [[TableOfContents(2)]] |
Zeile 4: | Zeile 4: |
The tool measures the vibration generated by the motors using the MK build-in sensors. This allows to balance motor/prop assemblies and to experiment with different motor-mounts. | The tool evaluates the vibration generated by the motors which allows balancing motor/prop assemblies and experimenting with different motor-mounts. The test uses the MK build-in sensors, so no extra hardware is required. Reducing vibration is very important, especially for Aerial Photography or Video. Vibrations result in blurry footage. Some claim that high frequency vibrations can be picked up by the Optical Image Stabilization lens assembly which is incorporated in almost all recent cameras. The OIS is not designed for these vibrations and makes thing worse, even when you switch the OIS feature off in the camera menu. In addition, the FlightControl sensors pickup the vibrations and this deteriorates performance; the new FC ME comes with vibration dampers in order to reduce the vibrations transferred to the FC. Propellers can be balanced the traditional way. However it was discovered that also the motors need balancing. One way to accomplish this is let a small unbalance in the prop compensate the motor unbalance, so the orientation of the prop is important (see [http://www.rcgroups.com/forums/showpost.php?p=12832508&postcount=228 this post]). Looking at the vibraions of a running motor allows balancing the prop/motor assembly as a whole. = How does it work? = The standard FlightControl program samples all sensors periodically and provides a command to read the latest sample from all sensors. The MKTool uses this command to generate graphs of the analog values. In a first approach the VibrationTest used this standard command to monitor vibrations. The problem is that this mechanism only allows to sample the values 30 times a second. The actual shape of the signals cannot be determined and one can only hope to catch the peak values. In order to get reliable results the values need to be monitored for a long time (a minute for example). This new approach is based on dedicated FlightControl software providing a new command. The new command instructs the FC to sample one of the sensors as fast as possible and store the info in its internal memory. Afterwards the recorded data can be read to analysis. This allows to grab a reliable signal in a very short time. This approach can capture about 11000 samples a second, 500 times more than the MKTool can. |
Zeile 7: | Zeile 17: |
[[Anchor(SampleSignalJpg)]] | |
Zeile 10: | Zeile 20: |
Zeile 12: | Zeile 21: |
The current implementation is very basic, it is a "command-line" tool without any graphical user-interface. I am still experimenting and working on the first version of the tool. Currently the tool was only tested on PC/Windows with FC 1.3 hardware. |
/!\ ~+'''The version available now (version 0.0) is an alpha version; it was only tested by a limited amount of people. More testers/evaluators are very welcome!'''+~ [[BR]][[BR]] The current implementation does not provide a graphical user interface; it is a "command-line" tool. While this approach is a bit less user-friendly, it allows to experiments more freely, which is important at this stage of the project. Later a more fancy user-interface might be added. [[BR]][[BR]] At the time of writing, the tool was tested in combination with: * PC/Windows XP and Vista * FC 1.2 and FC 1.3 Theoretically the tool should also run on MAC and Linux. [[BR]][[BR]] Features in the pipeline * Option to change the minimum battery voltage * Filtering of the signal * Graphical User Interface * Automatic backup and restore of flight settings * Automatic installing and restore of RC flight code [[BR]][[BR]] {i} [http://forum.mikrokopter.de/topic-11446.html MK Forum thread for discussions] [[BR]] {i} [[MailTo(frederic AT rc-flight DOT be)]] |
Zeile 19: | Zeile 42: |
The tool is written in programming language called [http://en.wikipedia.org/wiki/Python_(programming_language) Python]. The most logic and clean way to run the tool is to install support for Python on your PC (if you do not have it already). Python is also available for Linux and MAC; the tool should also run on these platforms, but I have never tried it. If you do not feel like installing Python, a version that is compiled to a windows executable is provided. So, you have two options. [[Anchor(InstallPython)]] |
|
Zeile 20: | Zeile 52: |
The tool is written in Python. In case you have heard of python, have look in [http://en.wikipedia.org/wiki/Python_(programming_language) Wikipedia]. In order to run the tool, you need to install support for Python on your PC. It you do not have Python installed on you PC, I propose you install: [http://www.activestate.com/activepython/ ActivePython for Windows] and [http://sourceforge.net/projects/pyserial/files/ PySerial (support for serial port access)] Python is also available for Linux and MAC. Once you have Python support on your PC all you need to is place the files VibrationTest.py and mkProto.py from [http://svn.mikrokopter.de/mikrowebsvn/listing.php?repname=Projects&path=%2FVibrationTest%2Ftrunk%2FVibrationTest%2F#_VibrationTest_trunk_VibrationTest_ SVN] together in a directory. == Option 2: Get compiled version == It should be possible to compile python applications to a windows executable. I did not investigate this approach yet. = Installing the FlightControl software = The VibrationTest tool works in combination with a special version of the FlightControl software. It must be flashed in the FC board before using the test and you need to reinstall your regular software version afterwards. This just takes a few minutes. Switching the software is done the usual way, using the MKTool. You can grab the latest version of the VibrationTest-FC.hex file from [http://svn.mikrokopter.de/mikrowebsvn/listing.php?repname=Projects&path=%2FVibrationTest%2Ftrunk%2FExecutables%2FFlightCtrl%2F#_VibrationTest_trunk_Executables_FlightCtrl_ SVN] |
For a Windows machine I propose you install: * [http://www.activestate.com/activepython/ ActivePython for Windows] Press the big "ActivePython Download Now" button. * [http://sourceforge.net/projects/pyserial/files/ PySerial (support for serial port access)] Select "pyserial-2.5-rc1.win32.exe" on that page. Once you have Python support on your PC, unzip [http://www.rc-flight.be/VibrationTest/VibrationTest_0_0.zip VibrationTest_0_0.zip] to a directory on your PC. == Option 2: Get the compiled version == unzip [http://www.rc-flight.be/VibrationTest/VibrationTestExe_0_0.zip VibrationTestExe_0_0.zip] to a directory on your PC |
Zeile 41: | Zeile 63: |
== Attach you MK to the table :) == |
== Prepare your MK == === Secure your MK === I use luggage straps to secure my MK to the table while it is still able to vibrate: attachment:mk1InTest.jpg === Installing the FlightControl software === The VibrationTest tool only works in combination with a special version of the FlightControl software. It must be flashed in the FC board before using the test and '''you need to reinstall your regular software version afterwards'''. This just takes a few minutes. Switching the software is done the usual way, using the MKTool. You will find the required hex file in the same directory with the VibrationTest tool. /!\ '''The FC code for the VibrationTest is based 0.74d but is not fit for flying! Before flying, you will need to reinstall your initial FC code. When the version you use for flying is 0.74d, your settings should be preserved. In combination with other versions, it might not be the case. It is a good idea to backup yout settings to PC (via the MKTool) before installing the VibrationTest FC code. ''' After insatlling the FC code for the VibrationTest, the LC-Display in the MKTool will look like this: attachment:LCDisplay.jpg == The command line == The current implementation of the tool does not have a graphical user interface. The simplest way to use the tool is from the command prompt. On Windows XP open a command shell by selecting Start>Run and typing "cmd". On Windows Vista, click Start and type "cmd.exe" in the "Start Search" box. Now, if you have for example unzipped the tool (the Pyhton version or the compiled version) in directory "D:\MK\VibrationToolExe" you should go to that directory by typing: {{{ D: cd \MK\VibrationToolExe }}} Now, the tool can be started by just typing "VibrationTest.py" if you have installed Python or "VibrationTest" if you use the compiled version. Without any parameters, it tool should display a description of the required parameters. attachment:cmdLine.jpg |
Zeile 44: | Zeile 99: |
The tool expects to be started with a few parameters. When the tool is started without or invalid parameters, a brief description of the expected parameters is displayed: |
|
Zeile 66: | Zeile 123: |
== General procudure == == Example 1 == |
4 parameters are mandatory: COMPORT MOTORS SPPEDS and CHANNELS * '''COMPORT''': The serial port that is connected to the MK e.g. "COM4" * '''MOTORS''': List of motors (comma-separated) that need to run during the test. Typically only one motor will be selected. It is also possible to activate all motors to evaluate the global vibrations before and after calibration for example. e.g. "1" or "1,2,3,4" * '''SPEEDS''': List of speeds at which will be tested. The "speed" is the I2C value that will be sent to controller and is a value between 0 and 255. Typically interesting values for vibration-testing vary between 100 and 200. [[BR]]There are 2 formats possible. First there is the simple list of speeds, e.g. "100,150,190,200". The second format specifies the minimum, maximum speed and step, e.g. "100-200:20" will test at 100,120,140 ... 200 * '''CHANNELS''': List of "channels" that will be monitored. A channel is in fact one of the MK analog sensors. Measuring the pressure or battery does not make much sense in this context, but is it possible. It is my experience that channel 6 and 7 produce best vibration signals, but YMMV. [[BR]] In addition, these optional parameters can be provided * '''-m MINSPEED''': The motor(s) will first be started at "idle" speed before being spooled up to the speed at which the measurement will take place. By default, this speed is 25 but it can be changed with this option. Your motors need to run smootly and start reliably at this speed. In combination with the TP converted ESC for example, the default value of 25 will be too low. * '''-s NBSAMPLES''': During a measurement, the FlightControl board will monitor a given channel and store 1000 samples in memory. Afterwards the VibrationTool will read these samples. These samples can be dumped in a file (see the "-d" option) and will be used to find the amplitude of the signal (the difference between the minimum and maximum measured value). [[BR]]It is important to read enough samples to cover a few periods. By default 400 samples are read but with this option, the number of samples can be modified (with a maximum of 1000). * '''-n NAME''': An indication of what you are testing. This string will be added to the dumps (see "-d" option) and should not contain spaces e.g. "-n AfterBalancing" * '''-d FILENAME''': With this option, all samples will be dumped in a text-file. This file can later be used for further analysis. It can for example be inported in MS Excel or OpenOffice Calc to make graphs of the vibration signal. When the file does not exist yet it will be created, otherwise the new data will be added. All measurements dumped in the same file should have the same number of samples (see the "-s" option) e.g. "-d motor1.txt" * '''-v''': With this option, the tool will be much more verbose; it will indicate what it is doing. Also when an error occurs, the tool will provide more technical details (the callstack) == The output == === The results on the screen === Without the "-v" option, only the results of the test is displayed: {{{ C:\DATA\temp\VibrationTestExe>VibrationTest COM5 1 100,150 6 -n Demo Demo Speed=100 U=12.1V Channel=AccRoll Min=497 Max=506 pp= 9 * Demo Speed=150 U=11.9V Channel=AccRoll Min=498 Max=508 pp= 10 ** }}} * "'''Demo'''" This is the name of the test as we provided with the "-n" option. * "'''Speed=100'''" Indicates the motor speed for this measurement * "'''U=12.1V'''" The measured battery voltage when the measurement was done * "'''Channel=AccRoll'''" The measured channel * "'''Min=497'''" Lowest value of all samples * "'''Max=506'''" Highest vale of all samples * "'''pp=9'''" Difference between Min and Max, this is the actual result * "'''**'''" The number of stars gives a quick indication of the pp-value With the "-v" option more details are provided: {{{ C:\DATA\temp\VibrationTestExe>VibrationTest COM5 1 100,150 6 -n Demo -v comPort = COM5 motors = ['1'] minSpeed = 25 speeds = ['100', '150'] channels = ['6'] nbSamples= 400 fileName = None testName = Demo Opening comPort... Version: 0.74 Voltage: 12.1V Minimum Voltage: 10.5V Starting motor(s) (speed=25)... OK Setting speed to 100 ... Getting data... Demo Speed=100 U=12.1V Channel=AccRoll Min=496 Max=508 pp= 12 ** Setting speed to 150 ... Getting data... Demo Speed=150 U=11.9V Channel=AccRoll Min=497 Max=508 pp= 11 ** }}} === The dumped signal === The "-d" option allows to dump the measured signal in a text-file. This is a "comma-separated" text file that can easily be imported in MS Excel or OpenOffice Calc. [[Anchor(DumpedSignalJpg)]] attachment:calc.jpg 1000 samples are acoputed in about 90ms (0.09 s), the time between samples is about 0.9 ms (0.00009 s). Suppose the prop is spinning at 5000 RPM, this means 83 rotations per second. In 0.09s we have captured 7.5 rotations. We we take 400 of the 1000 samples we should see 7.5/1000*400 = 3 rotations of the prop. == Proposed procedure to balance prop/motor assembly == First we need to find what what sensor provides the "best" footage of the vibrations. The largest signal is probably the best. Candidates are Gyro and Acc signals. My experience is that AccNick (channel 7) and especially AccRoll (channel 6) provide the nicest signal, but YMMV. The vibration will typically peak at a certain motor speed. So, first we perform a sweep between speeds 100 to 200 and look at channels 6 and 7 and choose a channel and speed we will concentrate on. Next I check if the prop can be balanced a bit better. I stick small strips of tape to the prop, close to the center. One strip to the side where the prop-dimension is mentioned I denote as "-1", one strip on the other side, I denote "+1". I test different configurations and check what gives the best results for my chosen channel and speed. Now that the prop is better balanced, I start to rotate the prop in relation to the motor. As names for the test I use "XsA" where "X" is the number of strips and "A" is the angle; e.g. "+1s60" means 2 strips (opposite to the prop-marking) and rotated by 60 degrees (compared to the starting position). Again I try to find the best position. Once we have found the best rotation, we can rebalance the prop in the same way as before. After all this we should have found the best combination. We can perform the swipe again to compare with the starting point. === Example 1 === This is an example with standard Roxxy 2824-34 motor with EPP 1045 prop. [[BR]] |
Zeile 74: | Zeile 205: |
Zeile 76: | Zeile 208: |
Zeile 79: | Zeile 210: |
Zeile 82: | Zeile 212: |
Speed=140 U=11.2V Channel=AccRoll Min=469 Max=519 pp= 50 ********** |
Speed=140 U=11.2V Channel=AccRoll Min=469 Max=519 pp= 50 ********** <<======= |
Zeile 85: | Zeile 214: |
Zeile 88: | Zeile 216: |
Zeile 91: | Zeile 218: |
Zeile 94: | Zeile 220: |
Zeile 102: | Zeile 227: |
So, lets concentrate on channel 6 at speed 140. | So, lets concentrate on channel 6 (AccRoll) at speed 140. |
Zeile 105: | Zeile 231: |
Zeile 115: | Zeile 242: |
For now, 1 sticker seems best. | For now, 1 strip seems best. |
Zeile 118: | Zeile 245: |
Zeile 120: | Zeile 248: |
Zeile 124: | Zeile 251: |
Zeile 128: | Zeile 254: |
Zeile 132: | Zeile 257: |
Zeile 136: | Zeile 260: |
Zeile 140: | Zeile 263: |
Zeile 144: | Zeile 266: |
Zeile 147: | Zeile 268: |
Zeile 149: | Zeile 269: |
Zeile 151: | Zeile 272: |
Zeile 155: | Zeile 275: |
Zeile 159: | Zeile 278: |
Zeile 163: | Zeile 281: |
Zeile 167: | Zeile 284: |
Zeile 170: | Zeile 286: |
So, 2 stickers is best |
So, 2 stickers is best, let's verify again: |
Zeile 174: | Zeile 290: |
Zeile 177: | Zeile 292: |
VibrationTest.py COM5 3 140 6,6,6 -d motor3.txt -n end |
VibrationTest.py COM5 3 140 6 -d motor3.txt -n end |
Zeile 182: | Zeile 296: |
[[BR]] | |
Zeile 183: | Zeile 298: |
Zeile 185: | Zeile 301: |
Zeile 188: | Zeile 303: |
Zeile 191: | Zeile 305: |
Zeile 194: | Zeile 307: |
Zeile 197: | Zeile 309: |
Zeile 200: | Zeile 311: |
Zeile 204: | Zeile 314: |
Zeile 207: | Zeile 315: |
[http://svn.mikrokopter.de/mikrowebsvn/listing.php?repname=Projects&path=%2FVibrationTest%2F#_VibrationTest_ VibrationTest Project in Subversion] Mail: [[MailTo(admin AT rc-flight DOT be)]] |
* [http://forum.mikrokopter.de/topic-11446.html MK Forum thread for discussions] * [http://svn.mikrokopter.de/mikrowebsvn/listing.php?repname=Projects&path=/VibrationTest/#_VibrationTest_ VibrationTest Project in Subversion] * [http://www.rcgroups.com/forums/showthread.php?t=1006721 Old Man Mike "Test Fixture Evaluates Motors/Props/ESCs for Quadcopter Performance"] * Mail FredericG: [[MailTo(frederic AT rc-flight DOT be)]] |
Zeile 212: | Zeile 320: |
/!\ ToDo: * Explain the parameters * The general procedure * Make a hex-file available * Provide a picture of my MK attached to the table [[BR]] [[AttachList]] |
## [[AttachList]] |
Zeile 223: | Zeile 324: |
. KategorieTools |
What is the VibrationTest Tool?
The tool evaluates the vibration generated by the motors which allows balancing motor/prop assemblies and experimenting with different motor-mounts. The test uses the MK build-in sensors, so no extra hardware is required.
Reducing vibration is very important, especially for Aerial Photography or Video. Vibrations result in blurry footage. Some claim that high frequency vibrations can be picked up by the Optical Image Stabilization lens assembly which is incorporated in almost all recent cameras. The OIS is not designed for these vibrations and makes thing worse, even when you switch the OIS feature off in the camera menu. In addition, the FlightControl sensors pickup the vibrations and this deteriorates performance; the new FC ME comes with vibration dampers in order to reduce the vibrations transferred to the FC.
Propellers can be balanced the traditional way. However it was discovered that also the motors need balancing. One way to accomplish this is let a small unbalance in the prop compensate the motor unbalance, so the orientation of the prop is important (see [http://www.rcgroups.com/forums/showpost.php?p=12832508&postcount=228 this post]). Looking at the vibraions of a running motor allows balancing the prop/motor assembly as a whole.
How does it work?
The standard FlightControl program samples all sensors periodically and provides a command to read the latest sample from all sensors. The MKTool uses this command to generate graphs of the analog values. In a first approach the VibrationTest used this standard command to monitor vibrations. The problem is that this mechanism only allows to sample the values 30 times a second. The actual shape of the signals cannot be determined and one can only hope to catch the peak values. In order to get reliable results the values need to be monitored for a long time (a minute for example).
This new approach is based on dedicated FlightControl software providing a new command. The new command instructs the FC to sample one of the sensors as fast as possible and store the info in its internal memory. Afterwards the recorded data can be read to analysis. This allows to grab a reliable signal in a very short time. This approach can capture about 11000 samples a second, 500 times more than the MKTool can.
This is an example of the signal measured by the Roll-ACC sensor: Anchor(SampleSignalJpg) attachment:test.jpg
Current Project status
The version available now (version 0.0) is an alpha version; it was only tested by a limited amount of people. More testers/evaluators are very welcome! BRBR The current implementation does not provide a graphical user interface; it is a "command-line" tool. While this approach is a bit less user-friendly, it allows to experiments more freely, which is important at this stage of the project. Later a more fancy user-interface might be added. BRBR At the time of writing, the tool was tested in combination with:
- PC/Windows XP and Vista
- FC 1.2 and FC 1.3
Theoretically the tool should also run on MAC and Linux. BRBR Features in the pipeline
- Option to change the minimum battery voltage
- Filtering of the signal
- Graphical User Interface
- Automatic backup and restore of flight settings
- Automatic installing and restore of RC flight code
BRBR [http://forum.mikrokopter.de/topic-11446.html MK Forum thread for discussions] BR MailTo(frederic AT rc-flight DOT be)
How do I install the tool?
The tool is written in programming language called [http://en.wikipedia.org/wiki/Python_(programming_language) Python].
The most logic and clean way to run the tool is to install support for Python on your PC (if you do not have it already). Python is also available for Linux and MAC; the tool should also run on these platforms, but I have never tried it.
If you do not feel like installing Python, a version that is compiled to a windows executable is provided.
So, you have two options.
Option 1: Install Python
For a Windows machine I propose you install:
[http://www.activestate.com/activepython/ ActivePython for Windows] Press the big "ActivePython Download Now" button.
[http://sourceforge.net/projects/pyserial/files/ PySerial (support for serial port access)] Select "pyserial-2.5-rc1.win32.exe" on that page.
Once you have Python support on your PC, unzip [http://www.rc-flight.be/VibrationTest/VibrationTest_0_0.zip VibrationTest_0_0.zip] to a directory on your PC.
Option 2: Get the compiled version
unzip [http://www.rc-flight.be/VibrationTest/VibrationTestExe_0_0.zip VibrationTestExe_0_0.zip] to a directory on your PC
How do I use the tool?
Prepare your MK
Secure your MK
I use luggage straps to secure my MK to the table while it is still able to vibrate:
attachment:mk1InTest.jpg
Installing the FlightControl software
The VibrationTest tool only works in combination with a special version of the FlightControl software. It must be flashed in the FC board before using the test and you need to reinstall your regular software version afterwards. This just takes a few minutes. Switching the software is done the usual way, using the MKTool.
You will find the required hex file in the same directory with the VibrationTest tool.
The FC code for the VibrationTest is based 0.74d but is not fit for flying! Before flying, you will need to reinstall your initial FC code. When the version you use for flying is 0.74d, your settings should be preserved. In combination with other versions, it might not be the case. It is a good idea to backup yout settings to PC (via the MKTool) before installing the VibrationTest FC code.
After insatlling the FC code for the VibrationTest, the LC-Display in the MKTool will look like this:
attachment:LCDisplay.jpg
The command line
The current implementation of the tool does not have a graphical user interface. The simplest way to use the tool is from the command prompt.
On Windows XP open a command shell by selecting Start>Run and typing "cmd".
On Windows Vista, click Start and type "cmd.exe" in the "Start Search" box.
Now, if you have for example unzipped the tool (the Pyhton version or the compiled version) in directory "D:\MK\VibrationToolExe" you should go to that directory by typing:
D: cd \MK\VibrationToolExe
Now, the tool can be started by just typing "VibrationTest.py" if you have installed Python or "VibrationTest" if you use the compiled version. Without any parameters, it tool should display a description of the required parameters.
attachment:cmdLine.jpg
The command line parameters
The tool expects to be started with a few parameters. When the tool is started without or invalid parameters, a brief description of the expected parameters is displayed:
VibrationTest.py COMPORT MOTORS SPEEDS CHANNELS [-m MINSPEED] [-s NBSAMPLES] [-n NAME] [-d FILENAME] [-v] COMPORT Serial port to use. e.g. COM4 MOTORS Motors to activate during test. Multiple motors can be used at the same time. e.g. 1,2,3,4 SPEEDS Indicates at what speeds the motors need to be tested. Format 1: e.g. 50,110,140 Tests at speeds 50, 110 and 140 Format 2: e.g. 100-200:50 Tests at speeds 100, 150 and 200 CHANNELS Channels to monitor. e.g. 5,6,7 Channel 0 = GyroYaw Channel 1 = GyroRoll Channel 2 = GyroNick Channel 3 = Pressure Channel 4 = Batt Channel 5 = AccTop Channel 6 = AccRoll Channel 7 = AccNick -m MINSPEED Minimum speed of the motor(s) -s NBSAMPLES Number of samples -n NAME Name of the test -d FILENAME File to which the measured values will be logged in -v Verbose
4 parameters are mandatory: COMPORT MOTORS SPPEDS and CHANNELS
COMPORT: The serial port that is connected to the MK e.g. "COM4"
MOTORS: List of motors (comma-separated) that need to run during the test. Typically only one motor will be selected. It is also possible to activate all motors to evaluate the global vibrations before and after calibration for example. e.g. "1" or "1,2,3,4"
SPEEDS: List of speeds at which will be tested. The "speed" is the I2C value that will be sent to controller and is a value between 0 and 255. Typically interesting values for vibration-testing vary between 100 and 200. BRThere are 2 formats possible. First there is the simple list of speeds, e.g. "100,150,190,200". The second format specifies the minimum, maximum speed and step, e.g. "100-200:20" will test at 100,120,140 ... 200
CHANNELS: List of "channels" that will be monitored. A channel is in fact one of the MK analog sensors. Measuring the pressure or battery does not make much sense in this context, but is it possible. It is my experience that channel 6 and 7 produce best vibration signals, but YMMV.
BR In addition, these optional parameters can be provided
-m MINSPEED: The motor(s) will first be started at "idle" speed before being spooled up to the speed at which the measurement will take place. By default, this speed is 25 but it can be changed with this option. Your motors need to run smootly and start reliably at this speed. In combination with the TP converted ESC for example, the default value of 25 will be too low.
-s NBSAMPLES: During a measurement, the FlightControl board will monitor a given channel and store 1000 samples in memory. Afterwards the VibrationTool will read these samples. These samples can be dumped in a file (see the "-d" option) and will be used to find the amplitude of the signal (the difference between the minimum and maximum measured value). BRIt is important to read enough samples to cover a few periods. By default 400 samples are read but with this option, the number of samples can be modified (with a maximum of 1000).
-n NAME: An indication of what you are testing. This string will be added to the dumps (see "-d" option) and should not contain spaces e.g. "-n AfterBalancing"
-d FILENAME: With this option, all samples will be dumped in a text-file. This file can later be used for further analysis. It can for example be inported in MS Excel or OpenOffice Calc to make graphs of the vibration signal. When the file does not exist yet it will be created, otherwise the new data will be added. All measurements dumped in the same file should have the same number of samples (see the "-s" option) e.g. "-d motor1.txt"
-v: With this option, the tool will be much more verbose; it will indicate what it is doing. Also when an error occurs, the tool will provide more technical details (the callstack)
The output
The results on the screen
Without the "-v" option, only the results of the test is displayed:
C:\DATA\temp\VibrationTestExe>VibrationTest COM5 1 100,150 6 -n Demo Demo Speed=100 U=12.1V Channel=AccRoll Min=497 Max=506 pp= 9 * Demo Speed=150 U=11.9V Channel=AccRoll Min=498 Max=508 pp= 10 **
"Demo" This is the name of the test as we provided with the "-n" option.
"Speed=100" Indicates the motor speed for this measurement
"U=12.1V" The measured battery voltage when the measurement was done
"Channel=AccRoll" The measured channel
"Min=497" Lowest value of all samples
"Max=506" Highest vale of all samples
"pp=9" Difference between Min and Max, this is the actual result
"**" The number of stars gives a quick indication of the pp-value
With the "-v" option more details are provided:
C:\DATA\temp\VibrationTestExe>VibrationTest COM5 1 100,150 6 -n Demo -v comPort = COM5 motors = ['1'] minSpeed = 25 speeds = ['100', '150'] channels = ['6'] nbSamples= 400 fileName = None testName = Demo Opening comPort... Version: 0.74 Voltage: 12.1V Minimum Voltage: 10.5V Starting motor(s) (speed=25)... OK Setting speed to 100 ... Getting data... Demo Speed=100 U=12.1V Channel=AccRoll Min=496 Max=508 pp= 12 ** Setting speed to 150 ... Getting data... Demo Speed=150 U=11.9V Channel=AccRoll Min=497 Max=508 pp= 11 **
The dumped signal
The "-d" option allows to dump the measured signal in a text-file. This is a "comma-separated" text file that can easily be imported in MS Excel or OpenOffice Calc.
Anchor(DumpedSignalJpg) attachment:calc.jpg
1000 samples are acoputed in about 90ms (0.09 s), the time between samples is about 0.9 ms (0.00009 s). Suppose the prop is spinning at 5000 RPM, this means 83 rotations per second. In 0.09s we have captured 7.5 rotations. We we take 400 of the 1000 samples we should see 7.5/1000*400 = 3 rotations of the prop.
Proposed procedure to balance prop/motor assembly
First we need to find what what sensor provides the "best" footage of the vibrations. The largest signal is probably the best. Candidates are Gyro and Acc signals. My experience is that AccNick (channel 7) and especially AccRoll (channel 6) provide the nicest signal, but YMMV. The vibration will typically peak at a certain motor speed. So, first we perform a sweep between speeds 100 to 200 and look at channels 6 and 7 and choose a channel and speed we will concentrate on.
Next I check if the prop can be balanced a bit better. I stick small strips of tape to the prop, close to the center. One strip to the side where the prop-dimension is mentioned I denote as "-1", one strip on the other side, I denote "+1". I test different configurations and check what gives the best results for my chosen channel and speed.
Now that the prop is better balanced, I start to rotate the prop in relation to the motor. As names for the test I use "XsA" where "X" is the number of strips and "A" is the angle; e.g. "+1s60" means 2 strips (opposite to the prop-marking) and rotated by 60 degrees (compared to the starting position). Again I try to find the best position.
Once we have found the best rotation, we can rebalance the prop in the same way as before.
After all this we should have found the best combination. We can perform the swipe again to compare with the starting point.
Example 1
This is an example with standard Roxxy 2824-34 motor with EPP 1045 prop. BR
Finding what sensor provides best information at what speed:
VibrationTest.py COM5 3 100-200:20 6,7 Speed=100 U=11.3V Channel=AccRoll Min=492 Max=505 pp= 13 ** Speed=100 U=11.3V Channel=AccNick Min=498 Max=507 pp= 9 * Speed=120 U=11.3V Channel=AccRoll Min=489 Max=503 pp= 14 ** Speed=120 U=11.3V Channel=AccNick Min=497 Max=507 pp= 10 ** Speed=140 U=11.2V Channel=AccRoll Min=469 Max=519 pp= 50 ********** <<======= Speed=140 U=11.2V Channel=AccNick Min=495 Max=508 pp= 13 ** Speed=160 U=11.1V Channel=AccRoll Min=478 Max=517 pp= 39 ******* Speed=160 U=11.1V Channel=AccNick Min=493 Max=511 pp= 18 *** Speed=180 U=10.9V Channel=AccRoll Min=479 Max=511 pp= 32 ****** Speed=180 U=10.9V Channel=AccNick Min=493 Max=514 pp= 21 **** Speed=200 U=10.7V Channel=AccRoll Min=479 Max=515 pp= 36 ******* Speed=200 U=10.7V Channel=AccNick Min=493 Max=513 pp= 20 **** VibrationTest.py COM5 3 130-160:10 6 Speed=130 U=11.1V Channel=AccRoll Min=484 Max=511 pp= 27 ***** Speed=140 U=11.1V Channel=AccRoll Min=469 Max=524 pp= 55 *********** Speed=150 U=11.1V Channel=AccRoll Min=475 Max=520 pp= 45 ********* Speed=160 U=11.1V Channel=AccRoll Min=479 Max=518 pp= 39 *******
So, lets concentrate on channel 6 (AccRoll) at speed 140.
Now, the preliminary balancing of the prop:
VibrationTest.py COM5 3 140 6 -d motor3.txt -n 0s0 0s0 Speed=140 U=11.0V Channel=AccRoll Min=470 Max=521 pp= 51 ********** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s0 1s0 Speed=140 U=11.0V Channel=AccRoll Min=482 Max=513 pp= 31 ****** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 2s0 2s0 Speed=140 U=11.0V Channel=AccRoll Min=475 Max=520 pp= 45 *********
For now, 1 strip seems best.
Now, lets rotate the prop:
VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s0 1s0 Speed=140 U=10.9V Channel=AccRoll Min=481 Max=513 pp= 32 ****** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s60 1s60 Speed=140 U=10.9V Channel=AccRoll Min=480 Max=512 pp= 32 ****** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s120 1s120 Speed=140 U=10.9V Channel=AccRoll Min=477 Max=514 pp= 37 ******* VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s180 1s180 Speed=140 U=10.9V Channel=AccRoll Min=482 Max=509 pp= 27 ***** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s240 1s240 Speed=140 U=10.9V Channel=AccRoll Min=482 Max=510 pp= 28 ***** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s300 1s300 Speed=140 U=10.9V Channel=AccRoll Min=482 Max=514 pp= 32 ****** VibrationTest.py COM5 3 140 6,6,6 -d motor3.txt -n 1s360 1s360 Speed=140 U=10.9V Channel=AccRoll Min=482 Max=515 pp= 33 ******
Rotating the prop by 180 degrees produces best results, now lets try to balance the prop again:
VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s180 1s180 Speed=140 U=10.9V Channel=AccRoll Min=483 Max=509 pp= 26 ***** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 0s180 0s180 Speed=140 U=10.9V Channel=AccRoll Min=472 Max=519 pp= 47 ********* VibrationTest.py COM5 3 140 6 -d motor3.txt -n 1s180 1s180 Speed=140 U=10.9V Channel=AccRoll Min=483 Max=510 pp= 27 ***** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 2s180 2s180 Speed=140 U=10.9V Channel=AccRoll Min=489 Max=508 pp= 19 *** VibrationTest.py COM5 3 140 6 -d motor3.txt -n 3s180 3s180 Speed=140 U=10.9V Channel=AccRoll Min=483 Max=512 pp= 29 *****
So, 2 stickers is best, let's verify again:
VibrationTest.py COM5 3 140 6 -d motor3.txt -n 2s180 2s180 Speed=140 U=10.9V Channel=AccRoll Min=488 Max=508 pp= 20 **** VibrationTest.py COM5 3 140 6 -d motor3.txt -n end end Speed=140 U=10.8V Channel=AccRoll Min=487 Max=510 pp= 23 ****
BR Now, we can perform a sweep in order to compare with the starting-point:
VibrationTest.py COM5 3 100-200:20 6,7 Speed=100 U=11.1V Channel=AccRoll Min=493 Max=501 pp= 8 * Speed=100 U=11.1V Channel=AccNick Min=499 Max=507 pp= 8 * Speed=120 U=11.1V Channel=AccRoll Min=489 Max=507 pp= 18 *** Speed=120 U=11.1V Channel=AccNick Min=497 Max=508 pp= 11 ** Speed=140 U=11.0V Channel=AccRoll Min=489 Max=507 pp= 18 *** Speed=140 U=11.0V Channel=AccNick Min=498 Max=509 pp= 11 ** Speed=160 U=10.9V Channel=AccRoll Min=482 Max=508 pp= 26 ***** Speed=160 U=10.9V Channel=AccNick Min=496 Max=510 pp= 14 ** Speed=180 U=10.7V Channel=AccRoll Min=489 Max=505 pp= 16 *** Speed=180 U=10.7V Channel=AccNick Min=495 Max=508 pp= 13 ** Speed=200 U=10.6V Channel=AccRoll Min=482 Max=508 pp= 26 ***** Speed=200 U=10.6V Channel=AccNick Min=491 Max=509 pp= 18 ***
Links
[http://forum.mikrokopter.de/topic-11446.html MK Forum thread for discussions]
[http://svn.mikrokopter.de/mikrowebsvn/listing.php?repname=Projects&path=/VibrationTest/#_VibrationTest_ VibrationTest Project in Subversion]
[http://www.rcgroups.com/forums/showthread.php?t=1006721 Old Man Mike "Test Fixture Evaluates Motors/Props/ESCs for Quadcopter Performance"]
Mail FredericG: MailTo(frederic AT rc-flight DOT be)