目录
pytorch拼接通道
import torch
x1 = torch.randn(2,2, 3)
x2 = torch.randn(2, 3)
data=torch.cat((x1,x2.unsqueeze(0)),0)
print(data.size())
图片添加通道:
import cv2
import numpy as np
rgb=cv2.imread(r"D:\nv.jpg")
rgba = np.dstack((rgb, np.zeros(rgb.shape[:-1])))
cv2.imshow("asdf",rgb)
cv2.waitKey()
tile行列同时扩展:
import numpy as np
x = np.array([[1,2],[3,4]])
data = np.tile(x, (2,2))
print(data)
repeat函数:按照维度进行复制拼接
a = np.arange(3)
a
array([0, 1, 2])
np.repeat(a, 2)
array([0, 0, 1, 1, 2, 2])>>> a = [[0,1], [2,3], [4,5]]>>> y = np.repeat(a, 2)>>> yarray([0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5])>>> x = np.tile(a, (2,1))>>> xarray([[0, 1], [2, 3], [4, 5], [0, 1], [2, 3], [4, 5]])>>> a = np.array([[1,2],[3,4]])>>> aarray([[1, 2], [3, 4]])>>> np.repeat(a, 2, 1)array([[1, 1, 2, 2], [3, 3, 4, 4]])>>> np.repeat(a, 2, 0)array([[1, 2], [1, 2], [3, 4], [3, 4]])
opencv通道拆分与合并:split和merge
原文:http://blog.youkuaiyun.com/omuyejingfeng1/article/details/25685141
#include<opencv2/opencv.hpp>
#include<iostream>
#include<cassert>
#include<vector>
using namespace cv;
using namespace std;
int main()
{
Mat srcImage=imread("e:/huangshan.jpg");
Mat imageBlue,imageGreen,imageRed;
Mat mergeImage;
//定义一个Mat向量容器保存拆分后的数据
vector<Mat> channels;
//判断文件加载是否正确
assert(srcImage.data!=NULL);
namedWindow("image",CV_WINDOW_AUTOSIZE);
namedWindow("mergeImage",CV_WINDOW_AUTOSIZE);
//通道的拆分
split(srcImage,channels);
//提取蓝色通道的数据
imageBlue = channels.at(0);
//提取绿色通道的数据
imageGreen = channels.at(1);
//提取红色通道的数据
imageRed = channels.at(2);
imshow("image",imageBlue);
//对拆分的通道数据合并
merge(channels,mergeImage);
imshow("mergeImage",mergeImage);
waitKey();
system("pause");
return 0;
}
#include<opencv2/opencv.hpp>
#include<iostream>
#include<cassert>
#include<vector>
using namespace cv;
using namespace std;
int main()
{
Mat srcImage=imread("e:/jiansheng.jpg");
Mat logoImage = imread("e:/timu.jpg",0);
Mat imageBlue,imageGreen,imageRed;
Mat mergeImage;
//定义一个Mat向量容器保存拆分后的数据
vector<Mat> channels;
//判断文件加载是否正确
assert(srcImage.data!=NULL && logoImage.data!=NULL);
//namedWindow("image",CV_WINDOW_AUTOSIZE);
namedWindow("mergeImage",CV_WINDOW_AUTOSIZE);
//通道的拆分
split(srcImage,channels);
//提取蓝色通道的数据
imageBlue = channels.at(1);
addWeighted(imageBlue(Rect(0,0,logoImage.cols,logoImage.rows)),0.5,logoImage,0.5,0.,imageBlue(Rect(0,0,logoImage.cols,logoImage.rows)));
//对拆分的通道数据合并
merge(channels,mergeImage);
imshow("mergeImage",mergeImage);
waitKey();
system("pause");
return 0;
}
#include<opencv2/opencv.hpp>
#include<iostream>
#include<vector>
using namespace std;
using namespace cv;
int main()
{
Mat img = imread("f:/huang.jpg");
namedWindow("image",WINDOW_AUTOSIZE);
imshow("image",img);
Mat gray;
cvtColor(img,gray,CV_RGB2GRAY);
namedWindow("gray",WINDOW_AUTOSIZE);
imshow("gray",gray);
Mat mimg = imread("f:/mei.jpeg");
namedWindow("mei",WINDOW_AUTOSIZE);
resize(mimg,mimg,Size(img.cols,img.rows));
addWeighted(mimg,0.2,img,0.9,0.,mimg);
imshow("mei",mimg);
vector<Mat> channels;
split(img,channels);
vector<Mat>::iterator it = channels.begin();
char str[][20]={"blue","green","red"};
int i=0;
for(;it!=channels.end();++it,++i)
{
namedWindow(str[i],WINDOW_AUTOSIZE);
imshow(str[i],*it);
}
waitKey();
return 0;
}