Форум программистов, компьютерный форум, киберфорум
Matlab
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/35: Рейтинг темы: голосов - 35, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 07.11.2012
Сообщений: 20

Метод Ромберга

27.02.2013, 17:01. Показов 6719. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день! Подскажите,как посчитать определенный интеграл при помощи алгоритма Ромберга?
Здесь он изложен теоретически http://www.exponenta.ru/educat... ch/4_1.asp как представить в виде программы?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.02.2013, 17:01
Ответы с готовыми решениями:

Найти площадь заштрихованной фигуры (метод половинного деления и метод трапеций)
Нужно найти площадь заштрихованной фигуры используя метод половинного деления и метод трапеций вот программа clc; clear; ...

Метод Ромберга
помогите перевести в паскаль. плииииз....

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

3
 Аватар для Зосима
5245 / 3573 / 379
Регистрация: 02.04.2012
Сообщений: 6,477
Записей в блоге: 18
27.02.2013, 18:44
Вообщем, лапа, погуглил я данный метод и окромя теории наткнулся на готовую матлаб-функцию:
http://www.math.ntnu.no/emner/... /romberg.m
Можешь ее использовать, но я из нее сделаю скриптик без заморочек
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
clear, clc
 
% подинтегральная ф-ция
f = inline('exp(-x).*sin(5*x).^2');
% пределы
a = 0;
b = 5;
% порядок интегрирования
n = 5;
 
% пустая матрица
R = zeros([n + 1, n + 1]);
% Начальное приближение.  Один интервал по методу трапеций.
R(1,1) = (b - a) / 2 * (f(a) + f(b));
 
% Первый столбец таблицы. 
% Значения интегралов
for i = 1 : n
   h = (b - a) / 2^i;
   s = 0;
   for k = 1 : 2^(i-1)
      s = s + f( a+(2*k-1)*h ) ;
   end
   R(i+1,1) = R(i,1)/2 + h*s;
end
 
% Рассчет уточнений
for j = 1:n
   fac = 1/(4^j-1);
   for m = j:n
      R(m+1, j+1) = R(m+1, j) + fac*(R(m+1,j) - R(m,j));
   end
end
 
R % таблица 
r = R(n+1,1) % итоговый результат
quad(f,a,b) % точное значение для сравнения
Добавлено через 1 минуту
И результат:
Matlab M
1
2
3
4
5
6
7
8
9
10
11
12
13
R =
    0.0003         0         0         0         0         0
    0.0011    0.0013         0         0         0         0
    0.0012    0.0013    0.0013         0         0         0
    0.0012    0.0012    0.0012    0.0012         0         0
    0.4886    0.6511    0.6944    0.7054    0.7082         0
    0.4916    0.4926    0.4821    0.4787    0.4778    0.4776
 
r =
    0.4916
 
ans =
    0.4918
1
0 / 0 / 0
Регистрация: 07.11.2012
Сообщений: 20
27.02.2013, 23:04  [ТС]
спасибо огромное!
0
0 / 0 / 0
Регистрация: 16.04.2013
Сообщений: 5
15.05.2013, 00:46
помогите перевести код в C++. с индексами беда. не могу разобраться там где счетчик со степенью.

Вот такой примерный код:

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
double a = 0; double b = 5; double s; double fac; double r;
    N = 5;
 
    matrix R;
    allocMem(N+1, N+1, R);
 
    vector h;
    allocMemVec(N,h);
    freeMemV(h);
 
 
    R.m[0][0] = (b - a) / 2.0 * (f(a) + f(b));
 
 
    for (int n=0; n < N; n++)
    {
    h.m[n] = (b - a) / pow(2.0,n+1.0);
       s = 0;
       for (int k=0; k <= pow(2.0,(n-1.0))-1.0; k++)
          {s = s+1.0 + f( a+(2.0*(k+1.0)-1.0)*h.m[n]) ;}
        R.m[n+1][0] = R.m[n][0]/2.0 + h.m[n]*s;
    }
 
    for (int j=1; j <= N; j++)
      { fac = 1.0/(pow(4.0,j)-1.0);
       for (int m=j; m <= N; m++)
          {R.m[m+1][j+1] = R.m[m+1][j] + fac*(R.m[m+1][j] - R.m[m][j]);}
      }
 
    printMatrix(R);
 
    for (int n=0; n < N; n++)
        for (int m=0; m < N; m++)
         r = R.m[N+1][1];
 cout << endl;
   cout << r;
Добавлено через 1 час 10 минут
ложная тревога, разобрался.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.05.2013, 00:46
Помогаю со студенческими работами здесь

СЛАУ. Метод обратной матрицы, метод Гаусса, метод Крамера, метод Зейделя
Помогите ребят. Не могу построить алгоритмы для этих методов Язык C++

Написать три алгоритма решения СЛАУ: Метод прогонки, метод квадратных корней, метод вращений
Начал писать курсовую. Нужно написать три алгоритма решения СЛАУ: прогонки, квадратных корней, вращений. С методом прогонки более менее...

Метод медиан из трех элементов VS улучшенный быстрый метод сортировки(метод Бентли-Макилроя)
Здравствуйте! Дали весьма интересное задание. Сравнить два вышеуказанных метода сортировки для массива из 10000 элементов, результаты...

Мой код - метод бисекции, метод секущих (метод хорд)
Всем привет!!! Изучаем в институте С++. Сделал код, и там, и там одна и та же проблема - при любых вбиваемых значениях программа делает...

Аналитический метод, метод половинного деления и метод итераций
Всем привет! Задача такая 1. Определить аналитическим путем точное решение уравнения a*x+b=0 на отрезке -5≤x≤5. При этом...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
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