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

Методом Монте-Карло определить площадь фигуры

Вчера, 14:46. Показов 153. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Поздравляю всех читающих с прошедшим Новым Годом и поздравляю со Старым Новым Годом.
Задача: Методом Монте-Карло определить площадь закрашенной фигуры. Сравнить найденное значение с вычисленным геометрическим путём. Код для программы PascalABC.NET.
Прошу помочь с решением задачи.
Миниатюры
Методом Монте-Карло определить площадь фигуры  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
Вчера, 14:46
Ответы с готовыми решениями:

Найти площадь фигуры методом Монте-Карло
Найти площадь фигуры методом Монте-Карло. Help)

Найти площадь методом Монте-Карло
Методом Монте-Карло определить площадь закрашенной фигуры. Сравнить найденное значение с вычисленным геометрическим путём. фото:

Вычислить интеграл методом Монте-Карло
Составить программу на языке высокого уровня, вычисляющую определенный интеграл 5 - exp(-2*x) на промежутке от -1 до 1 методом Монте-Карло...

Нахождение площади методом Монте-Карло.
Решить задачу нахождения площади области методом Монте-Карло

Вычисление интеграла методом Монте-Карло
Задания под буквой б

3
168 / 125 / 51
Регистрация: 14.06.2024
Сообщений: 343
Вчера, 16:39 2
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
begin
  var g:=0.0;
  var h:=2;
  while h<=8 do
  begin
    g:=g+h*2;
    h:=h+2;
  end;
  g:=g-2*8/2;
  //
  var m:=0.0;
  randomize;
  var n:=10000;
  for var i:=1 to n do
  begin
    var x:=random(65)/8;
    var y:=random(65)/8;
    var l:=Int(x/2)*2;
    if(x>=l)and(x<=l+2)and(y<=l+2)and(y>=x/4)then
      m:=m+1;
  end;
  m:=8*8*m/n;
  writeln(m,' ',g);
end.
1
Модератор
10068 / 5409 / 3354
Регистрация: 17.08.2012
Сообщений: 16,562
Вчера, 22:43 3
udmurt2024, Ваша программа получилась так себе, но её можно улучшить:
  • В задании написано, что точную площадь нужно вычислить геометрическим путём. То есть, вычислять точную площадь в программе не нужно, её просто нужно вычислить любым способом заранее. Допустим, что нужно всё же вычислить точную площадь программно. Для определения точной площади цикл не нужен. Площадь под ступенчатой функцией можно определить как четвёртое треугольное число, умноженное на площадь одного квадрата 2х2, из которых эта функция "сложена": (4 * (4 + 1) / 2 * 4) или как сумму четырёх членов арифметической прогрессии с первым членом 4 и разностью прогрессии 4: ((2 * 4) + 4 * (4 - 1)) / 2 * 4), а затем вычесть площадь треугольника. Или наоборот, можно к площади треугольника добавить три ступеньки.
  • Процедура randomize в Pascal ABC.NET ничего не делает, оставлена только для совместимости с другими диалектами паскаля. ГПСЧ инициализируется при запуске программы.
  • Ваш способ получения действительного случайного числа никуда не годится, поскольку генерируются не все числа из диапазона [0..8], а только те из них, дробная часть которых при умножении на 8 даёт целое число (0 или 1). Иными словами, вместо одного из 72057594037927937 возможных чисел типа real в диапазоне [0..8] Вы генерируете всего 65 возможных чисел. ВСЕГО 65, Карл! С таким же успехом могли бы написать просто random(9), мало бы что изменилось. Зачем Вы так сделали, неясно, ведь есть же функция random без аргументов, которая генерирует случайное действителльное число в диапазоне [0..1). Например, 8 * random сгенерирует одно из 9007199254740992 чисел. Конечно, это не 72057594037927937, но и не 65. Сгенерировать любое из 72057594037927937 возможных чисел из диапазона [0..8] можно так: 7 * random + random, но для данной программы это, по-моему, уже излишество.
  • Лишние условия в операторе if.
