- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这就是我为方程式生成数据点的方式:
struct Sine_point {
double x;
double y;
};
Sine_point graph[2000];
for(int i = 0; i < 2000; i++) {
float x = (i - 1000.0) / 100.0;
graph[i].x = x;
graph[i].y = sin(x * 10.0) / (1.0 + x * x);
cout<<graph[i].x<<graph[i].y<<endl;
}
现在我想根据这些点绘制图表。到目前为止我尝试过的是一个绘制直线的程序:
#include <vector>
#include "opencv2/highgui/highgui.hpp"
#include <opencv\cv.h>
#include <iostream>
#include<conio.h>
using namespace cv;
using namespace std;
int main()
{
std::vector<char> dataPtr(40000, 200);
cv::Point p1(0,0);
cv::Point p2(200, 200);
cv::Size size(200,200);
cv::Mat image(size, CV_8U, &(dataPtr[0]));
if (image.empty()) //check whether the image is valid or not
{
cout << "Error : Image cannot be created..!!" << endl;
system("pause"); //wait for a key press
return -1;
}
cv::line(image, p1, p2, 'r', 5, 8, 0);
namedWindow("MyWindow", CV_WINDOW_AUTOSIZE); //create a window with the name "MyWindow"
imshow("MyWindow", image); //display the image which is stored in the 'img' in the "MyWindow" window
waitKey(0); //wait infinite time for a keypress
destroyWindow("MyWindow"); //destroy the window with the name, "MyWindow"
return 0;
}
这使用 cv:line,它连接我提供的端点。但是我该如何处理我的函数数据呢?
更新
这是我现在的做法:
int main()
{
std::vector<char> dataPtr(40000, 200);
cv::Size s(200,200);
cv::Mat image(s, CV_8U, &(dataPtr[0]));
if (image.empty()) //check whether the image is valid or not
{
cout << "Error : Image cannot be created..!!" << endl;
system("pause"); //wait for a key press
return -1;
}
struct Sine_point {
double x;
double y;
};
Sine_point graph[2000];
for(int i = 0; i < 2000; i++) {
float x = (i - 1000.0) / 100.0;
graph[i].x = x;
graph[i].y = sin(x * 10.0) / (1.0 + x * x);
cv::Point p1(graph[i].x,graph[i].y);
cv::Point p2(graph[i+1].x, graph[i+1].y);
cv::line(image, p1, p2, Scalar(0,0,255), 5, 8, 0);
}
namedWindow("MyWindow", CV_WINDOW_AUTOSIZE); //create a window with the name "MyWindow"
imshow("MyWindow", image); //display the image which is stored in the 'img' in the "MyWindow" window
waitKey(0); //wait infinite time for a keypress
destroyWindow("MyWindow"); //destroy the window with the name, "MyWindow"
return 0;
}
但现在我得到的是空白图像。
最佳答案
这是我的解决方案。对您的代码进行了一些更改并添加了缩放比例:
struct Sine_point {
double x;
double y;
};
int main()
{
unsigned int nSamples = 2000;
// use float precision?!?
Sine_point min;
Sine_point max;
Sine_point graph[nSamples];
for(unsigned int i = 0; i < nSamples; i++)
{
//using double precision:
// sample to confirm y-axis mirroring: simple line
//double x = (i - 1000.0) / 100.0;
//double y = x;
double x = (i - 1000.0) / 100.0;
double y = sin(x * 10.0) / (1.0 + x * x);
Sine_point sample; sample.x = x; sample.y = y;
graph[i] = sample;
std::cout<<graph[i].x<<graph[i].y<<std::endl;
if(sample.x < min.x ) min.x = sample.x;
if(sample.y < min.y ) min.y = sample.y;
if(sample.x > max.x ) max.x = sample.x;
if(sample.y > max.y ) max.y = sample.y;
}
cv::Size imageSize(640,480); // your window size
cv::Mat image(imageSize, CV_8UC1);
if (image.empty()) //check whether the image is valid or not
{
std::cout << "Error : Image cannot be created..!!" << std::endl;
system("pause"); //wait for a key press
return -1;
}
//now scale your points to fit inside the image:
Sine_point dataOffset;
// here you could define the offsets by yourself, I just use image borders and scale the values to fit inside the image
dataOffset.x = -min.x;
// we have to mirror the y axis!
dataOffset.y = min.y;
Sine_point dataScale;
dataScale.x = (double)imageSize.width / (max.x - min.x);
// remember to mirror the y axis
dataScale.y = - (double)imageSize.height/ (max.y - min.y);
// scale the samples
for(unsigned int i=0; i<nSamples; ++i)
{
graph[i].x = (graph[i].x + dataOffset.x) * dataScale.x;
graph[i].y = (graph[i].y + dataOffset.y) * dataScale.y;
}
// draw the samples
for(unsigned int i=1; i<nSamples; ++i)
{
cv::Point2f p1; p1.x = graph[i-1].x; p1.y = graph[i-1].y;
cv::Point2f p2; p2.x = graph[i].x; p2.y = graph[i].y;
cv::line(image, p1, p2, 'r', 5, 8, 0);
}
cv::namedWindow("MyWindow", CV_WINDOW_AUTOSIZE); //create a window with the name "MyWindow"
cv::imshow("MyWindow", image); //display the image which is stored in the 'img' in the "MyWindow" window
cv::imwrite("sinusDraw.png", image);
cv::waitKey(0); //wait infinite time for a keypress
return 0;
}
给我这个结果:
关于c++ - 尝试使用 opencv c++ 绘制简单函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24526617/
我正在尝试从我的系统中完全删除 opencv。我试图学习 ROS,而在教程中我遇到了一个问题。创建空工作区后,我调用catkin_make 它给出了一个常见错误,我在 answers.ros 中搜索并
我在尝试逐步转移对warpAffine的调用时遇到崩溃(不是异常): void rotateImage( const Mat& source, double degree, Mat& output )
如何处理opencv gpu异常?是否有用于opencvgpu异常处理的特定错误代码集api? 我尝试了很多搜索,但只有1个错误代码,即CV_GpuNotSupported。 请帮帮我。 最佳答案 虽
笔记 我是 OpenCV(或计算机视觉)的新手,所以告诉我搜索查询会很有帮助! 我想问什么 我想编写一个从图片中提取名片的程序。 我能够提取粗略的轮廓,但反射光会变成噪点,我无法提取准确的轮廓。请告诉
我想根据像素的某个阈值将Mono16类型的Mat转换为二进制图像。我尝试使用以下内容: 阈值(img,ret,0.1,1,CV_THRESH_BINARY); 尝试编译时,出现make错误,提示: 错
我对使用GPU加速的OpenCV中的卷积函数有疑问。 使用GPU的卷积速度大约快3.5 运行时: convolve(src_32F, kernel, cresult, false, cbuffer);
我正在尝试使用非对称圆圈网格执行相机校准。 我通常找不到适合CirclesGridFinder的文档,尤其是findHoles()函数的文档。 如果您有关于此功能如何工作以及其参数含义的信息,将不胜感
在计算机上绘图和在 OpenCV 的投影仪上投影之间有什么区别吗? 一种选择是投影显示所有内容的计算机屏幕。但也许也有这样的选择,即在投影仪上精确地绘制和投影图像,仅使用计算机作为计算机器。如果我能做
我将Processing(processing.org)用于需要人脸跟踪的项目。现在的问题是由于for循环,程序将耗尽内存。我想停止循环或至少解决内存不足的问题。这是代码。 import hyperm
我有下面的代码: // Image Processing.cpp : Defines the entry point for the console application. // //Save
我正在为某些项目使用opencv。并有应解决的任务。 任务很简单。我有一张主图片,并且有一个模板,而不是将主图片与模板进行比较。我使用matchTemplate()函数。我只是好奇一下。 在文档中,我
我正在尝试使用以下命令创建级联分类器: haartraining -data haarcascade -vec samples.vec -bg negatives.dat -nstages 20 -n
我试图使用OpenCV检测黑色图像中一组形状的颜色,为此我使用了Canny检测。但是,颜色输出总是返回为黑色。 std::vector > Asteroids::DetectPoints(const
我正在尝试使用OpenCv 2.4.5从边缘查找渐变方向,但是我在使用cvSobel()时遇到问题,以下是错误消息和我的代码。我在某处读到它可能是由于浮点(??)之间的转换,但我不知道如何解决它。有帮
我正在尝试构建循环关闭算法,但是在开始开发之前,我想测试哪种功能描述符在真实数据集上效果更好。 我有两个在两个方向拍摄的走廊图像,一个进入房间,另一个离开同一个房间。因此它们代表相同的场景,但具有2个
有没有一种方法可以比较直方图,但例如要排除白色,因此白色不会影响比较。 最佳答案 白色像素有 饱和度 , S = 0 .因此,在创建直方图时很容易从计数中删除白色像素。请执行下列操作: 从 BGR 转
就像本主题的标题一样,如何在OpenCV中确定图像的特定像素(灰度或彩色)是否饱和(例如,亮度过高)? 先感谢您。 最佳答案 根据定义,饱和像素是指与强度(即灰度值或颜色分量之一)等于255相关联的像
我是OpenCV的新用户,正在从事大学项目。程序会获取输入图像,对其进行综合模糊处理,然后对其进行模糊处理。当对合成模糊图像进行反卷积时,会生成边界伪像,因为...好吧,到目前为止,我还没有实现边界条
我想知道OpenCV是haar特征还是lbp是在多尺度搜索过程中缩放图像还是像论文中提到的那样缩放特征本身? 编辑:事实证明,检测器可以缩放图像,而不是功能。有人知道为什么吗?通过缩放功能可以更快。
我在openCv中使用SVM.train命令(已定义了适当的参数)。接下来,我要使用我的算法进行分类,而不是使用svm.predict。 可能吗?我可以访问训练时生成的支持 vector 吗?如果是这
我是一名优秀的程序员,十分优秀!