python - from ._nnls import nnls ImportError: DLL load failed: 找不到指定的模块
问题描述
在运行 UNet 转换代码时,我发现 DLL load failed 错误。这是代码:
'''
import torch
import scipy
import albumentations as A
from ._nnls import nnls
from albumentations.pytorch import ToTensorV2
from tqdm import tqdm
import torch.nn as nn
import torch.optim as optim
from unet_model import UNet
from utilscar import (
load_checkpoint,
save_checkpoint,
get_loaders,
check_accuracy,
save_predictions_as_imgs,
)
# Hyperparameters etc.
LEARNING_RATE = 1e-4
DEVICE = "cuda" if torch.cuda.is_available() else "cpu"
BATCH_SIZE = 16
NUM_EPOCHS = 3
NUM_WORKERS = 2
IMAGE_HEIGHT = 160 # 1280 originally
IMAGE_WIDTH = 240 # 1918 originally
PIN_MEMORY = True
LOAD_MODEL = False
TRAIN_IMG_DIR = "Dataset/train_images/"
TRAIN_MASK_DIR = "Dataset/train_masks/"
VAL_IMG_DIR = "Dataset/val_images/"
VAL_MASK_DIR = "Dataset/val_masks/"
def train_fn(loader, model, optimizer, loss_fn, scaler):
loop = tqdm(loader)
for batch_idx, (data, targets) in enumerate(loop):
data = data.to(device=DEVICE)
targets = targets.float().unsqueeze(1).to(device=DEVICE)
# forward
with torch.cuda.amp.autocast():
predictions = model(data)
loss = loss_fn(predictions, targets)
# backward
optimizer.zero_grad()
scaler.scale(loss).backward()
scaler.step(optimizer)
scaler.update()
# update tqdm loop
loop.set_postfix(loss=loss.item())
def main():
train_transform = A.Compose(
[
A.Resize(height=IMAGE_HEIGHT, width=IMAGE_WIDTH),
A.Rotate(limit=35, p=1.0),
A.HorizontalFlip(p=0.5),
A.VerticalFlip(p=0.1),
A.Normalize(
mean=[0.0, 0.0, 0.0],
std=[1.0, 1.0, 1.0],
max_pixel_value=255.0,
),
ToTensorV2(),
],
)
val_transform = A.Compose(
[
A.Resize(height=IMAGE_HEIGHT, width=IMAGE_WIDTH),
A.Normalize(
mean=[0.0, 0.0, 0.0],
std=[1.0, 1.0, 1.0],
max_pixel_value=255.0,
),
ToTensorV2(),
],
)
model = UNet(in_channels=3, out_channels=1).to(DEVICE)
loss_fn = nn.BCEWithLogitsLoss()
optimizer = optim.Adam(model.parameters(), lr=LEARNING_RATE)
train_loader, val_loader = get_loaders(
TRAIN_IMG_DIR,
TRAIN_MASK_DIR,
VAL_IMG_DIR,
VAL_MASK_DIR,
BATCH_SIZE,
train_transform,
val_transform,
NUM_WORKERS,
PIN_MEMORY,
)
if LOAD_MODEL:
load_checkpoint(torch.load("my_checkpoint.pth.tar"), model)
check_accuracy(val_loader, model, device=DEVICE)
scaler = torch.cuda.amp.GradScaler()
for epoch in range(NUM_EPOCHS):
train_fn(train_loader, model, optimizer, loss_fn, scaler)
# save model
checkpoint = {
"state_dict": model.state_dict(),
"optimizer":optimizer.state_dict(),
}
save_checkpoint(checkpoint)
# check accuracy
check_accuracy(val_loader, model, device=DEVICE)
# print some examples to a folder
save_predictions_as_imgs(
val_loader, model, folder="saved_images/", device=DEVICE
)
if __name__ == "__main__":
main()
'''
我发现了这个错误: from ._nnls import nnls
ImportError:DLL 加载失败:找不到指定的模块。
在这里我想提一下,我的 python 是 64 位的,所有的库也是 64 位的。我使用 conda update 更新了所有内容。
解决方案
以下解决方案对我有用。
conda remove --force numpy, scipy
pip install -U numpy, scipy
成功安装numpy-1.19.5 scipy-1.5.4
参考:https ://github.com/conda/conda/issues/6396#issuecomment-350254762
推荐阅读
- bash - 将 bash 脚本输出重定向到不包括菜单的日志文件
- django - 如何在 django 中将静态添加到我的脚本中
- java - 为什么Java中的for循环是否存在不会有任何区别
- mysql - 如何在 Rails 应用程序中更改数据库
- javascript - 什么将在 NodeJS 中返回带有等待的 for 循环?
- python - 对数据集执行 k-means 聚类后分析聚类的技术
- docker - NuxtJS 开发服务器上客户端的连接错误问题
- android - 在 android 中使用 Room 时出错:错误 2067 (SQLITE_CONSTRAINT_UNIQUE)
- reactjs - React 如何更改具有关键属性的组件?
- php - 当我尝试使用 symfony 创建实体时出现 Aborted 错误消息