當前位置: 首頁>>代碼示例>>Python>>正文


Python pynvml.NVMLError方法代碼示例

本文整理匯總了Python中pynvml.NVMLError方法的典型用法代碼示例。如果您正苦於以下問題:Python pynvml.NVMLError方法的具體用法?Python pynvml.NVMLError怎麽用?Python pynvml.NVMLError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pynvml的用法示例。


在下文中一共展示了pynvml.NVMLError方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _get_driver

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def _get_driver(self):
        """ Obtain and return the installed driver version for the system's GPUs.

        Returns
        -------
        str
            The currently installed GPU driver version
        """
        if self._is_plaidml:
            driver = self._plaid.drivers
        elif IS_MACOS:
            driver = pynvx.cudaSystemGetDriverVersion(ignore=True)
        else:
            try:
                driver = pynvml.nvmlSystemGetDriverVersion().decode("utf-8")
            except pynvml.NVMLError:
                driver = "No Nvidia driver found"
        self._log("debug", "GPU Driver: {}".format(driver))
        return driver 
開發者ID:deepfakes,項目名稱:faceswap,代碼行數:21,代碼來源:gpu_stats.py

示例2: _init_nvml

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def _init_nvml(self):
        if self._load_nvidia_lib() == -1:
            return -1

        try:
            global pynvml
            import pip
            pip.main(['install', '--quiet', 'nvidia-ml-py'])
            import pynvml as pynvml
            pynvml.nvmlInit()
            return 0
        except pynvml.NVMLError, err:
            logger.debug('Failed to initialize NVML: ', err)
            return -1 
開發者ID:cloudviz,項目名稱:agentless-system-crawler,代碼行數:16,代碼來源:gpu_host_crawler.py

示例3: _shutdown_nvml

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def _shutdown_nvml(self):
        try:
            pynvml.nvmlShutdown()
        except pynvml.NVMLError, err:
            logger.debug('Failed to shutdown NVML: ', err) 
開發者ID:cloudviz,項目名稱:agentless-system-crawler,代碼行數:7,代碼來源:gpu_host_crawler.py

示例4: _get_container_id

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def _get_container_id(self, gpuhandle):
        cont_ids = []
        pids = []
        try:
            proc_objs = pynvml.nvmlDeviceGetComputeRunningProcesses(gpuhandle)
            if not proc_objs:
                return ['NA.NA']
            for proc_obj in proc_objs:
                pids.append(proc_obj.pid)
            for pid in pids:
                cont_ids.append(self._get_containerid_from_pid(pid))
            return cont_ids
        except pynvml.NVMLError, err:
            logger.debug('Failed to get pid on gpu: ', err) 
開發者ID:cloudviz,項目名稱:agentless-system-crawler,代碼行數:16,代碼來源:gpu_host_crawler.py

示例5: __exit__

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def __exit__(self, exception_type, exception_value, traceback):
        # Do nothing if the exception is not from pynvml or there is no exception
        if traceback is None:
            return False
        if not issubclass(exception_type, pynvml.NVMLError):
            return False

        # Suppress pynvml exceptions so we can continue
        if self.name in NvmlCall.previously_printed_errors:
            return True
        NvmlCall.previously_printed_errors.add(self.name)
        self.log.warning("Unable to execute NVML function: %s: %s", self.name, exception_value)
        return True 
開發者ID:DataDog,項目名稱:integrations-extras,代碼行數:15,代碼來源:nvml.py

示例6: mem_used_for

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def mem_used_for(device_handle):
    """Get GPU device memory consumption in percent"""
    try:
        return pynvml.nvmlDeviceGetMemoryInfo(device_handle).used
    except pynvml.NVMLError:
        return None 
開發者ID:msalvaris,項目名稱:gpu_monitor,代碼行數:8,代碼來源:gpu_interface.py

示例7: mem_used_percent_for

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def mem_used_percent_for(device_handle):
    """Get GPU device memory consumption in percent"""
    try:
        memory_info = pynvml.nvmlDeviceGetMemoryInfo(device_handle)
        return memory_info.used * 100.0 / memory_info.total
    except pynvml.NVMLError:
        return None 
開發者ID:msalvaris,項目名稱:gpu_monitor,代碼行數:9,代碼來源:gpu_interface.py

