С Новым годом! Форум программистов, компьютерный форум, киберфорум
Maple
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 1
Регистрация: 06.02.2013
Сообщений: 14
1

Размытие по Гауссу в Maple

06.12.2013, 11:49. Показов 1043. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте!

Мне нужно реализовать размытие по Гауссу в Maple с помощью пакета ImageTools, причем единственная процедура, которую я могу использовать из пакета - это открытие изображение и вызов окна с его показом. То есть, генерация матрицы свертки и ее применение в программе должно быть реализовано мной.

Если с генерацией матрицы свертки проблем нет (я проверил ее с помощью стандартной процедуры Convolution), то сделать рабочий алгоритм ее применения у меня не выходит. Я переводил рабочий алгоритм с C++.

Вот код моей программы в Maple:

Matlab M
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
> restart;
> with(ImageTools);
 
> FileLocation := cat("C:/image1.jpg");
  MyImg := Read(FileLocation);
 
> View(MyImg);
 
> GaussianBlur := proc(Img::Image, RADIUS::integer)::Image;
    sigma, W, Kernel, x, y;
    flag := true;
    sigma := RADIUS;
    W := 3*sigma;
    Kernel := Matrix(1 .. W, 1 .. W);
    for x to W do for y to W do
      Kernel[x, y] := (1/2)*evalf(exp(1), 10)^((-1)*.5*((1/2)*((x-(1/2)*W)^2+(y-(1/2)*W)^2)/sigma^2))/(evalf(Pi, 10)*sigma^2)
    end do end do;
    Img1 := Img;
    Img1 := Convolution(Img, Kernel, weight = 1);
    return Img1
  end proc;
 
> GaussianBlurConv := proc(Img::Image, RADIUS::integer)::Image;
    sigma, W, Kernel, x, y;
    flag := true;
    sigma := RADIUS;
    W := 3*sigma;
    Kernel := Matrix(1 .. W, 1 .. W);
    for x to W do for y to W do
      Kernel[x, y] := (1/2)*evalf(exp(1), 10)^((-1)*.5*((1/2)*((x-(1/2)*W)^2+(y-(1/2)*W)^2)/sigma^2))/(evalf(Pi, 10)*sigma^2)
    end do end do;
    kCenterX := (1/2)*W;
    kCenterY := (1/2)*W;
    Img1 := Img;
    for i to Height(Img) do for j to Width(Img) do
      Img1[i][j] := 0;
      for m from 0 to W-1 do
        mm := W-m;
        for n from 0 to W-1 do
          nn := W-n;
          ii := i+m-kCenterY;
          jj := j+n-kCenterX;
          if 1 <= ii and ii <= Height(Img) and 1 <= jj and jj <= Width(Img) then
            Img1[i][j] := Img1[i][j]+Img[ii][jj]*Kernel[mm][nn];
          end if
        end do
      end do
    end do end do;
    return Img1
  end proc;
 
> MyImg1Blur := GaussianBlur(MyImg1, 3);
  View(MyImg1, MyImg1Blur);
 
> MyImg1Blur1 := GaussianBlurConv(MyImg1, 3);
  View(MyImg1, MyImg1Blur1);
Среда пишет такую ошибку:

Matlab M
1
2
Error, (in GaussianBlurConv) bad index into Array
Error, (in ImageTools:-View) parameters must be images or lists of images
Пожалуйста, помогите разобраться, в чем дело!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
06.12.2013, 11:49
Ответы с готовыми решениями:

Ошибка : "the kernel loader cannot find maple engine library maple.dll"
Здравствуйте! Я установила Maple 2017 на windows 10 с помощью crack. Программы открывается,но не...

Размытие по Гауссу
Пожалуйста помогите решить задачу:) Нужно сделать размытие по Гауссу в матлаб) для чб изображения...

Размытие по Гауссу
Ребят, помогите пожалуйста с размытием(конечная цель восстановления размытия по Гауссу). ...

Размытие по Гауссу с возможностью выбора радиуса размытия
Всем привет! Нужно сделать алгоритм размытия изображения по Гауссу с возможностью выбора радиуса...

0
06.12.2013, 11:49
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.12.2013, 11:49
Помогаю со студенческими работами здесь

Maple Mini STM32F103RCBT6 - не через maple ide, возможно ли
Добрый день! Вопрос новичка, у меня есть плата Mopti mini...

Распределение по Гауссу
Нужно сделать генератор случайных чисел с распределением по Гауусу. Помогите, пожалуйста. Есть код...

СЛАУ по Гауссу, чтение массива из файла
Помогите, пожалуйста, исправить. Выдаёт ошибку External:SIGFTP, никак не понимаю, что он просит и...

Взаимодействие с библиотекой MATLAB (аппроксимация кривой по гауссу)
Здравствуйте. Написал я программу, в которой с помощью библиотеки матлаб проходит аппроксимация...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru