Author Topic: How I made my nanovoltmeter  (Read 6598 times)

0 Members and 1 Guest are viewing this topic.

Offline jaromirTopic starter

  • Supporter
  • ****
  • Posts: 338
  • Country: sk
How I made my nanovoltmeter
« on: May 16, 2022, 03:41:43 pm »
it is nearly 256 days since TiN released his call for nanovoltmeter designs [1] and it trigerred quite a few responses here [2].
I tinkered with DIY test gear before, but dedicated micro- and nano-voltmeters were always too niche and mysterious for me, so this contest didn't resonate with me too much at first. In fact, I never operated any nanovoltmeter before, had zero practical experience in low-level voltage measurement and it took me a few days to pluck up the courage for this voltnuttery area.

I will not repeat all the stuff I already wrote into public repository here [3]. so perhaps just small recap of the design process. As usual, the major starting problem was getting single piece of metal enclosure of right size that doesn't cost an arm and leg. I found some enclosures at Modushop [4], but it still needed some minor adjustments, like workarounding weird decision of using self-taper screws.
Electrical design was centered around finding good low noise amplifier. I went through half a dozen of test designs to finally settle on paralleled MCP6V51 opamps as good compromise between price, parameters and "time to market" (which is always major constraint in contests). The rest of analog circuitry wasn't that complicated - main amplifier with switchable gain, plus few MUXes and relays to connect the respective amplifiers where needed. I implemented automatic calibration (ACAL) which is not that complicated for voltmeters - it takes resistor divider string and way to attach one of divider outputs to amplifier input. Assuming good ADC linearity and known one voltage on the string, ACAL algorithm can measure voltages by more than one measurement range and calculate gains and offsets of amplifiers. One those are known, each range gain and offset can be adjusted.
ADC is of integrating charge balance type, with now rundown and residual integrator voltage readout. I could have perfectly used integrated sigma-delta ADC, but this was more fun.
One of funny aspects of this design was PSU - at first I was aiming at 50Hz dual back-to-back transformer type, but halfway through I realized I can feed the transformer by audio amplifier and local oscillator. That enables both DC power operation as well as AC line power (by using appropriate AC/DC power module).
Also, this project is GPIB playground. I never implemented any GPIB device, so I thought like this is good opportunity before this interface slowly fades into history. Unfortunately, deadline approached earlier than I expected, so I postponed it for later. But ethernet interface works and talks via SCPI-like commands.

The major design goals set up by the contest - 30nV p-p noise@10Hz, nV/10V combined inputs and two switchable inputs - were met and I'm happy to learn a thing or two, with byproduct of gaining an actual nanovoltmeter (NVM). It could be improved by many ways, a few major TODO points are also included in the repository and I'll try to address them as soon as possible.

While working on this project I realized it's probably quite complex and I really felt like it could be done in simpler way, albeit with less stringent design criteria. I cherrypicked some parts of this NVM and integrated then into much cheaper and simpler instrument. I really hoped to finish it until deadline, so I can present both full blown and budget versions of NVM, but unfortunately I had to focus more on the large one, so NVM junior has to wait a bit. Surely I'll share the design publicly and announce it here, too.

Attached are pictures of a whole device, short term noise measurement and 1uV steps provided by Keithley 260 source. Also, you may take a look into imgur album with random photo dump [5]


[1] https://xdevs.com/article/nvm_comp/
[2] https://www.eevblog.com/forum/metrology/nanovolt-design-challenge-build-and-show-your-own-nv-meter-in-256-days/
[3] https://github.com/jaromir-sukuba/nvm
[4] https://modushop.biz/site/
[5] https://imgur.com/a/fnK1Evj

Offline macaba

  • Regular Contributor
  • *
  • Posts: 205
  • Country: gb
Re: How I made my nanovoltmeter
« Reply #1 on: May 16, 2022, 03:48:52 pm »
Great work Jaromir, you're an inspiration to us all.
 
The following users thanked this post: Timeok

Online RoGeorge

  • Super Contributor
  • ***
  • Posts: 6202
  • Country: ro
Re: How I made my nanovoltmeter
« Reply #2 on: May 16, 2022, 04:15:37 pm »
Wow!  :-+

Online mawyatt

  • Super Contributor
  • ***
  • Posts: 3267
  • Country: us
Re: How I made my nanovoltmeter
« Reply #3 on: May 16, 2022, 04:30:36 pm »
Superb work, and stunning effort  :clap:

Really like the way you approached this task, the selection of the MCP6V51, and clever use of audio amp to drive the power transformer  :-+

Please post more details and images if you can, and thanks again.

Edit: Forgot to ask if you noticed any artifacts from the chopping action of the MCP6V51? Since you are using 100 devices, do they show a subtle beat against each other, or maybe injection lock to each other? Didn't notice the chopping frequency mentioned in the data sheet, but appears from some of the graphs to be ~50KHz.

