Wed 28 Aug 21:38:52 CEST 2024
This commit is contained in:
		
							parent
							
								
									b85ee407c4
								
							
						
					
					
						commit
						3329765caa
					
				
							
								
								
									
										111
									
								
								src/SimNDT/gui/managerPlotsController.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								src/SimNDT/gui/managerPlotsController.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,111 @@ | |||
| __author__ = 'Miguel Molero' | ||||
| 
 | ||||
| from SimNDT.graphics.mplWidget import PlotDialog | ||||
| import numpy as np | ||||
| 
 | ||||
| 
 | ||||
| class ManagerPlots(object): | ||||
|     def plotSingleLaunch(self): | ||||
| 
 | ||||
|         plot = PlotDialog(self) | ||||
|         sig = self.SimNDT_Receivers.getReceivers() | ||||
|         Name = self.SimNDT_Inspection.Name | ||||
| 
 | ||||
|         if Name == "Transmission" or Name == "PulseEcho": | ||||
|             lenght = np.size(sig) | ||||
|             self.SimNDT_Simulation.SimulationTime | ||||
|             time = np.linspace(0, self.SimNDT_Simulation.SimulationTime, lenght) * 1e6 | ||||
| 
 | ||||
|             plot.mpl.ax.plot(time, sig) | ||||
|             plot.mpl.ax.grid(True, color='gray') | ||||
|             plot.mpl.ax.set_title("Time Signal", fontsize=10) | ||||
|             plot.mpl.ax.set_xlabel("Time ($\mu$s)") | ||||
|             plot.mpl.ax.set_ylabel("Amplitude") | ||||
|             plot.show() | ||||
| 
 | ||||
|     def plotLinearScan(self): | ||||
| 
 | ||||
|         plot = PlotDialog(self) | ||||
|         sig = self.SimNDT_Receivers.getReceivers() | ||||
|         Name = self.SimNDT_Inspection.Name | ||||
| 
 | ||||
|         if Name == "LinearScan": | ||||
|             lenght, N = np.shape(sig) | ||||
|             self.SimNDT_Simulation.SimulationTime | ||||
|             time = self.SimNDT_Simulation.SimulationTime * 1e6 | ||||
| 
 | ||||
|             plot.mpl.ax.imshow(sig, extent=[0, N, time, 0], aspect='auto', interpolation=None) | ||||
|             plot.mpl.ax.grid(True, color='gray') | ||||
|             plot.mpl.ax.set_title("Linear Scan", fontsize=10) | ||||
|             plot.mpl.ax.set_ylabel("Time ($\mu$s)") | ||||
|             plot.mpl.ax.set_xlabel("# Signals") | ||||
|             plot.show() | ||||
| 
 | ||||
|     def plotTomoSignals(self): | ||||
| 
 | ||||
|         plot = PlotDialog(self) | ||||
|         sig = self.SimNDT_Receivers.getReceivers() | ||||
|         t = self.SimNDT_Simulation.t | ||||
|         Name = self.SimNDT_Inspection.Name | ||||
|         if Name == "Tomography": | ||||
| 
 | ||||
|             if self.SimNDT_Inspection.OneProjection: | ||||
| 
 | ||||
|                 M, N = np.shape(sig) | ||||
|                 ind = 0 | ||||
|                 delta = 2.0 / float(N) | ||||
|                 ascan = [] | ||||
|                 for i in range(0, N): | ||||
|                     ascan = sig[:, i] / np.max(np.abs(sig)) | ||||
|                     plot.mpl.ax.plot(t * 1e6, ascan + ind) | ||||
|                     plot.mpl.ax.hold(True) | ||||
|                     ind += delta | ||||
|                     plot.mpl.ax.grid(True, color='gray') | ||||
|                     plot.mpl.ax.set_title("Tomography Signals (One Projection)", fontsize=10) | ||||
|                     plot.mpl.ax.set_xlabel("Time ($\mu$s)") | ||||
|                     plot.mpl.ax.set_ylabel("# Signals") | ||||
|                     plot.mpl.ax.set_yticks([]) | ||||
|                     plot.mpl.ax.tick_params(axis='y', which='both', left='off', right='off') | ||||
|             else: | ||||
|                 lenght, R, E = np.shape(sig) | ||||
|                 print(lenght, R, E) | ||||
|                 ind = 0 | ||||
|                 delta = 2.0 / float(R) | ||||
|                 ascan = [] | ||||
|                 for i in range(0, R): | ||||
|                     ascan = sig[:, i] / np.max(np.abs(sig)) | ||||
|                     plot.mpl.ax.plot(t * 1e6, ascan + ind) | ||||
|                     plot.mpl.ax.hold(True) | ||||
|                     ind += delta | ||||
|                     plot.mpl.ax.grid(True, color='gray') | ||||
|                     plot.mpl.ax.set_title("Tomography Signals", fontsize=10) | ||||
|                     plot.mpl.ax.set_xlabel("Time ($\mu$s)") | ||||
|                     plot.mpl.ax.set_ylabel("# Signals") | ||||
|                     plot.mpl.ax.set_yticks([]) | ||||
|                     plot.mpl.ax.tick_params(axis='y', which='both', left='off', right='off') | ||||
| 
 | ||||
|             plot.show() | ||||
| 
 | ||||
|     def spectraSingleLaunch(self): | ||||
| 
 | ||||
|         plot = PlotDialog(self) | ||||
| 
 | ||||
|         sig = self.SimNDT_Receivers.getReceivers() | ||||
|         Name = self.SimNDT_Inspection.Name | ||||
| 
 | ||||
|         if Name == "Transmission" or Name == "PulseEcho": | ||||
|             spectraComplete = np.fft.fft(sig.flatten()) | ||||
|             N2 = np.size(spectraComplete) / 2.0 | ||||
|             spectra = np.abs(spectraComplete[0:N2]) | ||||
|             spectra /= np.max(spectra) | ||||
|             fs = 1.0 / self.SimNDT_Simulation.dt | ||||
|             frequency = np.linspace(0, fs / 2.0, N2) * 1e-6 | ||||
| 
 | ||||
|             plot.mpl.ax.plot(frequency, spectra) | ||||
|             plot.mpl.ax.grid(True, color='gray') | ||||
|             plot.mpl.ax.set_title("Spectra", fontsize=10) | ||||
|             plot.mpl.ax.set_ylim([0, 1.2]) | ||||
|             plot.mpl.ax.set_xlim([0, fs * 1e-6 / 4.0]) | ||||
|             plot.mpl.ax.set_xlabel("Frequency (MHz)") | ||||
|             plot.mpl.ax.set_ylabel("Normalized Magnitude") | ||||
|             plot.show() | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user