Можно, например, так:
Pascal
1
2
3
4
5
6
7
8
9
10
##
  var g := 32.0; //4 * (4 + 1) / 2 * 4 - 2 * 8 / 2;
  var (m, n) := (0, 10000);
  loop n do
    begin
      var (x, y) := (8 * random, 8 * random);
      if (y >= x / 4) and (y <= int(x / 2) * 2 + 2) then m += 1
    end;
  $'Площадь по методу Монте-Карло ({n} точек): {8 * 8 / n * m}'.Println;
  $'Точное значение площади: {g}'.Println
0
2351 / 1454 / 526
Регистрация: 07.04.2017
Сообщений: 4,792
Сегодня, 03:30 4
Цитата Сообщение от Cyborg Drone Посмотреть сообщение
Например, 8 * random сгенерирует одно из 9007199254740992 чисел. Конечно, это не 72057594037927937
Как может 2^56 получиться?
Максимум в 64-битный флоат можно записать 53 бита: 52 мантисы, но если уменьшать экспоненту - имеем бесконечнюу (почти) геометрическую последовательность с шагом 1/2, поэтому сумма кол-ва вариантов будет в 2 раза больше.
В .Net Core 53 бита и заполняет, но в .Net Framework (на котором пока что этот паскаль) пишет только 31 бит (конвертирует из integer).
И умножение на 8 должно менять только экспоненту, не трогая мантису, а значит вариантов должно остаться столько же...
Тем временем 7 * random + random даст не равномерное распределение - шанс получить 0..1 или 7..8 меньше:
Pascal
1
2
3
4
5
6
7
## uses PlotWPF;
 
function dist := 7 * Random + Random;
 
var a := ArrGen(100_000, i->Round(dist*100));
 
new LineGraphWPF(0, 800, x->a.CountOf(x.Round));
А вообще есть готовое Random(0.0, 8.0).
0
Сегодня, 03:30
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
Сегодня, 03:30
Помогаю со студенческими работами здесь

Нахождение площади методом Монте-Карло
Помогите, пожалуйста! Определите методом Монте-Карло площадь фигуры: 1) А; 2) В; 3) С; 4) А+С; 5) В+С; 6) В+А; 7) А+В+С Написать...

Найти длину отрезка методом Монте-Карло
Найти длину отрезка при помощи метода Фон-Неймана. Сам метод я не знаю, поэтому прошу помощи. К примеру: Точка двигается в определенном...

Определить площадь фигуры методом Монте Карло.
Составить и отладить программу определения площади фигуры методом Монте Карло в соответствии с заданием: |2x^2+y^3&lt;2 |x+y&lt;1 ...

Методом Монте-Карло определить площадь закрашенной фигуры
Методом Монте-Карло определить площадь закрашенной фигуры. Сравнить найденное значение с вычисленным геометрическим путём.

Определить площадь представленной фигуры методом Монте-Карло
Пожалуйста, помогите составить программу определения площади заданной фигуры методом Монте-Карло.

Найти площадь фигуры методом Монте-Карло
Найти площадь фигуры методом Монте-Карло. file:///C:/Users/SKR/Desktop/%D0%91%D0%B5%D0%B7%20%D0%B8%D0%BC%D0%B5%D0%BD%D0%B8.png - Фото


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на Go/Golang
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C#
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
Это работает. Скорость асинхронной логики велика. Вопрос видимо останется в стабильности. Плата - огонь!
Hrethgir 13.01.2025
По прошлому проекту в Logisim Evolution https:/ / www. cyberforum. ru/ blogs/ 223907/ blog8781. html прилагаю файл архива проекта в Gowin Eda. Восьмибитный счётчик из сумматора+ генератор сигнала. . .
UserScript для подсветки кнопок языков программировани­­­­я в зависимости от текущего раздела
volvo 13.01.2025
В результате работы этого скрипта подсвечиваются нужные кнопки не только в форме быстрого ответа, но и при редактировании сообщения: / / ==UserScript== / / @name CF_DefaultLangSelect / / . . .
Введение в модели и алгоритмы машинного обучения
InfoMaster 12.01.2025
Машинное обучение представляет собой одну из наиболее динамично развивающихся областей искусственного интеллекта, которая фокусируется на разработке алгоритмов и методов, позволяющих компьютерам. . .
Как на Python создать нейросеть для решения задач
InfoMaster 12.01.2025
В контексте стремительного развития современных технологий особое внимание уделяется таким инструментам, как нейросети. Эти структуры, вдохновленные биологическими нейронными сетями, используются для. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru