Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Mismatch (offset?) of data where zero=1 in PGF #8

Open
tuanpham96 opened this issue Dec 9, 2019 · 3 comments
Open

Mismatch (offset?) of data where zero=1 in PGF #8

tuanpham96 opened this issue Dec 9, 2019 · 3 comments

Comments

@tuanpham96
Copy link

tuanpham96 commented Dec 9, 2019

This is a very great tool. However, I have found that for some of the protocols I inherited, the data read from .dat files were offset. For example, here's the file as loaded within PatchMaster
from_PM

And here was the same data read in using the importer and plotted with MATLAB
from_MAT

At first I thought it was somehow multiplied by a factor of 2, but looking closely I realized it was shifted around -70mV (for example, the AP amplitude). I tried exporting these traces to an ITX file and it was fine.

I noticed that I had this particular issue with protocols that has this:
pgf_zero1

whereas protocols with Zero=0 are fine (as in no offset).

Do you know what's happening?

System info:
PatchMaster v2x90.1 on Windows 7
MATLAB R2018b on Windows 10

EDIT:
Apparently the data have already been zeroed when saved (I think). I have turned this line assignment to 0.

tr.TrZeroData = fread(fh, 1, 'double=>double');% = 88; (* LONGREAL *)

tr.TrZeroData = 0; % instead of fread(fh, 1, 'double=>double');%

And it worked for some reason. Is this right? Is there a place that we can check for that?

@ChristianKeine
Copy link
Owner

Hi tuanpham,

my apologies for the late response to this issue. Could you send me an example file to see what's going on? I would have to check what exactly Patchmaster does when the zero-ing is turned on. Is your holding potential perhaps at -70 mV during the experiment?

Thanks.

@ChristianKeine
Copy link
Owner

Hi tuanpham,

so according to the Patchmaster manual, the number in the "zero" column defines the number of the segment in which the zero-offset will be calculated. So I am assuming that the -140 mV in the data trace results from the measured -70 mV holding potential subtracted by -70 mV zero-offset. In my understanding, however, the baseline of your recorded trace should be at 0 mV (-70 mV recorded with -70 mV zero offset), so I am assuming that Patchmaster does not apply the zero offset when displaying the trace? When displaying traces with zero offset and without (both at -70 mV holding), does Patchmaster display them the same, i.e. both starting at around -70 mV?

I think the issue might originate in the following lines in which the TrZeroData is added and not subtracted from the data

for col=1:size(data,2)
data(:,col)=data(:,col)*tr_s(col).TrDataScaler+tr_s(col).TrZeroData;
end

Is this variable indeed -70 mV in your files in which zero offset is active and 0 in files in which zero offset is turned off?
If that is indeed the case, I will adjust the code accordingly.

@tuanpham96
Copy link
Author

Thanks for your reply, I'd have to check back with you on these questions when I'm in the lab in the next couple of weeks just in case.

As far as I can remember, what I did for data that I believe are already offset (or don't need offset) was basically this:

for col=1:size(data,2) 
     data(:,col)=data(:,col)*tr_s(col).TrDataScaler;
end 

I'll check back with you within a week or two about your questions.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants