Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 2003.06.02;
Скачать: [xml.tar.bz2];

Вниз

Метод Монте-Карло   Найти похожие ветки 

 
Dimich1978   (2003-05-21 17:38) [0]

мне необходимо вычилить площадь круга
(x-0.5)^2+(y-0.5)^2<1/4
и объем шара
(x-0.5)^2+(y-0.5)^2+(z-0.5)^2<1/4
Вот мой код, что не так подскажите(просто мне ажется что, где то вкралась ошибка), но никак не пойму где.
Заранее всем благодарен.
Program Monte_Carlo;
uses crt;
label 10;
var
i,n,m,m1:integer;
x,y,z:real;
begin
ClrScr;
writeln("Найдено количество 200 точек для каждой размерности");
Randomize;
m:=0;
m1:=0;
n:=0;
10:
n:=n+1;
x:=2*random-1;
y:=2*random-1;
z:=2*random-1;
if (sqr(x-0.5)+sqr(y-0.5))<(1/4) then m:=m+1;
if (sqr(x-0.5)+sqr(y-0.5)+sqr(z-0.5))<(1/4) then m1:=m1+1;
if (m>=200)and(m1>=200) then else goto 10;
writeln("Площадь круга равна=",4*(m/n));
writeln("Объем шара равен=",4*(m1/n));
readln;
end.


 
AFrolov   (2003-05-21 17:43) [1]

Сдесь бы цикл неплохо использовать (если надо именно методом монтекарло). А вообще то можно и аналитически вычислить...


 
Sandman25   (2003-05-21 18:12) [2]

По-моему, x, y и z должны находиться в интервале [0,1), а не [-1,1).
Или придется брать abs(x), abs(y), abs(z) перед подстановкой в формулы.


 
nikkie   (2003-05-21 19:15) [3]

>просто мне ажется что, где то вкралась ошибка
а почему так ажется-то? считать вроде правильно должна, только для шара надо умножать на 8, а не на 4...



Страницы: 1 вся ветка

Форум: "Основная";
Текущий архив: 2003.06.02;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.44 MB
Время: 0.008 c
1-2979
Chaos
2003-05-21 15:13
2003.06.02
Банальная работа со строками


1-2962
Dracula2000
2003-05-21 10:01
2003.06.02
Главное окно...


4-3225
Igor
2003-04-03 09:58
2003.06.02
Перехват процесса.


3-2812
DBDev
2003-05-15 11:44
2003.06.02
как корректно записать объект OLE в поле БД?


14-3121
Vital
2003-05-14 15:59
2003.06.02
Web Snap





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский