[vectorization] add nvdim arg allowing unvec() on 2D fields
This commit is contained in:
		
							parent
							
								
									b3c2fd391b
								
							
						
					
					
						commit
						50f92e1cc8
					
				| @ -28,14 +28,16 @@ def vec(f: cfdfield_t) -> vcfdfield_t: | |||||||
| def vec(f: ArrayLike) -> vfdfield_t | vcfdfield_t: | def vec(f: ArrayLike) -> vfdfield_t | vcfdfield_t: | ||||||
|     pass |     pass | ||||||
| 
 | 
 | ||||||
| def vec(f: fdfield_t | cfdfield_t | ArrayLike | None) -> vfdfield_t | vcfdfield_t | None: | def vec( | ||||||
|  |         f: fdfield_t | cfdfield_t | ArrayLike | None, | ||||||
|  |         ) -> vfdfield_t | vcfdfield_t | None: | ||||||
|     """ |     """ | ||||||
|     Create a 1D ndarray from a 3D vector field which spans a 1-3D region. |     Create a 1D ndarray from a vector field which spans a 1-3D region. | ||||||
| 
 | 
 | ||||||
|     Returns `None` if called with `f=None`. |     Returns `None` if called with `f=None`. | ||||||
| 
 | 
 | ||||||
|     Args: |     Args: | ||||||
|         f: A vector field, `[f_x, f_y, f_z]` where each `f_` component is a 1- to |         f: A vector field, e.g. `[f_x, f_y, f_z]` where each `f_` component is a 1- to | ||||||
|            3-D ndarray (`f_*` should all be the same size). Doesn't fail with `f=None`. |            3-D ndarray (`f_*` should all be the same size). Doesn't fail with `f=None`. | ||||||
| 
 | 
 | ||||||
|     Returns: |     Returns: | ||||||
| @ -47,33 +49,38 @@ def vec(f: fdfield_t | cfdfield_t | ArrayLike | None) -> vfdfield_t | vcfdfield_ | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @overload | @overload | ||||||
| def unvec(v: None, shape: Sequence[int]) -> None: | def unvec(v: None, shape: Sequence[int], nvdim: int) -> None: | ||||||
|     pass |     pass | ||||||
| 
 | 
 | ||||||
| @overload | @overload | ||||||
| def unvec(v: vfdfield_t, shape: Sequence[int]) -> fdfield_t: | def unvec(v: vfdfield_t, shape: Sequence[int], nvdim: int) -> fdfield_t: | ||||||
|     pass |     pass | ||||||
| 
 | 
 | ||||||
| @overload | @overload | ||||||
| def unvec(v: vcfdfield_t, shape: Sequence[int]) -> cfdfield_t: | def unvec(v: vcfdfield_t, shape: Sequence[int], nvdim: int) -> cfdfield_t: | ||||||
|     pass |     pass | ||||||
| 
 | 
 | ||||||
| def unvec(v: vfdfield_t | vcfdfield_t | None, shape: Sequence[int]) -> fdfield_t | cfdfield_t | None: | def unvec( | ||||||
|  |         v: vfdfield_t | vcfdfield_t | None, | ||||||
|  |         shape: Sequence[int], | ||||||
|  |         nvdim: int = 3, | ||||||
|  |         ) -> fdfield_t | cfdfield_t | None: | ||||||
|     """ |     """ | ||||||
|     Perform the inverse of vec(): take a 1D ndarray and output a 3D field |     Perform the inverse of vec(): take a 1D ndarray and output an `nvdim`-component field | ||||||
|      of form `[f_x, f_y, f_z]` where each of `f_*` is a len(shape)-dimensional |      of form e.g. `[f_x, f_y, f_z]` (`nvdim=3`) where each of `f_*` is a len(shape)-dimensional | ||||||
|      ndarray. |      ndarray. | ||||||
| 
 | 
 | ||||||
|     Returns `None` if called with `v=None`. |     Returns `None` if called with `v=None`. | ||||||
| 
 | 
 | ||||||
|     Args: |     Args: | ||||||
|         v: 1D ndarray representing a 3D vector field of shape shape (or None) |         v: 1D ndarray representing a vector field of shape shape (or None) | ||||||
|         shape: shape of the vector field |         shape: shape of the vector field | ||||||
|  |         nvdim: Number of components in each vector | ||||||
| 
 | 
 | ||||||
|     Returns: |     Returns: | ||||||
|         `[f_x, f_y, f_z]` where each `f_` is a `len(shape)` dimensional ndarray (or `None`) |         `[f_x, f_y, f_z]` where each `f_` is a `len(shape)` dimensional ndarray (or `None`) | ||||||
|     """ |     """ | ||||||
|     if v is None: |     if v is None: | ||||||
|         return None |         return None | ||||||
|     return v.reshape((3, *shape), order='C') |     return v.reshape((nvdim, *shape), order='C') | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user