07.18.08

Voltage Amplifiers Vs. Charge Amplifiers for Hydrophones

Posted in Electronics, PhD An Acoustic Disdrometer at 2:03 pm by philwinder

I have come to the conclusion that voltage amplifiers are better than charge amplifiers.  Equations state that the gain should be the capacitance of the hydrophone divided by the capacitance of the integrating capacitor.  When creating two circuits with (about) the same gain, the voltage amplifier always outperforms the charge amplifier.

This could be because of a few things.  Firstly, the capacitance of the hydrophone stated in the datasheet may not be true, or the capacitance undesirably alters with frequency.  Or secondly, it could be because the hydrophone, as a model, is a better voltage source than it is a charge source, however this is implicitly the same thing.  I.e. When the structure of the ceramic changes, a charge is formed via electrons jumping into non-stable spaces.  This forms a potential between the terminals on either side of the ceramic and when one side is connected to ground and the other to a load, a current flows.

So, in reality, for hydrophones at least, the two circuits are attempting to accomplish the same thing.  However, I would be worried that the integration in the charge amplifier would cause the signal to be altered from the delta like pulse to some sinc wave; single-handedly demolishing the drop size-impact pulse relationship.

Feel free to correct me if I am wrong, and here are some images of the results.  The charge amplifier simply didnt have enough gain to get the required results.

Charge Amplifier ResultsVoltage AmplifierVoltage Amplifier Zoomed

Incidently, a differential configuration did not work very well at all.  I thought a differential amplifier would remove a lot of the mains noise, but it didn’t.  Most of the mains must be picked up in the actual circuit, rather than the wire.  To remove the noise I would have to use a DC servo, adding complexity and possibly more capacitors in the path of the signal.

05.15.08

DAQmxReadAnalogF64 Intermittent Warning of 1

Posted in Electronics, PhD An Acoustic Disdrometer, Programming, Qt at 8:12 pm by philwinder

I’ve had a very serious problem recently regarding the long term stability of the NI-4462.

Problem:
Everything works fine for about 20-inf secs but then all of a suddent the DAQmxReadAnalogF64 function returns a 1 rather than a 0.

Solution:
The errors were buffer overrun errors (annoying that the 4462 almost always returns 1 as an error. Not very informative!). This, I eventually figured out, seemed to be happening every time my cpu hit 100% load. Then the DAQ would stop acquiring, post an error of 1 and quit. To fix this I manually set the sampsPerChanToAcquire setting in the DAQmxCfgSampClkTiming function.
Just a bit of background, I am using continuous acquiring, so the sampsPerChan… variable set the hardware buffer size. I am also interrupting every 50000 samples. So setting this value to 200000 or above (i.e. 4x your interrupt generation) seems to get rid of all my intermittent problems!! Woo!

Hope this helps someone in the future…

05.07.08

Acoustic Reflection Testing

Posted in PhD An Acoustic Disdrometer at 10:18 am by philwinder

I’ve been working on decomposing the different parts of the signal received, trying to figure out what each bit is and how to get rid of it.
The main conclusions of which are that bottom->surface reflections are the most predominant in the signal.
The attached two graphs of experiments where I was comparing the signals in a bucket to the signals in the tank, and in the tank at different heights.

The first test shows that side reflections constitute a fair amount of the signal but after the primary reflections have passed the main residing component is the reflections from the surface.  (Although they can still be seen in the signal - just).  The bottom->surface reflections have slightly different path lengths due to the odd shape of the bottom of the bucket and that the hydrophone protrudes by a few cm’s.  These two paths constructively and destructively interfere to produce the remaining oscillatory signal.

The second experiment was to make sure that the remaining signal was produced by surface reflections and not by some resonance in the hydrophone itself.  It can be seen that the cycles following the initial spike occur at a different time depending on the depth.  The deeper the water, the longer it takes the reflection to return back to the hydrophone.  This can be roughly seen but is shrouded by the different path lengths of the other reflections (because the drop wasnt directly over the hydrophone).

This seems to indicate that if we were to dampen the bottom->surface reflections using a lining then a lot of this type of “noise” could be removed.

I also noted that the oil used for this experiment was left in the tank a few days.  It looked like the cooking oil had started to coagulate, and did not behave as intended. (the semi-solid pieces were not recombining quick enough to “heal” the patch where the drop had just landed.)

This also helps to answer another question: How thick does it need to be?
Well this roughly depends on how quick/much it is raining.  If there is a thin film (about 2mm) then when a drop hits the surface it forces the oil away from the impact site.  If another drop was to hit the same place then there would be no oil to stop the bubble noise.  If the film is 2cm deep then the drop doesn’t have enough energy to break through the oil into the water, so if another drop did land in its place, there would still be enough oil left to inhibit bubble noise.  So the only worse case scenario is when one drop hits and another drop at practically the same time hits exactly the same place in the same orientation.  If this happened then a collision between the new drop and the old drop could occur and probably create some strange results.

