将2d矩阵的值赋给变量

时间:2011-02-18 13:31:52

标签: c++

我有一个3x3矩阵,没有排序。

按升序或降序对3x3矩阵进行排序后,我想将中值存储在整数变量(int med)中。

由于我的矩阵具有奇数个元素,我知道每次中值都是matrix[1][1],所以我基本上写得像这样:

int med = matrix[1][1];

虽然在运行应用程序中位数时我在Visual Studio中没有编译时错误,但我得到了以下运行时错误:

"#2 run time check failure..the stack around variable matrix[][] is corrupted..

以下是代码:

#include "stdafx.h"
#include <math.h>
#include <mtip.h>
#define MAX 3

int medianfilter_MIF(HMTIPMOD hMod ,Dataset_byte *in,Dataset_byte **out,int th) 
{
    if(!in)
    {
        mmsg_ReportError("Missing input!");
        return MRV_FAILURE;
    }

    *out = (Dataset_byte*)md_DatasetClone((Dataset*)in, DST_SAME);
    if(!*out)
    {
        mmsg_ReportError("Could not clone image!");
        return MRV_FAILURE;
    }


    BYTE *pin = DATA_PTR(in);
    BYTE *pout = DATA_PTR(*out);
    int d_w = NX(in); 
    int d_h = NY(in);
    int mask2d_int[MAX][MAX];
    int *element;
    int temp;

    for (int i = 1; i < d_w - 1; i++){  
        for (int j = 1; j < d_h - 1; j++){
            int temp = VAL2(in,i,j);
            mmsg_ReportError("the value of temp is: %d ",temp);
            for (int p = i - 1; p < i + 2; p++){
                for (int q = j - 1; q < j + 2; q++){
                    mask2d_int[p][q]=VAL2(in,p,q);
                    mmsg_ReportError("the value of mask2d_int[p][q] : %d ",mask2d_int[p][q]);
                }
            }


    for (element = &mask2d_int[0][0]; element <= &mask2d_int[MAX-1][MAX-1]; element ++) {
                 if (*element > *(element + 1)) {
               *element ^= *(element + 1); /* exclusive or swap */
               *(element + 1) ^= *element;
               *element ^= *(element + 1);
               }
        msg_ReportError("the value of element after swapping is %d ",element);
            }
            int med = mask2d_int[1][1];
            mmsg_ReportError("the value of median is: %d ",med);
            if ((temp - med) < th){
                *pout = temp;
                mmsg_ReportError("the value of *pout before is %d ",*pout);
                }
            else{
                *pout = med;
                mmsg_ReportError("the value of *pout after is %d ",*pout);
                }
            ++pout;
            }
        }
    return MRV_SUCCESS;
}


int medianfilter_MDF(HMTIPMOD hMod)
{
    INPUT_DATASET("Input image", 0, 0, DST_BYTE, CONN_REQUIRED);
    OUTPUT_DATASET("Output image", 0, 0, DST_BYTE, 0);
    CONTROL_INT_SLIDER("threshold:",30,0,255);
    return MRV_SUCCESS;
}

REGISTER_MTIP_MODULE("Median Filter", medianfilter_MDF, medianfilter_MIF, 0, 0, 0);

1 个答案:

答案 0 :(得分:1)

看看

for (element = &mask2d_int[0][0]; element <= &mask2d_int[MAX-1][MAX-1]; element ++) {
                                          ^^
                 if (*element > *(element + 1)) {
                                  ^^^^^^^^^^^

你循环element <= &mask2d_int[MAX-1][MAX-1]这意味着元素运行并包括最后一个int,然后你将它与“next”int(不存在)进行比较,并可能交换。

多维数组后面的字节包含一个“魔术值”,由编译器放置(可能是生成调试版本)。在数组之后用字节交换数组中的最后一个int会破坏此值,从而导致您看到的错误。

将for循环更改为

for (element = &mask2d_int[0][0]; element < &mask2d_int[MAX-1][MAX-1]; element ++) {
                                          ^

应该这样做。

如果您想要的是让它运转起来 - 那么我就说了 - 但我注意到您对矩阵进行排序的唯一原因是获得中位数,并且您已经标记了这个问题“c ++”意味着如果您有兴趣,有一些更简单的方法可以做到这一点。