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

Движение маятника в Borland 3.1

07.05.2012, 20:00. Показов 3541. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать программу имитирующую движение(без затухания) маятника. Помогите пожалуйста,не могу разобраться.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.05.2012, 20:00
Ответы с готовыми решениями:

движение маятника
var Form1: TForm1; n:real; implementation {$R *.dfm} procedure TForm1.Timer1Timer(Sender: TObject); var R: integer; ...

Организовать движение маятника
есть картинка нужно организовать движение маятника как поворачивать картинку относительно верхней середины картинки или как...

Движение математического маятника
Всем привет. Нужно срочно написать программу движения математического маятника на C#. Отклонение примерно сделать градусов в 45. Вот то...

9
74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
07.05.2012, 20:25
Графика шоле?
0
0 / 0 / 0
Регистрация: 07.05.2012
Сообщений: 14
07.05.2012, 20:39  [ТС]
да
есть ли какие нибудь формулы параметрические для задания движения по х и по у?
0
74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
09.05.2012, 19:21
Цитата Сообщение от djvipmax Посмотреть сообщение
да
есть ли какие нибудь формулы параметрические для задания движения по х и по у?
Формулы для математического маятника без учёта трения?

Добавлено через 27 минут
маятник
1
0 / 0 / 0
Регистрация: 07.05.2012
Сообщений: 14
11.05.2012, 15:32  [ТС]
Цитата Сообщение от Hi4ko Посмотреть сообщение
Формулы для математического маятника без учёта трения?

Добавлено через 27 минут
маятник
без учета( но если есть информация с учетом времени то предоставьте мне ее пожалуйста, для личного интереса)
0
74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
11.05.2012, 16:02
Цитата Сообщение от djvipmax Посмотреть сообщение
без учета( но если есть информация с учетом времени то предоставьте мне ее пожалуйста, для личного интереса)
Посмотри внимательно pdf-ку, там внимательно всё написано)
В вакууме координата x меняется по гармоническому закону(синусоиде), а при учёте вязкого трения по экспоненциальной).
1
0 / 0 / 0
Регистрация: 07.05.2012
Сообщений: 14
11.05.2012, 19:38  [ТС]
Цитата Сообщение от Hi4ko Посмотреть сообщение
Посмотри внимательно pdf-ку, там внимательно всё написано)
В вакууме координата x меняется по гармоническому закону(синусоиде), а при учёте вязкого трения по экспоненциальной).
а координата по у?

Добавлено через 12 минут
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
#include<iostream.h>
#include<conio.h>
#include<graphics.h>
#include<dos.h>
#include<stdlib.h>
#include<math.h>
int x0,y0,x,y,l,dlinapodvesa=50;
float u=-3;
void main()
{
 
int gdriver = DETECT, gmode, errorcode;
initgraph(&gdriver,&gmode,"");
errorcode = graphresult();
if(errorcode !=grOk)
  {
   cout<<"Graphicheskaia oshibka:%\n"<<grapherrormsg(errorcode);
   cout<<"Nagmite klavishy";
   getch();
   exit(1);
  }
 
setcolor(YELLOW);
 
line(getmaxx()/2-dlinapodvesa,getmaxy()/3,getmaxx()/2+dlinapodvesa,getmaxy()/3);
x0=getmaxx()/2; y0=getmaxy()/3;  x=getmaxx()/2;
 
 
while(!kbhit())
{
setcolor(RED);
line(x0,y0,x,y);
 
// [COLOR="Red"]тут нужно изменить  координаты  х и у. как это сделать?[/COLOR]
 
setcolor(YELLOW);
line(x0,y0,x,y);
 
}
 
 
 
getch();
closegraph();
}
Добавлено через 3 часа 3 минуты
удивительно, но это как то работает))причем я не понимаю почему)

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
#include<iostream.h>
#include<conio.h>
#include<graphics.h>
#include<dos.h>
#include<stdlib.h>
#include<math.h>
const pi=22/7;
int x0,y0,x,y,l=300,dlinapodvesa=50,A=50,w=10,radius=10;
float u=-(pi)/3,t=0;
void main()
{
// cout<<"vvedite dlinu mayatnika i amplitudu i skorost' ";
// cin>>l>>A>>w;
int gdriver = DETECT, gmode, errorcode;
initgraph(&gdriver,&gmode,"");
errorcode = graphresult();
if(errorcode !=grOk)
  {
   cout<<"Graphicheskaia oshibka:%\n"<<grapherrormsg(errorcode);
   cout<<"Nagmite klavishy";
   getch();
   exit(1);
  }
 
setcolor(YELLOW);
line(getmaxx()/2-dlinapodvesa,getmaxy()/3,getmaxx()/2+dlinapodvesa,getmaxy()/3);
x0=getmaxx()/2; y0=getmaxy()/3;  x=getmaxx()/2; y=y0;
while(!kbhit())
{
cleardevice();
line(getmaxx()/2-dlinapodvesa,getmaxy()/3,getmaxx()/2+dlinapodvesa,getmaxy()/3);
setcolor(YELLOW);
line(x0,y0,x,y-radius);
circle(x,y,radius);
delay(50);
 
x=x0+A*cos(w*t);
y=y0+sqrt(l*l-(x-x0)*(x-x0));
t+=0.01;
}
 
getch();
closegraph();
}
0
74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
11.05.2012, 19:45
Цитата Сообщение от djvipmax Посмотреть сообщение
Добавлено через 3 часа 3 минуты
удивительно, но это как то работает))причем я не понимаю почему)

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
#include<iostream.h>
#include<conio.h>
#include<graphics.h>
#include<dos.h>
#include<stdlib.h>
#include<math.h>
const pi=22/7;
int x0,y0,x,y,l=300,dlinapodvesa=50,A=50,w=10,radius=10;
float u=-(pi)/3,t=0;
void main()
{
// cout<<"vvedite dlinu mayatnika i amplitudu i skorost' ";
// cin>>l>>A>>w;
int gdriver = DETECT, gmode, errorcode;
initgraph(&gdriver,&gmode,"");
errorcode = graphresult();
if(errorcode !=grOk)
  {
   cout<<"Graphicheskaia oshibka:%\n"<<grapherrormsg(errorcode);
   cout<<"Nagmite klavishy";
   getch();
   exit(1);
  }
 
setcolor(YELLOW);
line(getmaxx()/2-dlinapodvesa,getmaxy()/3,getmaxx()/2+dlinapodvesa,getmaxy()/3);
x0=getmaxx()/2; y0=getmaxy()/3;  x=getmaxx()/2; y=y0;
while(!kbhit())
{
cleardevice();
line(getmaxx()/2-dlinapodvesa,getmaxy()/3,getmaxx()/2+dlinapodvesa,getmaxy()/3);
setcolor(YELLOW);
line(x0,y0,x,y-radius);
circle(x,y,radius);
delay(50);
 
x=x0+A*cos(w*t);
y=y0+sqrt(l*l-(x-x0)*(x-x0));
t+=0.01;
}
 
getch();
closegraph();
}
Почему?
Если ты по поводу строки 38, то всё нормально)
0
0 / 0 / 0
Регистрация: 07.05.2012
Сообщений: 14
16.05.2012, 17:21  [ТС]
хех, показал преподу, говорит сделай чтоб не мерцало, через сетвижуалпэйдж... и говорит что разрешение экрана не квадратное и типо длина линии меняется... как это учесть?
через страницы я уже сделал, а вот растяжении линии не знаю...
0
0 / 0 / 0
Регистрация: 07.05.2012
Сообщений: 14
26.05.2012, 23:41  [ТС]
может кому нибудь понадобится

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
#include<iostream.h>
#include<conio.h>
#include<graphics.h>
#include<dos.h>
#include<stdlib.h>
#include<math.h>
#include<stdio.h>
 
 
void main()
{
const pi=355/113, e=2721/1001;
float x0, y0, x, y, dlinapodvesa=100, A=150, w=300, radius=15, a;
float u=-7, t=0, l=300;
int gdriver = EGA, gmode = EGAHI, errorcode;
initgraph(&gdriver, &gmode, "");
errorcode = graphresult();
if (errorcode != grOk)
{
  printf("Graphics error: %s\n", grapherrormsg(errorcode));
  printf("Press any key to halt:");
  getch();
  exit(1);
}
cleardevice();
setbkcolor(134);
setcolor(YELLOW);
setactivepage(1);
line(getmaxx()/2-dlinapodvesa,1,getmaxx()/2+dlinapodvesa,1);
x0=getmaxx()/2;
y0=2;  
x=x0+l*sin(u); 
y=y0+sqrt(l*l-(x-x0)*(x-x0));  
A=(l*sin(u))/cos(w*t);
while(!kbhit())
{
setvisualpage(0);
setactivepage(1);
cleardevice();
setcolor(YELLOW);
line(x0,y0,x,y);
line(getmaxx()/2-dlinapodvesa,1,getmaxx()/2+dlinapodvesa,1);
setfillstyle(5,BLACK);
fillellipse(x-1,y-1,radius,radius*(getmaxx()/getmaxy()));
setvisualpage(1);
delay(10);
setactivepage(0); cleardevice();
 
x=x0+A*pow(e,-2.1*t)*cos(w*t);
y=(y0+sqrt(l*l-(x-x0)*(x-x0)));
t+=0.0001;
 
setcolor(YELLOW);
line(x0,y0,x,y);
line(getmaxx()/2-dlinapodvesa,1,getmaxx()/2+dlinapodvesa,1);
setfillstyle(1,BLACK);
fillellipse(x-1,y-1,radius,radius*(getmaxx()/getmaxy()));
}
getch();
closegraph();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.05.2012, 23:41
Помогаю со студенческими работами здесь

Движение маятника с затухающими колебаниями
Помогите сделать лабораторную! Как реализовать колебания нити маятника с затуханием движения #define WIN32_LEAN_AND_MEAN #include...

Как показать движение маятника?
как в пикчер боксе или в другом элементе показать движение маятника??? тоесть после запкска программы будет показан &quot;висячий&quot;...

Движение математического маятника в отклонении
Написать анимационную программу 1)движение колокольчика 2)движение математического маятника в отклонении Добавлено через 1 час 25...

Моделирование маятника: измерить время движения маятника с начала его движения до полной остановки
Подскажите пожалуйста какую формулу в данном коде добавить чтоб измерялось время движения маятника с начала его движения до его полной...

Подскажите где можно найти Borland C++ Builder или Borland Developer Studio 2006 C++ ? Очень надо.
Подскажите где можно найти Borland C++ Builder или Borland Developer Studio 2006 C++ ? Очень надо.


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru