
    h
              
          d dl Z d dlmZmZmZ d dlZd dlmZ	 d dl
mZmZ 	 ddeee	j                  f   deeeef      defdZ	 ddeee	j                  f   deee j                   f   deeeef      ddfd	Zd
edeee	j                  f   fdZdeee j                   f   deee	j                  f   fdZdeeej(                  f   deee	j                  f   fdZdeee	j                  f   deeej                  f   fdZy)    N)DictOptionalUnion)numpy	safe_opentensorsmetadatareturnc                 F    t        |       }t        j                  ||      S )a!  
    Saves a dictionary of tensors into raw bytes in safetensors format.

    Args:
        tensors (`Dict[str, mx.array]`):
            The incoming tensors. Tensors need to be contiguous and dense.
        metadata (`Dict[str, str]`, *optional*, defaults to `None`):
            Optional text only metadata you might want to save in your header.
            For instance it can be useful to specify more about the underlying
            tensors. This is purely informative and does not affect tensor loading.

    Returns:
        `bytes`: The raw bytes representing the format

    Example:

    ```python
    from safetensors.mlx import save
    import mlx.core as mx

    tensors = {"embedding": mx.zeros((512, 1024)), "attention": mx.zeros((256, 256))}
    byte_data = save(tensors)
    ```
    r	   )_mx2npr   save)r   r	   
np_tensorss      M/var/www/html/eduruby.in/venv/lib/python3.12/site-packages/safetensors/mlx.pyr   r   
   s    6 J::j844    filenamec                 H    t        |       }t        j                  |||      S )ae  
    Saves a dictionary of tensors into raw bytes in safetensors format.

    Args:
        tensors (`Dict[str, mx.array]`):
            The incoming tensors. Tensors need to be contiguous and dense.
        filename (`str`, or `os.PathLike`)):
            The filename we're saving into.
        metadata (`Dict[str, str]`, *optional*, defaults to `None`):
            Optional text only metadata you might want to save in your header.
            For instance it can be useful to specify more about the underlying
            tensors. This is purely informative and does not affect tensor loading.

    Returns:
        `None`

    Example:

    ```python
    from safetensors.mlx import save_file
    import mlx.core as mx

    tensors = {"embedding": mx.zeros((512, 1024)), "attention": mx.zeros((256, 256))}
    save_file(tensors, "model.safetensors")
    ```
    r   )r   r   	save_file)r   r   r	   r   s       r   r   r   )   s     > J??:x(CCr   datac                 B    t        j                  |       }t        |      S )a  
    Loads a safetensors file into MLX format from pure bytes.

    Args:
        data (`bytes`):
            The content of a safetensors file

    Returns:
        `Dict[str, mx.array]`: dictionary that contains name as key, value as `mx.array`

    Example:

    ```python
    from safetensors.mlx import load

    file_path = "./my_folder/bert.safetensors"
    with open(file_path, "rb") as f:
        data = f.read()

    loaded = load(data)
    ```
    )r   load_np2mx)r   flats     r   r   r   L   s    . ::dD$<r   c                     i }t        | d      5 }|j                         D ]  }|j                  |      ||<    	 ddd       |S # 1 sw Y   |S xY w)a  
    Loads a safetensors file into MLX format.

    Args:
        filename (`str`, or `os.PathLike`)):
            The name of the file which contains the tensors

    Returns:
        `Dict[str, mx.array]`: dictionary that contains name as key, value as `mx.array`

    Example:

    ```python
    from safetensors.flax import load_file

    file_path = "./my_folder/bert.safetensors"
    loaded = load_file(file_path)
    ```
    mlx)	frameworkN)r   offset_keys
get_tensor)r   resultfks       r   	load_filer"   g   sY    ( F	8u	- ( 	(AQF1I	(( M( Ms   *AA
numpy_dictc                 f    | j                         D ]  \  }}t        j                  |      | |<    | S N)itemsmxarray)r#   r!   vs      r   r   r      s5      " $1
1$r   mx_dictc                 j    i }| j                         D ]  \  }}t        j                  |      ||<    |S r%   )r&   npasarray)r*   new_dictr!   r)   s       r   r   r      s6    H $1jjm$Or   r%   )ostypingr   r   r   r   r,   mlx.corecorer'   safetensorsr   strr(   bytesr   PathLiker   r   r"   ndarrayr   r    r   r   <module>r9      sZ   	 ( (   ( HL5#rxx- 5,4T#s(^,D5
5D *. D#rxx-  DC$% D tCH~& D 
	 DFu c288m, 6c2;;./ Dbhh4G 6tCO, c288m1D Dbhh' Dbhh,? r   