Having a thicker film also helps to stop the oil coagulating.  So basically, the thicker the better.  BUT we have to make sure that we dont make it too big because reflections will occur on the boundary of the water and the oil and the speed of sound will be different, affecting the TDOA’s.

 Oil in a Tank vs. Oil in a BucketSurface Reflections

04.25.08

Viscosity, not surface tension, is key to mitigating bubble formation - All rise for the scientific Jelly!

Posted in PhD An Acoustic Disdrometer at 2:39 pm by philwinder

Over the past week I have had enough of the surface tension tests since I was getting nowhere. I redid the low surface tension (Ethylene Oxide) and the high surface tension (salt) tests to get some more resolute data. (I thought I might have just been either putting too much in at a time or something.) I found that when I reduced the surface tension this increased the amount of large bubbles being created and the amount that were sustained on the surface (surface bubbles for a long time). This meant that there were some semi-large bubble noise but some utterly huge signals when the large bubbles on the surface popped. Hence, not a good route to go down.

For the higher surface tension test with salt I found that the results were little better. What seems to happen here is that the production of many smaller bubbles is more apparent. Im assuming this is because the large bubbles that are created cannot withstand the pressure inside the water and break up into lots of small bubbles. This is quite good to watch, since the 1 large bubble that is created due to the drop seems to ‘blow up’ and scatter into many smaller bubbles; typically in a spherical arrangement. This also leads to quite a lot of small ‘foam’ on the surface. So the signals from the ‘exploding’ bubbles plus the signal from the drop hitting the foam is also pretty rubbish.

So I sat back and started thinking why oil works so well again. After a small conversation to Sergei we decided that the only other parameter to play with was viscosity. This reminded me of the idea that Kevin had that a change in viscosity may change the frequency of the escaping bubbles. So I thought I would give it a go; a double whammy if you will. Sergei pointed me to Glycerol, stating that it had good thickening properties, but it wasnt very good. Infact it was very similar to the ethylene oxide tried before. So I went back down my simplistic metal path and decided the easiest thing that I could get hold of to make things thicker was Jelly! At worst I would have a nice pudding for tea.

First attempt I didnt use enough jelly, but second attempt I got is spot on. (It is a bit annoying that I have to leave it overnight, but thats the price I pay!) With about a mixture of 3 parts water 1 part jelly-water (as mixed to the directions on the packet) I got a consistency very similar to oil. After a few data captures I knew I was onto a winner.

So, for once I think this almost categorically means that viscosity is the key when trying to minimise bubbles, not surface tension. A nice think liquid acts like a cushion not allowing a depression to form and also preventing the backlash of water that you get on the exit of the bubble.

The images below compare the oil results to the new jelly results. Note the similarity.
The jelly has 3 levels of zoom. The first is the normal 10 second data. The second is zooming in on the noise that you can see in the 10 second data. I think this is the actual oscillation of the liquid iteslf. I could quite easily test for this later. The third image is zoomed right in to the spike itself. The very quick oscillation you can see is reflections of the side walls. These tests are done in a 6×6″ bucket, and will be a lot less in real life. (So will the surface oscillation)

Engine OilJelly - 3-1 Ratio Jelly - 3-1 Ratio (Zoomed to Surface Oscillation).Jelly - 3-1 Ratio (Zoomed to Reverbaration)

04.23.08

PCB Manufacture notes and PreAmpV0.2 Died!

Posted in Electronics, PhD An Acoustic Disdrometer at 8:57 pm by philwinder

Just for future reference (because I always forget), using the naff double sided PCB, 3:30 exposure was enough, but by far and away the most important point was to remember to jam the acetate down to the exposure unit, to the point of stressing the joints. Too many times have I relied on the foam in the lid of the exposure unit only to find that the acetate has warped slightly so I get a blurring after developing. Argh! Never again!

On the preamp front, it died! I dont know why, but I know what could have happened. Today in the lab, I came back from cleaning the “drop chamber”, as I like to call it, plugged it back in and it didnt work. I think it was because there was a DC spike on the output of the hydrophone which then knocked out the amplifier input. Here is my reasoning. I washed the hydrophone in hot water, boiling hot, since its the best way of getting rid of all the contaminants. I think this cause a charge build up in the peizoelectric material (either that or it was still hot, hence a wierd DC value) which then discharged (or stayed the same if it was simply due to the heat) and wiped out the input with a fair amount of voltage.

