Plot Impedance from Touchstone Files

조회 수: 15 (최근 30일)
Ajeya Gupta
Ajeya Gupta 2019년 5월 10일
댓글: Simon 2022년 3월 29일
Hello Guys,
I have been using RF Toolbox quite extensively for my Signal Integrity work. I can import touchstone file, and use 'frplot' function to plot all kinds of SI data (like S11, S22 etc). However, I am not able to plot Impedance graph from touchstone file (.s2p or .s4p or .s8p). Is there a way this can be achieved? Is there a pre-defined function that can be used to plot impedance?
Note: I am currently using MATLAB 2018a version.
Thank you for your help.
  댓글 수: 1
Srikanth K
Srikanth K 2021년 2월 3일
Convert your S-parm file to Z-parm and plot impedance plots..you can use below fucntion to do that.
Z = zparameters('defaultbandpass.s2p');
z11 = rfparam(Z,1,1);
plot(Z.Frequencies, imag(z11)) ;% this is for imaginary part of Z-, change as per your requrements
look below link for more info..
https://www.mathworks.com/help/rf/ref/zparameters.html

댓글을 달려면 로그인하십시오.

채택된 답변

Ajeya Gupta
Ajeya Gupta 2021년 2월 4일
Thanks for your reply, Srikanth. How will the characteristic impedance come into play here? I have a 50 ohms line, and I'd like to plot a TDR graph corresponding to the touchstone file. Moreover, the function 'zparameters' does not give result in time domain (the very definition of TDR plot). Instead the parameters are still in frequency domain!

추가 답변 (1개)

Srikanth K
Srikanth K 2021년 2월 8일
Unfortunatly ,I guess we dont have a direct TDR fucntion but we can make one by writing our own function.
Please find the below link for your refeance.
the above link provides TDR response Time Vs Voltage.You can plot in Impedance vs Time using below script(for referance).
filename = 's_parm.s2p';
S_parm_cb = sparameters(filename);
s11 = rfparam(S_parm_cb,1,1);
freq = S_parm_cb.Frequencies;
Vin = 1;
tdrfreqdata = Vin*(s11+1)/2;
tdrfit = rationalfit(freq,tdrfreqdata,'NPoles',350);
Ts = 5e-12;%
N = 10000; % Number of samples
Trise = 5e-11; % Define a step signal
[Vtdr,tdrT] = stepresp(tdrfit,Ts,N,Trise);
ylabel('Differential TDR (V)');
xlabel('Time (ns)');
legend('Calculated TDR');
ylim([0.46 0.55]);
t11_row=(((2*Vtdr)-Vin)/Vin);
tdrz=50*((1+t11_row)./(1-t11_row));
figure
plot(tdrT*1e9,tdrz,'b','LineWidth',2);
ylabel('TDR (Ohm)');
xlabel('Time (ns)');
legend('Calculated TDR');
ylim([40 60]);
  댓글 수: 2
Ajeya Gupta
Ajeya Gupta 2021년 2월 10일
편집: Ajeya Gupta 2021년 2월 11일
Thanks for sharing this, Srikanth. This is very helpful. I also read the paper in the reference section (https://apps.dtic.mil/dtic/tr/fulltext/u2/a168194.pdf) which has a lot of details related to this implementation.
I did a lot proof reading of this code. One thing that I'v realized is the graph will be plotted only up to Ts*N time value (this product is important to view the data appropriately, since we want the x axis to scale according to the length of DUT. Essentially, the product N*Ts shoud be equal to the product of DUT_Length/Vp (Vp = signal velocity on Copper/Al).
However, one thing that I've realized is that the time where the DUT impedance ends and 50ohms termination starts is always double the electrical length of the DUT. For example, a 1 mtr cable with Vp of 0.77*c should have varying impedance up to 4.22ns. However, the TDR plot from the above code gives an impression that the DUT is 2 meters long (or the DUT impedance ends at ~8.5ns which is approximately double of 4.22ns). I am wondering why does it show like this? I can imagine someone might say that signal travels from Port 1 to Port 2 and back from Port 2 to Port 1, but in that case, I should see an impedance plot and a reverse impedance plot (to show T11 and T22). More than this, I was wondering is there is a rationale in the code behind this, or may be a way to rectify this.
Thank you.
Simon
Simon 2022년 3월 29일
Thank you for your answer, Srikanth and Ajeya Gupta. It is really helpful! But I don't understand how “tdrfreqdata = Vin*(s11+1)/2” and "t11_row=(((2*Vtdr)-Vin)/Vin)" come from. Can you explain it for me? Thank you very much.
My email:919736488@qq.com

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Surface and Mesh Plots에 대해 자세히 알아보기

제품


릴리스

R2018a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by