示例8: utilization_for

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def utilization_for(device_handle):
    """Get GPU device consumption in percent
        Percent of time over the past sample period during which one or more kernels was executing on the GPU.
    """
    try:
        return pynvml.nvmlDeviceGetUtilizationRates(device_handle).gpu
    except pynvml.NVMLError:
        return None 
開發者ID:msalvaris,項目名稱:gpu_monitor,代碼行數:10,代碼來源:gpu_interface.py

示例9: mem_utilization_for

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def mem_utilization_for(device_handle):
    """
        Percent of time over the past sample period during which global (device) memory was being read or written.
    """
    try:
        return pynvml.nvmlDeviceGetUtilizationRates(device_handle).memory
    except pynvml.NVMLError:
        return None 
開發者ID:msalvaris,項目名稱:gpu_monitor,代碼行數:10,代碼來源:gpu_interface.py

示例10: power_for

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def power_for(device_handle):
    try:
        return pynvml.nvmlDeviceGetPowerUsage(device_handle)
    except pynvml.NVMLError:
        return None 
開發者ID:msalvaris,項目名稱:gpu_monitor,代碼行數:7,代碼來源:gpu_interface.py

示例11: _get_device_count

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def _get_device_count(self):
        """ Detect the number of GPUs attached to the system and allocate to
        :attr:`_device_count`. """
        if self._is_plaidml:
            self._device_count = self._plaid.device_count
        elif IS_MACOS:
            self._device_count = pynvx.cudaDeviceGetCount(ignore=True)
        else:
            try:
                self._device_count = pynvml.nvmlDeviceGetCount()
            except pynvml.NVMLError:
                self._device_count = 0
        self._log("debug", "GPU Device count: {}".format(self._device_count)) 
開發者ID:deepfakes,項目名稱:faceswap,代碼行數:15,代碼來源:gpu_stats.py

示例12: can_log_gpu_resources

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def can_log_gpu_resources():
    if pynvml is None:
        return False

    try:
        pynvml.nvmlInit()
        return True
    except pynvml.NVMLError:
        return False 
開發者ID:polyaxon,項目名稱:polyaxon,代碼行數:11,代碼來源:gpu_processor.py

示例13: get_gpu_metrics

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def get_gpu_metrics() -> List:
    try:
        pynvml.nvmlInit()
        device_count = pynvml.nvmlDeviceGetCount()
        results = []

        for i in range(device_count):
            handle = pynvml.nvmlDeviceGetHandleByIndex(i)
            results += metrics_dict_to_list(query_gpu(handle))
        return results
    except pynvml.NVMLError:
        logger.debug("Failed to collect gpu resources", exc_info=True)
        return [] 
開發者ID:polyaxon,項目名稱:polyaxon,代碼行數:15,代碼來源:gpu_processor.py

示例14: _monitor

# 需要導入模塊: import pynvml [as 別名]
# 或者: from pynvml import NVMLError [as 別名]
def _monitor(self):
        pynvml.nvmlInit()
        self._find_gpu()
        current_sample = []
        while not self.should_stop:
            used_cpu = None
            used_cpumem = None
            used_gpu = None
            used_gpumem = None
            
            cpu_process = psutil.Process(self.pid)
            used_cpu = cpu_process.cpu_percent() / psutil.cpu_count() # CPU utilization in %
            used_cpumem = cpu_process.memory_info().rss // (1024*1024) # Memory use in MB

            gpu_processes = pynvml.nvmlDeviceGetComputeRunningProcesses(self.gpu)
            for gpu_process in gpu_processes:
                if gpu_process.pid == self.pid:
                    used_gpumem = gpu_process.usedGpuMemory // (1024*1024) # GPU memory use in MB
                    break

            if self.accounting_enabled:
                try:
                    stats = pynvml.nvmlDeviceGetAccountingStats(self.gpu, self.pid)
                    used_gpu = stats.gpuUtilization
                except pynvml.NVMLError: # NVMLError_NotFound
                    pass

            if not used_gpu:
                util = pynvml.nvmlDeviceGetUtilizationRates(self.gpu)
                used_gpu = util.gpu / len(gpu_processes) # Approximate based on number of processes

            current_sample.append((used_cpu, used_cpumem, used_gpu, used_gpumem))

            time.sleep(self.sampling_rate)

        self.stats.append([round(sum(x) / len(x)) for x in zip(*current_sample)])
        pynvml.nvmlShutdown() 
開發者ID:vlimant,項目名稱:mpi_learn,代碼行數:39,代碼來源:monitor.py


注:本文中的pynvml.NVMLError方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。