- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想为 C++ 库编写一个 Python 包装器。我想要的部分是一个 C++ 图像对象到一个 numpy 数组。我最初的想法是使用 Python C API 和 SWIG 生成绑定(bind)创建一个 PyBuffer
。 numpy.frombuffer
然后可以处理实际保存图像的 pybuffer。到目前为止,一切都很好。但是当我读到 python.memap
时,事情发生了变化,我想知道使用 python.memap
C 对象而不是 PyBuffer
是个不错的选择对象?
这里的优缺点是什么?。由 C++ 库处理的图像可能会非常大。举个例子~4GB。
最佳答案
根据要求,一个最小的例子根据 SciPy' Cookbook :
tst.i
文件是 SWIG 接口(interface)文件,其中已经包含用于动态分配 100 个 doubles
的 C++ 代码。还实现了将数组内容打印到 stdout
的函数:
%module(docstring="A Simple Numpy Memview example") tstI
%{
#define SWIG_FILE_WITH_INIT
// Her comes the C-code:
#include<iostream>
double *x = NULL;
void __call_at_begining() {
std::cout << "__call_at_begining() ..." << std::endl;
x = new double(100);
for(int i=0; i<100;i++) // fill x with some values
x[i] = i*10;
}
void __call_at_end(void) {
std::cout << "__call_at_end() ..." << std::endl;
if (x != NULL)
free(x);
}
// The interface for the memory view:
void view_x(double** d, int* d_n) {
*d = x;
*d_n = 100;
}
// dump context to stdout:
void print_x() {
std::cout << "x = ";
for(int i=0; i<100;i++)
std::cout << x[i] << " ";
std::cout << std::endl;
}
%}
%include "numpy.i"
%init %{
import_array();
__call_at_begining();
%}
%inline %{
void finalize(void) {
__call_at_end();
}
%}
// This is the SWIG magic:
%apply (double** ARGOUTVIEW_ARRAY1, int *DIM1) {(double** d, int* d_n)}
// Here's the Interface decalartion for Python:
void view_x(double** d, int* d_n); // SWIG declaration
void print_x();
我喜欢Cmake ,所以这是一个最小的 CMakeLists.txt
文件,用于使用 SWIG(在 Debian Sid 下测试),使用 cmake 构建。
和 make
:
# This is a CMake example for Python
cmake_minimum_required(VERSION 2.8)
FIND_PACKAGE(SWIG REQUIRED)
INCLUDE(${SWIG_USE_FILE})
FIND_PACKAGE(PythonLibs)
INCLUDE_DIRECTORIES(${PYTHON_INCLUDE_PATH})
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR} )
SET(CMAKE_SWIG_FLAGS "")
SET_SOURCE_FILES_PROPERTIES(tstI.i PROPERTIES CPLUSPLUS ON)
SET_SOURCE_FILES_PROPERTIES(tstI.i PROPERTIES SWIG_FLAGS "-includeall")
SWIG_ADD_MODULE(tstI python tstI.i )
SWIG_LINK_LIBRARIES(tstI ${PYTHON_LIBRARIES})
在以下使用包装器的示例 Python session 中:
In [1]: import numpy as np
In [2]: import tstI # loads module
__call_at_begining() ...
In [3]: y = tstI.view_x() # get memory view
In [4]: y[:10]
Out[4]: array([ 0., 10., 20., 30., 40., 50., 60., 70., 80., 90.])
In [5]: y[:10] = np.zeros(10)
In [6]: tstI.print_x() # dump memory contents
x = 0 0 0 0 0 0 0 0 0 0 100 110 120 130 140 150 160 170 180 190 200 210 220 230 240 250 260
270 280 290 300 310 320 330 340 350 360 370 380 390 400 410 420 430 440 450 460 470 480 490
500 510 520 530 540 550 560 570 580 590 600 610 620 630 640 650 660 670 680 690 700 710 720
730 740 750 760 770 780 790 800 810 820 830 840 850 860 870 880 890 900 910 920 930 940
950 960 970 980 990
关于用于大图像处理的 python memap 或 pybuffer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24010906/
CleanVision是一个开源的Python库,旨在帮助用户自动检测图像数据集中可能影响机器学习项目的常见问题。该库被设计为计算机视觉项目的初步工具,以便在应用机器学习之前发现并解决数据集中的问题。
我只是想知道需要什么样的计算/编程语言/框架来生成图像,例如 http://www.erdas.com/ 中的图像。 ? 以编程方式,如何生成一般空间分析图像? ps:我大部分时间都在使用java。
我尝试在我的 grails 项目(Mac OS X 上的 1.1.1)中使用一些图像处理插件或 java 库:imageTools 插件、imageJ、awt 库等。每次我从路径打开/获取图像以启动进
我有一个项目,我必须以多种方式处理图像。我陷入了像素化的困境。 对于像素化,我必须采用一组 10x10 像素并返回一个单独平均 RGB 颜色的单元格。目前我在运行程序中得到的只是一个红色图像。谢谢您的
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
这是一项作业,因为我是Python编程新手,所以我付出了很大的努力: 我正在运行以下函数,它接受图像和短语(空格将被删除,因此只有文本)作为参数,我已经获得了所有导入和预处理代码,我只需要实现这个函数
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
我需要一种简单易学且快速的方法来从背景图像、文本生成图像,然后保存为 JPEG 格式。 您有什么建议?有关于此的任何图书馆或教程吗?重要的标准是简单。 最佳答案 在 .Net 3.5/4 中,您还可以
我正在构建一个夜视应用程序,但我没有找到任何有用的算法可以应用于黑暗图像以使其清晰。任何人请给我一些好的算法。 提前致谢 最佳答案 由于 iphone 镜头和传感器的尺寸,无论您做什么,都会有很多噪音
所以我为游戏制作了这个程序,需要帮助让它更自动化一些。 程序接收图像然后显示它。我正在对 OpenGL 中的纹理执行此操作。当我截取游戏截图时,它通常约为 700x400。我将高度和宽度输入到我的程序
我想更改图像中像素的值,为此我需要将图像存储为矩阵。我怎样才能完成这项工作?请指导。 最佳答案 BufferedImage image = ImageIO.read(..); image.setRGB
概述: 我正在做一个视频创作项目。我使用的技术有:imageMagick、php、ffmpeg。 当前状态: 目前,该项目能够使用图像和文本以及很少的基本过渡来创建视频。我这样做的方式是使用 imag
我正在创建 facebook 应用程序,其中我将用户图像作为背景图像,并有一个用户可以四处移动的默认大写图像。用户将叠加图像(一顶帽子)放在正确的位置后,他点击保存 这就是我感到震惊的地方,我想知道如
我正在尝试编写一个 JavaScript 程序,通过在图像上放置三个垂直条纹来修改图像。左边三分之一是红色条纹,中间是绿色条纹,右边三分之一是蓝色条纹。 这是我试图实现的算法:1. 从您要更改的图像开
目前,我正在尝试通过图像分割方法将面部和头发修剪在一起,然后将所有非彩色像素设置为透明,然后尝试使用Binary Threshold技术和Adaptive Threshold。但是我得到了不希望的结果
我必须使此图像Book Image To Process的页面标题为:“单元3:主动学习的秘诀”,使其成为图像中的唯一页面 为此,我需要删除也在图像中的其他页面的一部分 我需要编写一个通用代码,可以对
我正在研究一个问题,其中我缩小图像的尺寸,在缩小图像中找到类似于二进制图像的有趣点。现在我只想放大在缩小图像中找到的有趣点(即白色像素点),而不是放大整个图像然后找到有趣的点。哪种技术可以最好地用于此
Closed. This question needs debugging details。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic用于堆栈溢出。 上个月关闭。 I
嗨,我需要编写一个程序,从灰度图像中删除分界(图像中带有文本) 我阅读了有关阈值和模糊的信息,但我仍然不知道该怎么做。 我的图像是这样的希伯来文本图像: 我需要删除分界线(假设分界线是图像中的最小元素
我正在做一个带有深度图像的项目。但是我的深度相机有噪音和像素读取失败的问题。有一些点和轮廓(尤其是边缘)的值为零。如何忽略这个零值并将其与周围的值混合? 我试过 dilation和 erosion (
我是一名优秀的程序员,十分优秀!