Best,
« Last Edit: May 16, 2022, 05:23:28 pm by mawyatt »
Curiosity killed the cat, also depleted my wallet!
~Wyatt Labs by Mike~
 

Online DH7DN

  • Regular Contributor
  • *
  • Posts: 128
  • Country: de
    • DH7DN Blog
Re: How I made my nanovoltmeter
« Reply #4 on: May 16, 2022, 06:37:58 pm »
Congrats for completing the challenge. Thanks for sharing! ;D
vy 73 de DH7DN, My Blog
 

Offline branadic

  • Super Contributor
  • ***
  • Posts: 2390
  • Country: de
  • Sounds like noise
Re: How I made my nanovoltmeter
« Reply #5 on: May 17, 2022, 05:26:32 am »
Maybe you would like to add third input channel to the wish list, which allows for 3-cornered hat method measurement without rearranging the connections?

Where do I have to send money to get one of this units? :)

-branadic-
Computers exist to solve problems that we wouldn't have without them. AI exists to answer questions, we wouldn't ask without it.
 
The following users thanked this post: TiN, egonotto, Okertime

Online tggzzz

  • Super Contributor
  • ***
  • Posts: 19507
  • Country: gb
  • Numbers, not adjectives
    • Having fun doing more, with less
Re: How I made my nanovoltmeter
« Reply #6 on: May 17, 2022, 07:18:06 am »
Apart from anything else, congratulations on the superb documentation. That does you a great deal of credit!
There are lies, damned lies, statistics - and ADC/DAC specs.
Glider pilot's aphorism: "there is no substitute for span". Retort: "There is a substitute: skill+imagination. But you can buy span".
Having fun doing more, with less
 

Online Kleinstein

  • Super Contributor
  • ***
  • Posts: 14198
  • Country: de
Re: How I made my nanovoltmeter
« Reply #7 on: May 17, 2022, 04:11:53 pm »
A really nice project. The nV preamplifier is a bit brute force, but doing its job.
There are a few points I find a little odd - some could be due to the tight deadline:
1) The AZ switching may have quite some charge pulse at the input and could this effect the low pass filter. So I would consider to combine the AZ switching an filter selection and not share R1 for the filter and direct path. This way the filter + AZ combination could use the normal path as a kind of pre-charge.

2) The amplification for the residual charge amplification is very low (~1/10). With a rundown phase the residual charge left is expected to be quite small. A gain of some 5-10 could be useful to reduce the quantization noise below the noise of the residual charge.

3) The overflow detection would only detect gross overlaod, but not occasional clipping from superimosed hum.

Maybe you would like to add third input channel to the wish list, which allows for 3-cornered hat method measurement without rearranging the connections?

Where do I have to send money to get one of this units? :)

-branadic-

I think the 3 cornered hat (and a few other tests) would need additional switching at the low side. So another relay from ground to 2 more terminals, not so much a 3rd normal input.

 

Offline jaromirTopic starter

  • Supporter
  • ****
  • Posts: 338
  • Country: sk
Re: How I made my nanovoltmeter
« Reply #8 on: May 18, 2022, 09:59:12 am »
Thank you guys for your feedback, it's very appreciated.

A really nice project. The nV preamplifier is a bit brute force, but doing its job.
There are a few points I find a little odd - some could be due to the tight deadline:
1) The AZ switching may have quite some charge pulse at the input and could this effect the low pass filter. So I would consider to combine the AZ switching an filter selection and not share R1 for the filter and direct path. This way the filter + AZ combination could use the normal path as a kind of pre-charge.
I probably know what you mean, but I did not completely understand how would you modify the AZ switching/filter part. Moving pin 6 of U1B to other side of R1?

2) The amplification for the residual charge amplification is very low (~1/10). With a rundown phase the residual charge left is expected to be quite small. A gain of some 5-10 could be useful to reduce the quantization noise below the noise of the residual charge.

Current prototype of the ADC doesn't use rundown, just residual reading after runup, so that I scaled down full integrator swing to fit ADC range. This simple approach is fine for this application.
I'm planning to play around with rundown, though, in that case I can change the amplifier gain.

3) The overflow detection would only detect gross overlaod, but not occasional clipping from superimosed hum.
Yes, this serves to sense gross overload, to keep LNA safer from user error - determined person will always find a way to destroy a thing, though.


Please post more details and images if you can, and thanks again.

It's quite a task to document the instrument in very detailed way, but I can try. Are there any specific details you are interested in or you found lacking?

Edit: Forgot to ask if you noticed any artifacts from the chopping action of the MCP6V51? Since you are using 100 devices, do they show a subtle beat against each other, or maybe injection lock to each other? Didn't notice the chopping frequency mentioned in the data sheet, but appears from some of the graphs to be ~50KHz.
I did not see much of an chopping artifacts, but I can take more detailed look, thanks for this suggestion.
 

Online Kleinstein

  • Super Contributor
  • ***
  • Posts: 14198
  • Country: de
Re: How I made my nanovoltmeter
« Reply #9 on: May 18, 2022, 11:51:45 am »
Thank you guys for your feedback, it's very appreciated.

A really nice project. The nV preamplifier is a bit brute force, but doing its job.
There are a few points I find a little odd - some could be due to the tight deadline:
1) The AZ switching may have quite some charge pulse at the input and could this effect the low pass filter. So I would consider to combine the AZ switching an filter selection and not share R1 for the filter and direct path. This way the filter + AZ combination could use the normal path as a kind of pre-charge.
I probably know what you mean, but I did not completely understand how would you modify the AZ switching/filter part. Moving pin 6 of U1B to other side of R1?

Moving pin6 of U1B to the other side of R1 would be a way, though with still an additonal resistor in series. This way reading the path withput the fitler would than no longer disturb the filter.
I would than also eliminate U1A and thus have the filter input side always connected. The filter has no gain and should not effect the other path.
The no longer needed U1A part could than be used to substitude U3 (DG419) for the AZ switching. So there are 3 paths to chose: zero, the direct path with a new 16 K resistor or the filter. AZ mode with the filter should than use a short (e.g. a few µs) phase with the direct path as a precharge to reduce the charge spike towards the filter.


When running the ADC similar to the 34401, without rundown, the low gain for the resual charge makes sense. With a rundown one should get better resolution, which can be a big plus for the ACAL part. The quatization noise could still be a relevant part of the noise, expecially for the faster conversions.
With the MS-3 like ADC I still see an uncertainty in the exact timing of the auxiliary ADC reading and thus kowning how much of the last feedback step is before or after the residual charge reading.

Without the filter the AZ mode samples the input only half the time and this gives additional noise bandwidth or aliasing from noise in the 25 Hz band (for 1 PLC). So filtering out that band helps to reduce the extra noise from sampling the input only half the time. The 10 Hz low pass filter would especially make sense together with the 1 PLC AZ mode. For suppressing mains hum the filter can also help.

The non AZ mode seems to work quite well, as the ADC can be low dirft and the front amplifier is an AZ type anyway. So it looks like it is real option to use the ADC in the non AZ mode, up to 6 digit resolution. It may still help to have AZ mode, as there can be long time drift in the ADC. This is not only the amplifiers, but also the resistor networks and a change in the charge injection of the 4053 or just leakage currents.

I just saw one more easy improvement near the ADC. Especially with the LM399 reference it makes sense to have some filtering between the reference and the ref. amplifier (U16). This would be for noise in the frequency band around 1/4-1/2 the runup modulation. So some 50-200 kHz, and thus not much RC filtering (e.g. 1 K and 100 nF) needed to reduce the noise of the reference effecting the ADC.

For a lower const ("junior" version) it should be OK to use MORN resistor networks instead of the LT5400. They should even fit on the same foot-print (just no substrate pad).
 

Offline jaromirTopic starter

  • Supporter
  • ****
  • Posts: 338
  • Country: sk
Re: How I made my nanovoltmeter
« Reply #10 on: May 18, 2022, 01:26:34 pm »
Thanks Kleinstein, I see now.
Switches rearranging and optimization sounds good. I'll consider it for next PCB revision.
 

Online Kleinstein

  • Super Contributor
  • ***
  • Posts: 14198
  • Country: de
Re: How I made my nanovoltmeter
« Reply #11 on: May 18, 2022, 06:29:03 pm »
For reducing the power consumption one could save a little with the +-8/9 V supply for the 100 MCP6V51. Best would be a lower votlage transformer tap. A small improvement could be done with a separate recitifer and choke or more resistor before the filter cap to improve on the power factor. Ideally this may reduce the power by some 30%, with a resistor more like 10% maybe 15% of an improvement.

Another possible saving could be possible by using simple passive averaging instead of inverting summing amplifiers, at least for the first step. This could save 10 of the MCP6V51.

I don't think one would really need the offset compensation for the input. The input offset should be pretty small (e.g. 10 µV range or less) and thus even in the 100 µV range only 10% of the range lost. If really needed a single selected resistor could be good enough, but I would expect it to end up not populated.
The bias current compensation could likely also get away with a simpler DAC. This may than eliminate the +-2.8 V reference levels.

For the 9 mV test signal one should get away with MOSFET / DG419 switching instead of the Reed relays. A pair of 2N7002 should do the job nearly as good and with less power. At least the one that is active when not in used could be replaced.

With the ADC good for +-10 V, why are the test signal for ACAL using 700 mV and 70 mV and not 900 mV or 1 V, so closer to the full scale ?
To improve on the ACAL procedure, one could also use additional negative test points (needs however extra HW). This would provide more points for self testing (the gain for the positive and negative side should be the same) and make ACAL a little less sensitive to the INL.

I don't know if it is already used, but there may be the option to improve on the ADC noise: the auxiliary ADC could read the residual charge a few times over consecutive cycles, and not just once for the start and stop. Thus would result in an slightly extended input aperture and modified frequency response (more attenuation of higher frequencies). In addition the oversampling of the auxiliary ADC could reduce the noise, especially if still limited by the quantization noise at shorter integration.

If crazy for very low noise also in the AZ mode, there would be a possible upgrade of the main amplifier to give not only a +10 / +100 fold gain, but also a negative output to create a differential signal. This way one could get an AZ mode with nearly 100% sampling of the input and thus the lower effective bandwidth of the no AZ mode. It would mainly be a thing for the 10 PLC AZ mode, for 1 PLC the 10 Hz fitler could do much of the job.
 
The following users thanked this post: jaromir

Offline Jeff eelcr

  • Frequent Contributor
  • **
  • Posts: 265
  • Country: us
Re: How I made my nanovoltmeter
« Reply #12 on: May 19, 2022, 02:47:58 pm »
Very, very nicely designed and lay out is fantastic.
Jeff
 

Offline ZhuraYuk

  • Regular Contributor
  • *
  • Posts: 56
  • Country: ua
Re: How I made my nanovoltmeter
« Reply #13 on: May 26, 2022, 08:14:49 am »
jaromir Did you conducted any testing or measurements of thermal EMF for your selected relays G6KU-2? Also did you considered using AD8428 in the input amplifier, they has filter outputs and averaging noise seems to be better when you using them.
 

Online Kleinstein

  • Super Contributor
  • ***
  • Posts: 14198
  • Country: de
Re: How I made my nanovoltmeter
« Reply #14 on: May 26, 2022, 09:02:22 am »
Latching relays often have a reasonable low thermal EMF. With essentially no power from the relay itself chances are that thermal gradients are small and constant. It still depends on the layout and surrounding - often more than the relay type.

The AD8428 has low voltage noise, but quite some current noise and drift in the input bias. So it is not that attractive, especially if you combine several in parallel. The real world time scale of interrest is usually slower than 0.1 - 10 Hz and more like 100-1000 seconds. So the relevant noise is more like the noise at 0.01 or 0.1 Hz. At 0.1 Hz the AD8428 has comparable voltage noise to a single MCP6V51 and it gets wose with lower frequency. Possible chopping with a relay in front would be slow and with relatively frequent switching could cause thermal problems even with latching relays.

So the AD8428 (3 or 4 or them in parallel) may be a cheap way to meet the 0.1-10 Hz target of the contest. However it is not suitable for a nV meter input.
 

Offline jaromirTopic starter

  • Supporter
  • ****
  • Posts: 338
  • Country: sk
Re: How I made my nanovoltmeter
« Reply #15 on: May 26, 2022, 11:50:02 am »
jaromir Did you conducted any testing or measurements of thermal EMF for your selected relays G6KU-2?

It is difficult to differentiate between TEMF of relays and rest of test setup. PCB layouts and wiring definitely comes into play here.
I did input switching test - that is switching between both inputs, with shorting plug connected to the input terminal. This way I'm measuring not just relays, but the difference between TEMF from 'relay - PCB - internal wiring - front panel terminal - contacts - shorting plug' paths of both channels.
The difference seems to be around 40nV.
 
The following users thanked this post: egonotto, Kleinstein, 2N3055, ch_scr, ZhuraYuk, Anders Petersson, DH7DN

Offline MegaVolt

  • Frequent Contributor
  • **
  • Posts: 917
  • Country: by
Re: How I made my nanovoltmeter
« Reply #16 on: September 12, 2022, 04:28:47 pm »
What kind of solder was used in the input part?
 

Offline maxwell3e10

  • Frequent Contributor
  • **
  • Posts: 869
  • Country: us
Re: How I made my nanovoltmeter
« Reply #17 on: July 25, 2023, 06:21:51 pm »
It's an old post, but I am hoping jaromir is still willing to answer questions about this impressive design. I am wondering if you ever tried to measure the current noise of the nanovoltmeter, measure it with a high input resistor across. The spec sheet of MCP6V51 says it's only a few fA/sqrt(Hz), but some measurements mentioned indicate it maybe orders of magnitude higher.
 

Offline aronake

  • Regular Contributor
  • *
  • Posts: 187
  • Country: hk
Re: How I made my nanovoltmeter
« Reply #18 on: July 26, 2023, 09:57:11 pm »
Extremely impressive project!

Has anyone else build one who can share some expreiences?
 


Share me

Digg  Facebook  SlashDot  Delicious  Technorati  Twitter  Google  Yahoo
Smf