You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							21 lines
						
					
					
						
							506 B
						
					
					
				
			
		
		
	
	
							21 lines
						
					
					
						
							506 B
						
					
					
				| def int_rnd(x):
 | |
|   return int(round(x))
 | |
| 
 | |
| def clip(x, lo, hi):
 | |
|   return max(lo, min(hi, x))
 | |
| 
 | |
| def interp(x, xp, fp):
 | |
|   N = len(xp)
 | |
|   def get_interp(xv):
 | |
|     hi = 0
 | |
|     while hi < N and xv > xp[hi]:
 | |
|       hi += 1
 | |
|     low = hi - 1
 | |
|     return fp[-1] if hi == N and xv > xp[low] else (
 | |
|       fp[0] if hi == 0 else
 | |
|       (xv - xp[low]) * (fp[hi] - fp[low]) / (xp[hi] - xp[low]) + fp[low])
 | |
|   return [get_interp(v) for v in x] if hasattr(
 | |
|     x, '__iter__') else get_interp(x)
 | |
| 
 | |
| def mean(x):
 | |
|   return sum(x) / len(x)
 | |
| 
 |