⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sim_img.m

📁 FIELD II 是B超的matlab仿真程序。 执行 先运行 field_init.m
💻 M
字号:
%  Example of use of the new Field II program running under %  Matlab.%%  This example shows how a linear array B-mode system scans an image%%  This script assumes that the field_init procedure has been called%  Here the field simulation is performed and the data is stored%  in rf-files; one for each rf-line done. The data must then%  subsequently be processed to yield the image. The data for the%  scatteres are read from the file pht_data.mat, so that the procedure%  can be started again or run for a number of workstations.%%  Example by Joergen Arendt Jensen and Peter Munk, %  Version 1.2, August 14, 1998, JAJ.%  Ver. 1.1: 1/4-98: Procedure xdc_focus_center inserted to use the new%                    focusing scheme for the Field II program%  Ver. 2.0: 13/8 2007: Parallel version that checks whether the simulation%                       of a line has been made before, which makes it possible%                       to run the code in parallel on multiple workstations.%  Generate the transducer apertures for send and receivef0=3.5e6;                %  Transducer center frequency [Hz]fs=100e6;                %  Sampling frequency [Hz]c=1540;                  %  Speed of sound [m/s]lambda=c/f0;             %  Wavelength [m]width=lambda;            %  Width of elementelement_height=5/1000;   %  Height of element [m]kerf=0.05/1000;          %  Kerf [m]focus=[0 0 70]/1000;     %  Fixed focal point [m]N_elements=192;          %  Number of physical elementsN_active=64;             %  Number of active elements %  Set the sampling frequencyset_sampling(fs);%  Generate aperture for emissionxmit_aperture = xdc_linear_array (N_elements, width, element_height, kerf, 1, 10,focus);%  Set the impulse response and excitation of the xmit apertureimpulse_response=sin(2*pi*f0*(0:1/fs:2/f0));impulse_response=impulse_response.*hanning(max(size(impulse_response)))';xdc_impulse (xmit_aperture, impulse_response);excitation=sin(2*pi*f0*(0:1/fs:2/f0));xdc_excitation (xmit_aperture, excitation);%  Generate aperture for receptionreceive_aperture = xdc_linear_array (N_elements, width, element_height, kerf, 1, 10,focus);%  Set the impulse response for the receive aperturexdc_impulse (receive_aperture, impulse_response);%   Load the computer phantomif ~exist('pht_data.mat')  disp('Scatterer positions should be made by the script mk_pht')  disp('before this script can be run')  returnelse  load pht_data  end%  Set the different focal zones for receptionfocal_zones=[30:20:200]'/1000;Nf=max(size(focal_zones));focus_times=(focal_zones-10/1000)/1540;z_focus=60/1000;          %  Transmit focus%  Set the apodizationapo=hanning(N_active)';%   Do linear array imagingno_lines=50;                    %  Number of lines in imageimage_width=40/1000;            %  Size of image sectord_x=image_width/no_lines;       %  Increment for image% Do imaging line by linefor i=[1:no_lines]  %  Test if the file for the line exist.  %  Skip the simulation, if the line exits and  %  go the next line. Else make the simulation    file_name=['rf_data/rf_ln',num2str(i),'.mat'];  if ~exist(file_name)        %  Save a file to reserve the calculation        cmd=['save rf_data/rf_ln',num2str(i),'.mat i'];    eval(cmd);        disp(['Now making line ',num2str(i)])      %  The the imaging direction    x= -image_width/2 +(i-1)*d_x;    %   Set the focus for this direction with the proper reference point    xdc_center_focus (xmit_aperture, [x 0 0]);    xdc_focus (xmit_aperture, 0, [x 0 z_focus]);    xdc_center_focus (receive_aperture, [x 0 0]);    xdc_focus (receive_aperture, focus_times, [x*ones(Nf,1), zeros(Nf,1), focal_zones]);    %  Calculate the apodization        N_pre  = round(x/(width+kerf) + N_elements/2 - N_active/2);    N_post = N_elements - N_pre - N_active;    apo_vector=[zeros(1,N_pre) apo zeros(1,N_post)];    xdc_apodization (xmit_aperture, 0, apo_vector);    xdc_apodization (receive_aperture, 0, apo_vector);      %   Calculate the received response    [rf_data, tstart]=calc_scat(xmit_aperture, receive_aperture, phantom_positions, phantom_amplitudes);    %  Store the result    cmd=['save rf_data/rf_ln',num2str(i),'.mat rf_data tstart'];    disp(cmd)    eval(cmd);  else    disp(['Line ',num2str(i),' is being made by another machine.'])    end  end%   Free space for aperturesxdc_free (xmit_aperture)xdc_free (receive_aperture)disp('You should now run make_image to display the image')

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -