Reformat the date and time, and also show nanoseconds using mathlab

I made a program about the moving object distance calculation,I have problem in finding time to receive and send the difference to be precise in order of nano, how to find the mathlab retrieve data with nanosecond.thx

 Accepted Answer

You need to tell us more about the data representation.
Are these value serial date numbers? If so then
>> eps(now)
ans =
1.16415321826935e-10
>> ans * 24*60*60
ans =
1.00582838058472e-05
which tells you that you cannot get higher resolution than 1000 nanoseconds using that format.
If you are trying to time events using tic and toc, then you will find that those clocks are only defined down to milliseconds (1000 Hz). To go beyond that requires system-dependent methods.

4 Comments

thanx mr.walter roberson.
in the system that I created,I send the signal automatically and receive automatic.I want to calculate the difference between the signals sent and received by the order of nano second.can you tell me how to find that.
thx
How are the signals being sent and how are they being received? Is there a clock that is synchronized between the two of them? Is this a theoretical question based upon the distance and the medium and the path length and the temperature, or is this a practical question of how a receiver can figure out how long a signal was in transit?
If this is the practical matter of a receiver figuring out how long a signal was in transit, then I am not certain whether it is possible with a single source, but I would suggest that you study the way that it is done for GPS.
I'm looking for how matlab can find the time to nano-second?
The following code that I created but can not make time to nano..
function Tx_send_Callback(hObject, eventdata, handles)
TxText = get(handles.Tx_send, 'string');
fprintf(handles.serConn, TxText);
currList = get(handles.history_box, 'String');
set(handles.history_box, 'String', ...
[currList ; ['Sent = ' date(now) ': ' TxText] ]);
set(handles.history_box, 'Value', length(currList) + 1 );
set(hObject, 'String', '');
Mathworks does not provide any means to time serial device events to nanoseconds. If you had the Data Acquisition Toolbox and were receiving the data with an appropriate card, you might be able to get access to higher resolution time stamps; I do not know how accurate they can go.
Recall that a nanosecond only about 2 clock cycles on a 2 GHz CPU. There is no way that an interpreted language such as MATLAB running on a multiprocessing system is going to be able to reliably interrupt and access hardware clock cycle counters within 2 instructions. For nanosecond measurements, you need a real-time device or additional hardware support.

Sign in to comment.

More Answers (2)

The "now" function is only good to about 0.015 sec accuracy. You should not use it for any timing that you need more precisely than that. e.g., run this code (Ctrl-C to stop it):
n = now;
while( true )
m = now;
if( m ~= n )
disp((m-n)*86400);
n = m;
end
end
You will have to get more precise timing some other way. e.g., if you have an OpenMP capable compiler you could get MTIMESX from the FEX and use its omp_get_wtime functionality. e.g.,
n = mtimesx('omp_get_wtime');
while( true )
m = mtimesx('omp_get_wtime');
if( m ~= n )
disp(m-n);
n = m;
end
end
On my system the above returns differences on the order of 1.5e-5 seconds (I presume this is all system dependent), so maybe something like this will work for you. MTIMESX (which admittedly is overkill for your situation) can be found here:

3 Comments

Note that eps(now)*86400, which gives a result in the 1e-5 range, is misleading. The "now" function is *not* that accurate as the above test code will show you.
n = now;
while( true )
m = now;
if( m ~= n )
disp((m-n)*86400);
n = m;
end
end
how to see the difference time in orde nano seconds from the program?
You could multiply the difference by 10^9, but as discussed above that number not be meaningful to within 15000 nanoseconds.

Sign in to comment.

how i can get the compiler openMP

1 Comment

That is a new question on a different topic; please start a new thread.

Sign in to comment.

Categories

Community Treasure Hunt

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

Start Hunting!