Форум программистов, компьютерный форум, киберфорум
Massaraksh7
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
Библиотека матвычислений на Delphi.
Здесь будут публиковаться рабочие процедуры, выполняющие различные математические вычисления.

Интересная функция

Запись от Massaraksh7 размещена 20.03.2024 в 00:14
Показов 1312 Комментарии 3

Нашёл забавную функцию, график которой при изменении параметра причудливо меняет форму, напоминая то ли сокращающееся сердце, то ли ещё что. Функция в декартовых координатах неявная, поэтому график строится через преобразование в полярные координаты, и решение кубического уравнения.
(x2+y2)2-A*x*y2=850*y
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
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
unit Unit1;
 
{$mode objfpc}{$H+}
 
interface
 
uses
  Classes, SysUtils, Forms, Controls, Graphics, Dialogs, StdCtrls, ComCtrls,
  ExtCtrls, TAGraph, TASeries, Math;
 
type
 
  { TForm1 }
 
  TForm1 = class(TForm)
    Chart1: TChart;
    Chart1LineSeries1: TLineSeries;
    Image1: TImage;
    Label1: TLabel;
    TrackBar1: TTrackBar;
    procedure FormShow(Sender: TObject);
    procedure TrackBar1Change(Sender: TObject);
  private
  ak:integer;
  procedure DoGraph;
  public
  end;
 
var
  Form1: TForm1;
 
implementation
 
{$R *.lfm}
 
{ TForm1 }
 
//-------Решение куб. уравнения по формуле Кардано
function Kardano(a,b,c,d:Extended):Extended;
var p,q,qq,alfa,beta:Extended;
begin
p:=(3*a*c-b*b)/(3*a*a);
q:=(2*b*b*b-9*a*b*c+27*a*a*d)/(27*a*a*a);
qq:=p*p*p/27+q*q/4;
if qq>0 then
   begin
   alfa:=power(-q/2+Sqrt(qq),1/3);
   beta:=power(-q/2-Sqrt(qq),1/3);
   Result:=alfa+beta;
   end;
if qq=0 then Result:=0;
if qq<0 then Result:=0;
end;
 
//------Функция в полярных коррдинатах сводится к решению куб. уравнения
function MyFunc(ap,fi:Extended):Extended;
var cf,sf,x:Extended;
a,b,c,d:Extended;
begin
a:=1;
cf:=cos(fi*PI/180);sf:=sin(fi*PI/180);
b:=ap*cf*sf*sf;
c:=0;
d:=-850*sf;
Result:=Kardano(a,b,c,d);
end;
 
//-----------График функции (x^2+y^2)^2+-a*x*y^2=850y    -43<=a<=43
//-----------Полярн.коорд r^3+-a*cos(ф)*sin^2(ф)*r^2-850*sin(ф)=0;     r=f(ф)
procedure TForm1.DoGraph;
var i:integer;
r,x,y:Extended;
begin
Chart1LineSeries1.Clear;
if ak<0 then Chart1LineSeries1.LinePen.Color:=clRed else Chart1LineSeries1.LinePen.Color:=clBlue;
for i:=0 to 180 do
   begin
   r:=MyFunc(Form1.ak,i);
   x:=r*cos(i*PI/180);
   y:=r*sin(i*PI/180);
   if i=0 then begin x:=0;y:=0;r:=0;end;
   Chart1LineSeries1.AddXY(x,y);
   end;
end;
 
procedure TForm1.TrackBar1Change(Sender: TObject);
begin
ak:=TrackBar1.Position;
Label1.Caption:='a='+IntToStr(ak);
DoGraph;
end;
 
procedure TForm1.FormShow(Sender: TObject);
begin
ak:=0;DoGraph;
end;
 
end.
Миниатюры
Нажмите на изображение для увеличения
Название: Func.gif
Просмотров: 203
Размер:	1.50 Мб
ID:	8572  
Размещено в Без категории
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 3
Комментарии
  1. Старый комментарий
    Аватар для gunslinger
    На тему "сердца": https://www.cyberforum.ru/cpp-... 91822.html
    Запись от gunslinger размещена 20.03.2024 в 02:05 gunslinger вне форума
  2. Старый комментарий
    Аватар для Massaraksh7
    Цитата Сообщение от gunslinger
    На тему "сердца": https://www.cyberforum.ru/cpp-... 91822.html
    Да, кардиоида-то известна ещё с 18 века. А вот "действующая модель" - это, действительно, забавно. )))
    Запись от Massaraksh7 размещена 20.03.2024 в 03:08 Massaraksh7 вне форума
  3. Старый комментарий
    Аватар для gunslinger
    Я хотел сказать, что "сердце" тоже можно анимировать.
    Запись от gunslinger размещена 20.03.2024 в 09:58 gunslinger вне форума
 
Новые блоги и статьи
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
Модель здравосохранения 17. Планы на выгорание
anaschu 23.05.2026
Вот конкретная схема реализации: В классе Работник добавить: накопленнаяУсталость — растёт каждый час работы, снижается в перерывы и болезни коэффициентПрезентеизма — снижает продуктивность. . .
Изменение цветов в палитре gif файла aka фавикона
russiannick 23.05.2026
Изменение цветов в палитре gif файла, юзаемого как фавиконка в составе html-файла, помещенная в base64, средствами нативного Java Script, навеянное сном в майский день. Для работы необходим браузер,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru