網站首頁 編程語言 正文
圖像有時候比數據更能滿足人們的視覺需求
Pytorch中保存圖片的方式
pytorch下保存圖像有很多種方法,但是這些基本上都是基于圖像處理的,將圖像的像素指定一定的維度 ,方法如下:
1、tensor直接保存
#!/usr/bin/env python # _*_ coding:utf-8 _*_ import torch from torchvision import utils as vutils def save_image_tensor(input_tensor: torch.Tensor, filename): """ 將tensor保存為圖片 :param input_tensor: 要保存的tensor :param filename: 保存的文件名 """ assert (len(input_tensor.shape) == 4 and input_tensor.shape[0] == 1) # 復制一份 input_tensor = input_tensor.clone().detach() # 到cpu input_tensor = input_tensor.to(torch.device('cpu')) # 反歸一化 # input_tensor = unnormalize(input_tensor) vutils.save_image(input_tensor, filename)
2、tensor轉cv2保存
#!/usr/bin/env python # _*_ coding:utf-8 _*_ import torch import cv2 def save_image_tensor2cv2(input_tensor: torch.Tensor, filename): """ 將tensor保存為cv2格式 :param input_tensor: 要保存的tensor :param filename: 保存的文件名 """ assert (len(input_tensor.shape) == 4 and input_tensor.shape[0] == 1) # 復制一份 input_tensor = input_tensor.clone().detach() # 到cpu input_tensor = input_tensor.to(torch.device('cpu')) # 反歸一化 # input_tensor = unnormalize(input_tensor) # 去掉批次維度 input_tensor = input_tensor.squeeze() # 從[0,1]轉化為[0,255],再從CHW轉為HWC,最后轉為cv2 input_tensor = input_tensor.mul_(255).add_(0.5).clamp_(0, 255).permute(1, 2, 0).type(torch.uint8).numpy() # RGB轉BRG input_tensor = cv2.cvtColor(input_tensor, cv2.COLOR_RGB2BGR) cv2.imwrite(filename, input_tensor)
3、tensor轉pillow保存
def save_image_tensor2pillow(input_tensor: torch.Tensor, filename): """ 將tensor保存為pillow :param input_tensor: 要保存的tensor :param filename: 保存的文件名 """ assert (len(input_tensor.shape) == 4 and input_tensor.shape[0] == 1) # 復制一份 input_tensor = input_tensor.clone().detach() # 到cpu input_tensor = input_tensor.to(torch.device('cpu')) # 反歸一化 # input_tensor = unnormalize(input_tensor) # 去掉批次維度 input_tensor = input_tensor.squeeze() # 從[0,1]轉化為[0,255],再從CHW轉為HWC,最后轉為numpy input_tensor = input_tensor.mul_(255).add_(0.5).clamp_(0, 255).permute(1, 2, 0).type(torch.uint8).numpy() # 轉成pillow im = Image.fromarray(input_tensor) im.save(filename)
?主要是寫一些函數來保存圖片;
另外,pytorch中有很多可以直接保存圖片的語句
如
save_image(fake_images, './img/fake_images-{}.png'.format(epoch + 1))
此語句同樣需要轉化像素。
那么如果
我只需要打開一個視窗,觀察訓練過程中圖像的變化,我對圖像像素保存沒有什么需求,只是保存一個視窗,那么我需要的保存圖像的函數僅僅是一個
plt.savefig
plt.savefig的用法以及保存的路徑,及訓練過程中不會被覆蓋掉,可以上代碼供大家參考
if epoch % 10== 0: plt.title('ber:{:.3f},a: {:.3f},b:{:.3f},snr: {:.3f}'.format( error_rate, a, b,M )) plt.plot(r3) # 繪制波形 # save_image(r3, './img/fake_images-{}.png'.format(epoch + 1)) # print(type(r3)) # plt.draw() plt.draw() plt.savefig('./img/pic-{}.png'.format(epoch + 1)) plt.pause(1) plt.close(fig1)
大功告成,可以看看保存后的圖片
?已經都整整齊齊的在我的保存路徑下了。
總結
原文鏈接:https://blog.csdn.net/xzm961226xzm/article/details/120951317
相關推薦
- 2022-06-07 Pytorch上下采樣函數之F.interpolate數組采樣操作詳解_python
- 2022-08-30 C++示例講解初始化列表方法_C 語言
- 2022-06-12 PostgreSQL數據庫視圖及子查詢使用操作_PostgreSQL
- 2022-10-03 React?正確使用useCallback?useMemo的方式_React
- 2022-04-09 SpringBoot設置CorsFilter過濾器解決跨域問題
- 2022-04-22 Element UI 使用表單校驗,正確輸入后,仍然有提示信息
- 2022-07-08 自定義資源CRD使用介紹_云其它
- 2022-04-04 git: git commit時出現 -modified content, untracked co
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支