Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/29: Рейтинг темы: голосов - 29, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 21.05.2012
Сообщений: 8

Процедура вычисления кратного интеграла методом Монте-Карло

21.05.2012, 17:59. Показов 5614. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Создать функцию для вычисления кратных интегралов методом Монте Карло.
Помогите написать рабочий код. Укажите на ошибки.


C++
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#include <stdio.h>
#include <time.h>
#include <math.h>
#include <conio.h>
#include <stdlib.h>
 
double func(double a, double b, double c)
{
    return (a*b*c)/sqrt(pow(a,2)+pow(b,2)+pow(c,2));
}
 
int debug(int x)
{
    if((x>-32768) && (x<32767));
    else
   {
    printf("\n \t \t Vy vveli nevernyj simvol. \n \t \t Neobhodimo bylo vvesti celoe chislo. \n \n");
    getch();
    exit(1);
    }
    return 0;
}
 
void main()
{
    double x, y, z;
   double a, b, c;
   unsigned int n;
   int i;
   double sum=0;
   double S=0;
   double min=0;
 
   srand(time(NULL));
    printf("\n \t Vvediteniz. granicu integrirovanija (x): ");
    scanf("%lf",&x);
   debug(x);
 
    printf("\t Vvedite granicu integrirovanija (y): ");
    scanf("%lf",&y);
   debug(y);
 
   printf("\t Vvedite  granicu integrirovanija (z): ");
    scanf("%lf",&z);
   debug(z);
 
 
    inv: printf("\n \t Vvedite chislio ispytanij \n");
    printf("\t N = ");
    scanf("%d",&n);
   if((n<0) || (n>65535))
   {
    printf("\n \t Vy vveli nepravilnoe chislo, kolichestvo mozhet byt ot 0 do 65535 \n");
    goto inv;
   }
 
 
    printf("\n \t / / / \n");
    printf("\t | | | (x*y*z)/sqr(pow(x,2)+pow(y,2)+pow(z,2))dxdydz \n");
    printf("\t / / / \n");
   printf("\t   D   \n");
 
   // вычисления двойного интеграла
   for(i=0;i<n;i++)
   {
 
    a=x*rand()/RAND_MAX;//генерируем x в интервале
      b=y*rand()/RAND_MAX;//генерируем y в интервале
      c=z*rand()/RAND_MAX;//генерируем z в интервале
 
      if (sqrt(pow(a,2)+pow(b,2)+pow(c,2))<=1)
    {
           sum+=func(a, b, c);
        }
         printf("\n \n \t a,b,c = %8.3lf %8.3lf %8.3lf\n", a,b,c);
   }
   S=(((x-0)*(y-0)*(z-0))/n)*sum;
   printf("\n \n \t Integral = %8.3lf \n", S);
 
   getch();
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.05.2012, 17:59
Ответы с готовыми решениями:

Решения кратного интеграла методом Монте Карло на С++
Помогите пожалуста решить тройной интеграл методом Монте Карло.... Нужно написать програму на С :cry: :cry:

Программа для вычисления интеграла с заданной точностью методом Симпсона и методом Монте-Карло
Здравствуйте, подскажите как решить эту задачу, пожалуйста: Разработать программу для вычисления интеграла с заданной точностью методом...

Вычисление интеграла методом Монте-Карло
Нужно вычислить интеграл, как показано на первой картинке внизу темы. На второй картинке сам интеграл. Написал программу, но она выдает это...

5
0 / 0 / 0
Регистрация: 21.05.2012
Сообщений: 8
21.05.2012, 19:00  [ТС]
Помогите пожалуйста.
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
21.05.2012, 19:40
А с этим кодом что не так? Вроде считает и выдаёт 0.025, т. е. 1/40
1
0 / 0 / 0
Регистрация: 21.05.2012
Сообщений: 8
21.05.2012, 20:01  [ТС]
При каких это значениях?
Borland C++, у меня рандомные значение даже в в интервал(выбора) не попадают.
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
21.05.2012, 20:17
Цитата Сообщение от unt Посмотреть сообщение
При каких это значениях?
1, 1, 1

Цитата Сообщение от unt Посмотреть сообщение
Borland C++, у меня рандомные значение даже в в интервал(выбора) не попадают.
Это как? От 0 до заданного значения получаются a, b и с.

Добавлено через 5 минут
Проверил с BorlandC 3.1. Тоже работает.
1
0 / 0 / 0
Регистрация: 21.05.2012
Сообщений: 8
21.05.2012, 20:24  [ТС]
Спасибо. Похоже, я что-то перепутал.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.05.2012, 20:24
Помогаю со студенческими работами здесь

Вычисление интеграла методом Монте-Карло
Здравствуйте! Задача такая: пользователь в текстовом файле задает координаты точек (любое количество точек), программа считывает...

Вычисление интеграла методом Монте-Карло
Здравствуйте. Помогите в написании программы. Вычислить приближенно интеграл методом Монте-Карло. Рассмотреть случай с 1000 испытаний,...

Вычисление интеграла геометрическим методом Монте-Карло
Всем доброго времени суток. В универе дали задание: вычислить интеграл \int_{0}^{1}dx\int_{0}^{1-x}(1-x-y)dy геометрическим методом...

Решение определенного интеграла методом Монте Карло
Доброго времени суток ! Столкнулся с такой проблемой, что реализовал вроде бы правильно, а результат не верный, совсем зашел в тупик....

Рассчет определенного интеграла методом Монте-Карло.
Не могли бы вы посмотреть, я неправильно понимаю метод Монте Карло для нахождения определенного интеграла или неправильно его реализую? ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru