py-smi

py-smi py-smi

py-smilink image 0

¿Quieres poder usar nvidia-smi desde Python? Aquí tienes una librería para hacerlo.

Instalaciónlink image 1

Para poder instalarla ejecuta:

pip install python-smi
      

Usolink image 2

Importamos la librería

	
from py_smi import NVML
Copy

Creamos un objeto de pynvml (la librería detrás de nvidia-smi)

	
nv = NVML()
Copy

Obtenemos la versión del driver y de CUDA

	
nv.driver_version, nv.cuda_version
Copy
	
('560.35.03', '12.6')

Como en mi caso tengo dos GPUs creo una variable con el número de GPUs

	
num_gpus = 2
Copy

Obtengo la memoria de cada GPU

	
[nv.mem(i) for i in range(num_gpus)]
Copy
	
[_Memory(free=24136.6875, total=24576.0, used=439.3125),
_Memory(free=23509.0, total=24576.0, used=1067.0)]

La utilización

	
[nv.utilization() for i in range(num_gpus)]
Copy
	
[_Utilization(gpu=0, memory=0, enc=0, dec=0),
_Utilization(gpu=0, memory=0, enc=0, dec=0)]

La potencia usada

Esto me viene muy bien, porque cuando entrenaba un modelo y tenía las dos GPUs llenas a veces se me apagaba el ordenador, y viendo la potencia, veo que la segunda consume mucho, por lo que puede que sea lo que yo ya sospechaba, que era por alimentación.

	
[nv.power(i) for i in range(num_gpus)]
Copy
	
[_Power(usage=15.382, limit=350.0), _Power(usage=40.573, limit=350.0)]

Los relojes de cada GPU

	
[nv.clocks(i) for i in range(num_gpus)]
Copy
	
[_Clocks(graphics=0, sm=0, mem=405), _Clocks(graphics=540, sm=540, mem=810)]

Datos del PCI

	
[nv.pcie_throughput(i) for i in range(num_gpus)]
Copy
	
[_PCIeThroughput(rx=0.0, tx=0.0),
_PCIeThroughput(rx=0.1630859375, tx=0.0234375)]

Y los procesos (ahora no estoy corriendo nada)

	
[nv.processes(i) for i in range(num_gpus)]
Copy
	
[[], []]

Seguir leyendo

DoLa – Decoding by Contrasting Layers Improves Factuality in Large Language Models

DoLa – Decoding by Contrasting Layers Improves Factuality in Large Language Models

¿Alguna vez has hablado con un LLM y te ha respondido algo que suena como si hubiera estado bebiendo café de máquina durante toda la noche? 😂 ¡Eso es lo que llamamos una alucinación en el mundo de los LLMs! Pero no te preocupes, porque no es que tu modelo de lenguaje esté loco (aunque a veces puede parecerlo 🤪). La verdad es que los LLMs pueden ser un poco... creativos cuando se trata de generar texto. Pero gracias a DoLa, un método que utiliza capas de contraste para mejorar la factibilidad de los LLMs, podemos evitar que nuestros modelos de lenguaje se conviertan en escritores de ciencia ficción 😂. En este post, te explicaré cómo funciona DoLa y te mostraré un ejemplo de código para que puedas entender mejor cómo hacer que tus LLMs sean más fiables y menos propensos a inventar historias. ¡Vamos a salvar a nuestros LLMs de la locura y hacer que sean más útiles! 🚀

Últimos posts -->

¿Has visto estos proyectos?

Subtify

Subtify Subtify

Generador de subtítulos para videos en el idioma que desees. Además a cada persona le pone su subtítulo de un color

Ver todos los proyectos -->

¿Quieres aplicar la IA en tu proyecto? Contactame!

¿Quieres mejorar con estos tips?

Últimos tips -->

Usa esto en local

Los espacios de Hugging Face nos permite ejecutar modelos con demos muy sencillas, pero ¿qué pasa si la demo se rompe? O si el usuario la elimina? Por ello he creado contenedores docker con algunos espacios interesantes, para poder usarlos de manera local, pase lo que pase. De hecho, es posible que si pinchas en alún botón de ver proyecto te lleve a un espacio que no funciona.

Ver todos los contenedores -->

¿Quieres aplicar la IA en tu proyecto? Contactame!

¿Quieres entrenar tu modelo con estos datasets?

short-jokes-dataset

Dataset de chistes en inglés

opus100

Dataset con traducciones de inglés a español

netflix_titles

Dataset con películas y series de Netflix

Ver más datasets -->