Debugged getDataArray, same data lengths are now guaranteed
This commit is contained in:
		
							parent
							
								
									13b8a9daec
								
							
						
					
					
						commit
						2fcf325a6e
					
				| @ -117,8 +117,8 @@ class CharacteristicFunction(object): | |||||||
| 
 | 
 | ||||||
|     def getTimeArray(self): |     def getTimeArray(self): | ||||||
|         if self.getTime1(): |         if self.getTime1(): | ||||||
|            incr = self.getARdetStep() |            incr = self.getARdetStep()[0] | ||||||
|            self.TimeArray = np.arange(0, len(self.getCF()) * incr[0], incr[0]) + self.getCut()[0] \ |            self.TimeArray = np.arange(0, len(self.getCF()) * incr, incr) + self.getCut()[0] \ | ||||||
|                            + self.getTime1() + self.getTime2()   |                            + self.getTime1() + self.getTime2()   | ||||||
|         else: |         else: | ||||||
|            incr = self.getIncrement() |            incr = self.getIncrement() | ||||||
| @ -143,18 +143,31 @@ class CharacteristicFunction(object): | |||||||
|         cutting window |         cutting window | ||||||
|         ''' |         ''' | ||||||
|         if cut is not None: |         if cut is not None: | ||||||
|             if self.cut[0] == 0: |             if len(self.orig_data) == 1: | ||||||
|  |                 if self.cut[0] == 0 and self.cut[1] == 0: | ||||||
|                    start = 0 |                    start = 0 | ||||||
|  |                    stop = len(self.orig_data[0]) | ||||||
|  |                 elif self.cut[0] == 0 and self.cut[1] is not 0: | ||||||
|  |                    start = 0 | ||||||
|  |                    stop = self.cut[1] / self.dt | ||||||
|                 else: |                 else: | ||||||
|                    start = self.cut[0] / self.dt |                    start = self.cut[0] / self.dt | ||||||
|                    stop = self.cut[1] / self.dt |                    stop = self.cut[1] / self.dt | ||||||
|             if len(self.orig_data) == 1: |  | ||||||
|                 zz = self.orig_data.copy() |                 zz = self.orig_data.copy() | ||||||
|                 z1 = zz[0].copy() |                 z1 = zz[0].copy() | ||||||
|                 zz[0].data = z1.data[start:stop] |                 zz[0].data = z1.data[start:stop] | ||||||
|                 data = zz |                 data = zz | ||||||
|                 return data |                 return data | ||||||
|             elif len(self.orig_data) == 2: |             elif len(self.orig_data) == 2: | ||||||
|  |                 if self.cut[0] == 0 and self.cut[1] == 0: | ||||||
|  |                    start = 0 | ||||||
|  |                    stop = min([len(self.orig_data[0]), len(self.orig_data[1])]) | ||||||
|  |                 elif self.cut[0] == 0 and self.cut[1] is not 0: | ||||||
|  |                    start = 0 | ||||||
|  |                    stop = self.cut[1] / self.dt | ||||||
|  |                 else: | ||||||
|  |                    start = self.cut[0] / self.dt | ||||||
|  |                    stop = self.cut[1] / self.dt | ||||||
|                 hh = self.orig_data.copy() |                 hh = self.orig_data.copy() | ||||||
|                 h1 = hh[0].copy() |                 h1 = hh[0].copy() | ||||||
|                 h2 = hh[1].copy() |                 h2 = hh[1].copy() | ||||||
| @ -163,6 +176,15 @@ class CharacteristicFunction(object): | |||||||
|                 data = hh  |                 data = hh  | ||||||
|                 return data |                 return data | ||||||
|             elif len(self.orig_data) == 3: |             elif len(self.orig_data) == 3: | ||||||
|  |                 if self.cut[0] == 0 and self.cut[1] == 0: | ||||||
|  |                    start = 0 | ||||||
|  |                    stop = min([len(self.orig_data[0]), len(self.orig_data[1]), len(self.orig_data[2])]) | ||||||
|  |                 elif self.cut[0] == 0 and self.cut[1] is not 0: | ||||||
|  |                    start = 0 | ||||||
|  |                    stop = self.cut[1] / self.dt | ||||||
|  |                 else: | ||||||
|  |                    start = self.cut[0] / self.dt | ||||||
|  |                    stop = self.cut[1] / self.dt | ||||||
|                 hh = self.orig_data.copy() |                 hh = self.orig_data.copy() | ||||||
|                 h1 = hh[0].copy() |                 h1 = hh[0].copy() | ||||||
|                 h2 = hh[1].copy() |                 h2 = hh[1].copy() | ||||||
| @ -195,6 +217,9 @@ class AICcf(CharacteristicFunction): | |||||||
|         print 'Calculating AIC ...' |         print 'Calculating AIC ...' | ||||||
|         x = self.getDataArray() |         x = self.getDataArray() | ||||||
|         xnp = x[0].data |         xnp = x[0].data | ||||||
|  |         nn = np.isnan(xnp) | ||||||
|  |         if len(nn) > 1: | ||||||
|  |            xnp[nn] = 0 | ||||||
|         datlen = len(xnp) |         datlen = len(xnp) | ||||||
|         k = np.arange(1, datlen) |         k = np.arange(1, datlen) | ||||||
|         cf = np.zeros(datlen) |         cf = np.zeros(datlen) | ||||||
| @ -224,6 +249,9 @@ class HOScf(CharacteristicFunction): | |||||||
| 
 | 
 | ||||||
|         x = self.getDataArray(self.getCut()) |         x = self.getDataArray(self.getCut()) | ||||||
|         xnp =x[0].data |         xnp =x[0].data | ||||||
|  |         nn = np.isnan(xnp) | ||||||
|  |         if len(nn) > 1: | ||||||
|  |            xnp[nn] = 0 | ||||||
|         if self.getOrder() == 3:  # this is skewness |         if self.getOrder() == 3:  # this is skewness | ||||||
|             print 'Calculating skewness ...' |             print 'Calculating skewness ...' | ||||||
|             y = np.power(xnp, 3) |             y = np.power(xnp, 3) | ||||||
| @ -256,6 +284,9 @@ class HOScf(CharacteristicFunction): | |||||||
|             elif self.getOrder() == 4: |             elif self.getOrder() == 4: | ||||||
|                 LTA[j] = lta / np.power(lta1, 2) |                 LTA[j] = lta / np.power(lta1, 2) | ||||||
|          |          | ||||||
|  |         nn = np.isnan(LTA) | ||||||
|  |         if len(nn) > 1: | ||||||
|  |            LTA[nn] = 0 | ||||||
|         self.cf = LTA |         self.cf = LTA | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -266,6 +297,9 @@ class ARZcf(CharacteristicFunction): | |||||||
|         print 'Calculating AR-prediction error from single trace ...' |         print 'Calculating AR-prediction error from single trace ...' | ||||||
|         x = self.getDataArray(self.getCut()) |         x = self.getDataArray(self.getCut()) | ||||||
|         xnp = x[0].data |         xnp = x[0].data | ||||||
|  |         nn = np.isnan(xnp) | ||||||
|  |         if len(nn) > 1: | ||||||
|  |            xnp[nn] = 0 | ||||||
|         #some parameters needed |         #some parameters needed | ||||||
|         #add noise to time series |         #add noise to time series | ||||||
|         xnoise = xnp + np.random.normal(0.0, 1.0, len(xnp)) * self.getFnoise() * max(abs(xnp)) |         xnoise = xnp + np.random.normal(0.0, 1.0, len(xnp)) * self.getFnoise() * max(abs(xnp)) | ||||||
| @ -288,6 +322,9 @@ class ARZcf(CharacteristicFunction): | |||||||
|          |          | ||||||
|         #convert list to numpy array |         #convert list to numpy array | ||||||
|         cf = np.asarray(cf) |         cf = np.asarray(cf) | ||||||
|  |         nn = np.isnan(cf) | ||||||
|  |         if len(nn) > 1: | ||||||
|  |            cf[nn] = 0 | ||||||
|         self.cf = cf |         self.cf = cf | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -376,6 +413,12 @@ class ARHcf(CharacteristicFunction): | |||||||
|         print 'Calculating AR-prediction error from both horizontal traces ...' |         print 'Calculating AR-prediction error from both horizontal traces ...' | ||||||
|          |          | ||||||
|         xnp = self.getDataArray(self.getCut()) |         xnp = self.getDataArray(self.getCut()) | ||||||
|  |         n0 = np.isnan(xnp[0].data) | ||||||
|  |         if len(n0) > 1: | ||||||
|  |            xnp[0].data[n0] = 0 | ||||||
|  |         n1 = np.isnan(xnp[1].data) | ||||||
|  |         if len(n1) > 1: | ||||||
|  |            xnp[1].data[n1] = 0 | ||||||
|          |          | ||||||
|         #some parameters needed |         #some parameters needed | ||||||
|         #add noise to time series |         #add noise to time series | ||||||
| @ -390,7 +433,7 @@ class ARHcf(CharacteristicFunction): | |||||||
|                |                | ||||||
|         cf = [] |         cf = [] | ||||||
|         loopstep = self.getARdetStep() |         loopstep = self.getARdetStep() | ||||||
|         for i in range(ldet + self.getOrder() - 3, tend - lpred + 1, loopstep[1]): |         for i in range(ldet + self.getOrder() - 1, tend - lpred + 1, loopstep[1]): | ||||||
|             self.arDetH(Xnoise, self.getOrder(), i-ldet, i) |             self.arDetH(Xnoise, self.getOrder(), i-ldet, i) | ||||||
|             #AR prediction of waveform using calculated AR coefficients |             #AR prediction of waveform using calculated AR coefficients | ||||||
|             self.arPredH(xnp, self.arpara, i + 1, lpred) |             self.arPredH(xnp, self.arpara, i + 1, lpred) | ||||||
| @ -401,6 +444,9 @@ class ARHcf(CharacteristicFunction): | |||||||
| 
 | 
 | ||||||
