assert all(map(lambda i: i.is_cuda, inputs)) AssertionError

报错如下:

assert all(map(lambda i: i.is_cuda, inputs))
AssertionError

报错原因:
pytorch框架代码在服务器上运行时,服务器上有好几GPU,程序暂时不知道怎么用多个gpu(或者说不知道用哪个GPU)

解决方法:
方法1:

import os
os.environ[“CUDA_VISIBLE_DEVICES”] = "0" # 指定一个GPU编号,这里例子写的0,也可以是1,2,...

方法2:

net = torch.nn.DataParallel(model,device_ids=[0])
# 通过device_ids进行指定

以上两种方法使用之后就不再报错了,但是只能使用一个GPU,多个GPU使用,并且不报错,还在研究中。。。。

参考:
https://blog.youkuaiyun.com/qq_32780465/article/details/106300394

https://blog.youkuaiyun.com/baoyongshuai1509/article/details/85254298

https://blog.youkuaiyun.com/kongkongqixi/article/details/100521590

这段代码实现了一个简单的内存分配器和进程类。其中,内存分配器使用一个数组来表示内存块的使用情况,每个进程对象都包含一个指向内存块的引用。 这段代码的实现还可以进行一些改进: 1. 内存分配器可以使用更高效的数据结构,比如位图,来表示内存块的使用情况。 2. 进程类可以添加一个方法来释放内存,而不是在内存分配器中实现。 3. 内存分配器可以添加一个方法来查找可用的内存块,而不是在进程类中实现。 4. 进程类可以将内存块的起始位置和长度作为属性,而不是在set_memory方法中设置。 下面是改进后的代码: ``` class Process: def __init__(self, pid, duration): self.__pid = pid self.__duration = duration self.__memory_start = None self.__memory_length = None @property def pid(self): return self.__pid @property def duration(self): return self.__duration @property def memory_start(self): return self.__memory_start @property def memory_length(self): return self.__memory_length def set_memory(self, start, length): self.__memory_start = start self.__memory_length = length def release_memory(self): self.__memory_start = None self.__memory_length = None class MemoryAllocator: def __init__(self, memory_size): self.__memory_blocks = [False] * memory_size def find_free_memory(self, length): for i in range(len(self.__memory_blocks) - length + 1): if all(not self.__memory_blocks[j] for j in range(i, i + length)): return i return None def allocate_memory(self, process): length = process.duration start = self.find_free_memory(length) assert start is not None, 'allocation failed' for i in range(start, start + length): self.__memory_blocks[i] = True process.set_memory(start, length) def free_memory(self, process): start = process.memory_start length = process.memory_length for i in range(start, start + length): self.__memory_blocks[i] = False process.release_memory() ``` 改进后的代码更加清晰和易于维护,也更加高效。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

机器不学习我学习

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值