So next PCB, remember the protection diodes! I didnt put them on this time because I couldnt be bothered, and I didnt think this would happen!

p.s. Also, dont forget to place some text so you know which way round the acetate is supposed to go!  Plus that the text that is to be on the bottom layer should be flipped! Elementary I know, but always forgotten!

New surface tension vs. drop bubble thoughts.

Posted in PhD An Acoustic Disdrometer at 8:57 pm by philwinder

After lots of testing, here is the brief version.  What I have found is that if you lower the surface tension, you increase the longevity and the size of bubbles under, and on top of the water.  If you increase the surface tension, the opposite happens.  You get lots of tiny bubbles.  Neither actually gets rid of bubbles.  (Disclaimer: This could be a coincidence)

Thinking what else could be making the oil work so well in preventing bubble formation is viscosity.  This is the only difference between oil and the rest of the tested liquids.  So I am in the process of making some scientific jelly, but I dont think I’m going to get it quite right to catagorically prove one thing or another (as usual).

The problem I have is the inability to change one single constant.  For example, all the chemicals that are specifically designed for decreasing the surface tension also tend to be quite viscous (although nowhere near oil, and a lot more expensive!) and very very foamy (if that’s a word).  Great for washing machine engineers, bad for scientists.

So in the end, I will still probably end up using oil and although it doesn’t mix,  it does provide good results and its cheap.

04.14.08

Speed test: c++ vs Matlab - Using Multilateration Routines

Posted in PhD An Acoustic Disdrometer, Qt at 10:13 am by philwinder

Quick update, I wanted to try the matlab vs c++ routines again, because from what I can remember, matlab was several orders of magnitude quicker than the c++ program. But I recently found a library in Qt called QVector, which claims to be very quick on the
whole memory front. So I went back and did the test again. (Because for some reason I didnt leave any trail of documentation like I normally do?)

Now notice my shock, suprise and glee when I rewrote the program for Qt 4, put it in release mode instead of debug and opened a large can of groinal kickers on matlab. See the results below.

Programs, settings, etc. __________________________________
Matlab V7.3 (2006b)
Qt V4.3.4 (release mode, default optimisations, single threading, pure c++ (no QVectors etc.)

MATLAB_____________________________________________

x = -0.5; y = -0.24; hydrophoneDepth = -0.3; SoS = 1482; hydrophoneSpacing = 0.5;
T = [1000000*sqrt( x^2 + (y-hydrophoneSpacing)^2 + hydrophoneDepth^2 )/SoS;
1000000*sqrt( (x-hydrophoneSpacing)^2 + y^2 + hydrophoneDepth^2 )/SoS;
1000000*sqrt( x^2 + (y+hydrophoneSpacing)^2 + hydrophoneDepth^2 )/SoS;
1000000*sqrt( (x+hydrophoneSpacing)^2 + y^2 + hydrophoneDepth^2 )/SoS];
tic
for(x = 1:1000000)
SolvePosition(T,hydrophoneSpacing,hydrophoneDepth,SoS);
end
toc
tic
for(x = 1:1000000)
SolvePosition(T,hydrophoneSpacing,hydrophoneDepth,SoS);
end
toc
tic
for(x = 1:1000000)
SolvePosition(T,hydrophoneSpacing,hydrophoneDepth,SoS);
end
toc
tic
for(x = 1:1000000)
SolvePosition(T,hydrophoneSpacing,hydrophoneDepth,SoS);
end
toc

Elapsed time is 18.844249 seconds.
Elapsed time is 18.670732 seconds.
Elapsed time is 18.662103 seconds.
Elapsed time is 18.620391 seconds.

c++_____________________________________________

Starting Test
___Position Solve Speed Test___
This routine tests the speed of c++ vs.
Matlab for our developed Multilateration Algorithm
7015

Starting Test
___Position Solve Speed Test___
This routine tests the speed of c++ vs.
Matlab for our developed Multilateration Algorithm
6985

Starting Test
___Position Solve Speed Test___
This routine tests the speed of c++ vs.
Matlab for our developed Multilateration Algorithm
6969

Starting Test
___Position Solve Speed Test___
This routine tests the speed of c++ vs.
Matlab for our developed Multilateration Algorithm
6984

Note that the c++ program is in ms. It is clear to see that there is a clear speed advantage, not a lot I know, but it is clear. There is also more scope for firstly optimising my code specifically for c++, using more aggressive optimisations in the compiler and also using the fast access libraries included in Qt.

04.01.08

Long time no see

Posted in PhD An Acoustic Disdrometer at 9:28 pm by philwinder

Haven’t updated in a while. Cracking on with the PhD doing lots of experimental work. Lots of time has been put into experimenting with the new hardware setup, PC->NI DAQ->Single Hydrophone, playing with all sorts of different concoctions. Results have been adequate, but not astonishing. The expected amount of bubble noise is there, masking the instant verification that would have been so nice. The most interesting part is that the bubble creates quite a number of frequencies that span from almost-DC to 10’s of kilohertz’s which means that a simple kill-all-bubble noise filter is not as simple as we first thought. Ive attached images of a control test where droplets of about 2mm are dropped from a hight of approximately 3 meters into a tank of water. The first is a simple plot of the data, and the second is a spectrogram showing the different frequency components at different times.

Plot of Droplets in WaterSpectrogram of Drops in Water

Over the past couple of days I have started trying to filter out the bubbles in software, so I don’t have to put so much emphasis on reducing the bubbles at the source.  I have had some success convolving an average of 10 drop pulses and also using the fact that the drop pulse is very delta-like.  In the frequency domain this can be viewed as a broad spectrum, so taking an average of a FFT will produce a high result and others spurious signals give out a low.

12.21.07

Finished Rewriting Routines

Posted in PhD An Acoustic Disdrometer at 11:50 am by philwinder

I have finished rewriting all the subroutines now and I have manage to increase the speed even more. When rewriting, I got rid of any grossly underperforming code and now at 100mm/h it runs through in just under a second.

But once again, the errors are still plaguing the system. At this rainfall rate there are quite a few ghost drops and therefore still quite a lot of missed drops. The one I have just done is at 9% and I can clearly see at least 2 ghost drops. Have to investigate this further.

However, I think its about time I stopped for Christmas, so I don’t think I will be doing much except maybe showing a few people what I have done over the holidays.

Merry Christmas all!

Update
Just a quick update, I continued tarting up the code, and it now reports all ghost drops and all missing drops and why they were missed (ghosting/verification/etc.). Ive just done a beefy test at 100mm/h over 1 second:

run(’..\..\Create Samples\V0_7\V0_7′); V0_9;
7966 Drops Generated
Elapsed time is 143.394716 seconds.
12.7% Error

Thats without all the warning and debug messages. As a results Ive found that the thresholding/peak detection routine does not always find all the pulses. In fact, it only finds them at very slow rain rates. As a consequence I have had to pad the data so they are all the same length. So I am definitely going to have to look into that.

The graph also now shows the errors so it makes them easier to pick out. So just for formality, here are a few screenshots and program outputs:

run(’..\..\Create Samples\V0_7\V0_7′); V0_9;
79 Drops Generated
Elapsed time is 1.486008 seconds.
Ghost Detected at: (0.2093440.1,-0.3657250.1) Due to Pulses: 3774,3492,3380,3705
Ghost Detected at: (0.3033100.1,-0.0157940.1) Due to Pulses: 3619,3407,3602,3758
Ghost Detected at: (-0.0449920.1,0.3495790.1) Due to Pulses: 3481,3749,3880,3702
Ghost Detected at: (0.0771620.1,-0.4683740.1) Due to Pulses: 4014,3790,3505,3864
Ghost Detected at: (0.3148400.1,0.0721700.1) Due to Pulses: 4199,4023,4276,4384
Drop Missed: Number 6. The data did not pass varification tests.
Drop Missed: Number 30. The data was eaten by Ghosts!
Drop Missed: Number 31. The data was eaten by Ghosts!
Drop Missed: Number 32. The data was eaten by Ghosts!
Drop Missed: Number 33. The data did not pass varification tests.
Drop Missed: Number 36. The data was eaten by Ghosts!
Drop Missed: Number 37. The data was eaten by Ghosts!
Drop Missed: Number 38. The data was eaten by Ghosts!
Drop Missed: Number 39. The data was eaten by Ghosts!
Drop Missed: Number 40. The data was eaten by Ghosts!
Drop Missed: Number 41. The data was eaten by Ghosts!
Drop Missed: Number 56. The data did not pass varification tests.
79 drops originally, we have found 67
15.2% Error

And Some output Screenshots:

Data Tank

12.19.07

Slight error in Multilateration Routines

Posted in PhD An Acoustic Disdrometer at 5:20 pm by philwinder

After a knock in the right direction from Kevin, I found a slight error in the Multilateration routines.  When simplifying U, we chose points on the edge of the tank to solve for.  The point which is at the top right of the tank was wrong.  I was solving for x^2+y^2 = 1.  I should have been solving for x^2 + y^2 = d^2.  Fixed that, and now the results are a lot more accurate.  No more inaccuracies around the outsides of the tank.  Somewhere near +/-0.2mm.  Too small to measure.

Still the largest problem is the number of false detects.  I have started rewriting the code, but because of this silly error today, I have not had any time to continue rewriting the rest of the code.

« Previous entries