|         #convert list to numpy array |         #convert list to numpy array | ||||||
|         cf = np.asarray(cf) |         cf = np.asarray(cf) | ||||||
|  |         nn = np.isnan(cf) | ||||||
|  |         if len(nn) > 1: | ||||||
|  |            cf[nn] = 0 | ||||||
|         self.cf = cf |         self.cf = cf | ||||||
| 
 | 
 | ||||||
|     def arDetH(self, data, order, rind, ldet): |     def arDetH(self, data, order, rind, ldet): | ||||||
| @ -493,6 +539,15 @@ class AR3Ccf(CharacteristicFunction): | |||||||
|         print 'Calculating AR-prediction error from all 3 components ...' |         print 'Calculating AR-prediction error from all 3 components ...' | ||||||
|          |          | ||||||
|         xnp = self.getDataArray(self.getCut()) |         xnp = self.getDataArray(self.getCut()) | ||||||
|  |         n0 = np.isnan(xnp[0].data) | ||||||
|  |         if len(n0) > 1: | ||||||
|  |            xnp[0].data[n0] = 0 | ||||||
|  |         n1 = np.isnan(xnp[1].data) | ||||||
|  |         if len(n1) > 1: | ||||||
|  |            xnp[1].data[n1] = 0 | ||||||
|  |         n2 = np.isnan(xnp[2].data) | ||||||
|  |         if len(n2) > 1: | ||||||
|  |            xnp[2].data[n2] = 0 | ||||||
|          |          | ||||||
|         #some parameters needed |         #some parameters needed | ||||||
|         #add noise to time series |         #add noise to time series | ||||||
| @ -508,7 +563,7 @@ class AR3Ccf(CharacteristicFunction): | |||||||
|                |                | ||||||
|         cf = [] |         cf = [] | ||||||
|         loopstep = self.getARdetStep() |         loopstep = self.getARdetStep() | ||||||
|         for i in range(ldet + self.getOrder() - 3, tend - lpred + 1, loopstep[1]): |         for i in range(ldet + self.getOrder() - 1, tend - lpred + 1, loopstep[1]): | ||||||
|             self.arDet3C(Xnoise, self.getOrder(), i-ldet, i) |             self.arDet3C(Xnoise, self.getOrder(), i-ldet, i) | ||||||
|             #AR prediction of waveform using calculated AR coefficients |             #AR prediction of waveform using calculated AR coefficients | ||||||
|             self.arPred3C(xnp, self.arpara, i + 1, lpred) |             self.arPred3C(xnp, self.arpara, i + 1, lpred) | ||||||
| @ -520,6 +575,9 @@ class AR3Ccf(CharacteristicFunction): | |||||||
| 
 | 
 | ||||||
|         #convert list to numpy array |         #convert list to numpy array | ||||||
|         cf = np.asarray(cf) |         cf = np.asarray(cf) | ||||||
|  |         nn = np.isnan(cf) | ||||||
|  |         if len(nn) > 1: | ||||||
|  |            cf[nn] = 0 | ||||||
|         self.cf = cf |         self.cf = cf | ||||||
| 
 | 
 | ||||||
|     def arDet3C(self, data, order, rind, ldet): |     def arDet3C(self, data, order, rind, ldet): | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user