1 / 1 / 1
Регистрация: 01.04.2019
Сообщений: 10

Перевести с PascalABC.net на JS

27.12.2019, 10:53. Показов 887. Ответов 3

Студворк — интернет-сервис помощи студентам
Помогите перевести на JS c PascalABC.Net. Пробывал сам перевести, считает не так как на Pascal
Запись в файл не нужно. считаю при входных данных: N = 50; t_end = 180; L = 0.3; lamda = 384; ro = 8800; c = 381; kapa1 = 1000; kapa2 = 500; Te1 = -30; Te2= 10; T0 = 50
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
99
100
101
102
103
104
105
106
107
108
uses crt;
const mf=500;
type
vector=array[1..mf] of real;
var {раздел описания переменных, которые мы будем использовать в
программе}
i, j, N : integer;
T, alfa, beta : vector;
ai, bi, ci, fi : real;
a, lamda, ro, c, h, tau : real;
kapa1, kapa2, Te1, Te2 : real;
T0, L, t_end, time : real;
f, g : text;
begin
clrscr;
{с клавиатуры вводим все необходимые входные параметры}
Writeln('Введите количество пространственных узлов, N');
Readln(N);
Writeln('Введите окончание по времени, t_end');
Readln(t_end);
Writeln('Введите толщину пластины, L');
Readln(L);
Writeln('Введите коэффициент теплопроводности материала пластины,lamda');
Readln(lamda);
Writeln('Введите плотность материала пластины, ro');
Readln(ro);
Writeln('Введите теплоемкость материала пластины, c');
Readln(c);
Writeln('Введите коэффициент теплообмена на границе х = 0, kapa1');
Readln(kapa1);
Writeln('Введите коэффициент теплообмена на границе х = L, kapa2');
Readln(kapa2);
Writeln('Введите температуру внешней среды относительно границы х= 0, Te1');
Readln(Te1);
Writeln('Введите температуру внешней среды относительно границы х= L, Te2');
Readln(Te2);
Writeln('Введите начальную температуру, T0');
Readln(T0);
{определяем расчетный шаг сетки по пространственной координате}
h:=L/(N-1);
{определяем коэффициент температуропроводности}
a:=lamda/(ro*c);
{определяем расчетный шаг сетки по времени}
tau:=t_end/100.0;
{определяем поле температуры в начальный момент времени}
for i:= 1 to N do
T[i]:=T0;
 
Writeln('beta = ', (lamda*sqr(h)*T[1]+2.0*a*tau*kapa1*h*Te1)
/(2.0*a*tau*(lamda+kapa1*h)+lamda*sqr(h)));
{проводим интегрирование нестационарного уравнения
теплопроводности}
time:=0;
while time<t_end do {используем цикл с предусловием}
begin
{увеличиваем переменную времени на шаг τ}
time:=time+tau;
{определяем начальные прогоночные коэффициенты на основе левого
граничного условия, используя соотношения (24)}
alfa[1]:=2.0*a*tau*lamda/(2.0*a*tau*(lamda+kapa1*h)+lamda*sqr(h));
beta[1]:=(lamda*sqr(h)*T[1]+2.0*a*tau*kapa1*h*Te1)
/(2.0*a*tau*(lamda+kapa1*h)+lamda*sqr(h));
{цикл с параметром для определения прогоночных коэффициентов по
формуле (8)}
for i:= 2 to N-1 do
begin
{ai, bi, ci, fi – коэффициенты канонического представления СЛАУ с
трехдиагональной матрицей}
ai:=lamda/sqr(h);
bi:=2.0*lamda/sqr(h)+ro*c/tau;
ci:=lamda/sqr(h);
fi:=-ro*c*T[i]/tau;
{alfa[i], beta[i] – прогоночные коэффициенты}
alfa[i]:=ai/(bi-ci*alfa[i-1]);
beta[i]:=(ci*beta[i-1]-fi)/(bi-ci*alfa[i-1]);
end;
{определяем значение температуры на правой границе, используя
соотношение (25)}
T[N]:=(lamda*sqr(h)*T[N]+2.0*a*tau*(lamda*beta[N-1]+kapa2*h*Te2))
/(lamda*sqr(h)+2.0*a*tau*(lamda*(1-alfa[N-1])+kapa2*h));
{используя соотношение (7) определяем неизвестное поле
температуры}
for i:= N-1 downto 1 do
T[i]:=alfa[i]*T[i+1]+beta[i];
end; {цикл с предусловием окончен}
{выводим результат в файл}
Assign(f,'res.txt');
Rewrite(f);
Writeln(f,'Толщина пластины L = ',L:6:4);
Writeln(f,'Число узлов по координате N = ',N);
Writeln(f,'Коэффициент теплопроводности материала пластины lamda =',lamda:6:4);
Writeln(f,'Плотность материала пластины ro = ',ro:6:4);
Writeln(f,'Теплоемкость материала пластины с = ',c:6:4);
Writeln(f,'Начальная температура T0 = ',T0:6:4);
Writeln(f,'Коэффициент теплообмена kapa1 = ',kapa1:6:4);
Writeln(f,'Коэффициент теплообмена kapa2 = ',kapa2:6:4);
Writeln(f,'Температура внешней среды Te1 = ',Te1:6:4);
Writeln(f,'Температура внешней среды Te2 = ',Te2:6:4);
Writeln(f,'Результат получен с шагом по координате h = ',h:6:4);
Writeln(f,'Результат получен с шагом по времени tau = ',tau:6:4);
Writeln(f,'Температурное поле в момент времени t = ',t_end:6:4);
close(f);
Assign(g,'tempr.txt');
Rewrite(g);
for i:=1 to N do
writeln(g,' ',h*(i-1):10:8,' ',T[i]:8:5);
close(g);
end.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.12.2019, 10:53
Ответы с готовыми решениями:

Перевести С на PascalABC.NET
Ребят Я пытался ... (честно !) Но есть много ошибок . В основном у меня проблемы с функциями, не могу перевести. Такие как...

Перевести код с Си на PascalABC.NET
У меня такая проблема, есть программа на си а еще нужно написать на паскале (Паскаль АБЦ.нет), и никак не могу так как Паскаль я не очень...

Перевести с Powershell на PascalABC.NET
Всем привет! Помогите, пожалуйста, перевести код с Powershell на PascalABC.NET. Сам код: function Get-AccessCode ($url) { $ie...

3
 Аватар для Sun Serega
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
27.12.2019, 12:28
Дайте тот JS код.

Добавлено через 2 минуты
Ну и нормальное условие задачи. Одного кода может быть мало.
0
1 / 1 / 1
Регистрация: 01.04.2019
Сообщений: 10
27.12.2019, 13:31  [ТС]
Мой код на JS
JavaScript
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
    let N = 50;
    let i,j;
    
    let T = [], alfa = [], beta = [];
    let ai, bi, ci, fi;
    let a, lamda, ro, c, h, tau;
    let kapa1, kapa2, Te1, Te2;
    let T0, L, t_end, time;
 
    t_end = 180.0000;
    L = 0.3000;
    lamda = 384.000;
    ro = 8800.000;
    c = 381.000;
    kapa1 = 1000.000;
    kapa2 = 500.000;
    Te1 = -30.000;
    Te2 = 10.00;
    T0 = 50.000;
    
    h = L / (N - 1);
    a = lamda / (ro * c);
    tau = t_end / 100.0;
 
    for(i = 0; i < N; i++) {
        T[i] = T0;
    }
    console.log(T);
    let Bi = (kapa1 * h) / lamda;
    time = 0.0;
    
    while(time < t_end) {
        time = time + tau;
 
        alfa[0] = (2 * a * tau * lamda) / (2 * a * tau * (lamda + kapa1*h) + lamda * Math.pow(h,2));
        beta[0] = (lamda * Math.pow(h,2) * T[0] + 2 * a * tau * kapa1 * h * Te1) /
                   (2 * a * tau * (lamda + kapa1 * h) + lamda * Math.pow(h,2)); 
        
        for (i = 1; i < N - 1; i++) {
            ai = lamda / h ** 2;
            bi = 2 * lamda / h ** 2 + ro * c / tau;
            ci = lamda / h ** 2;
            fi = - ro * c * T[i] / tau;
 
            alfa[i] = ai / (bi - ci * alfa[i -1]);
            beta[i] = (ci * beta[i - 1] - fi) / (bi - ci * alfa[i-1]);
        }
 
        T[N] = (lamda * h ** 2 * T[N] + 2 * a * tau * (lamda * beta[N-1] + kapa2*h*Te2))/
                (lamda * h ** 2 + 2 * a * tau * (lamda * (1 - alfa[N-1] + kapa2 * h)));
    
        for(i = N - 1; i > 0; i--) {
            T[i] = alfa[i] * T[i] + beta[i];
        }
    }
Полное условие задачи следующие:
Определить температурное поле в медной пластине через 30, 180 и
600 секунд. Толщина пластины
T0 = 500С . На границе ( x = 0 и) x = L пластина контактирует с внешней средой (κ =1000 Вт м21
T e1 = 10 0C ).
0
1 / 1 / 1
Регистрация: 01.04.2019
Сообщений: 10
27.12.2019, 14:01  [ТС]
Полное условие задачи:
Определить температурное поле в медной пластине через 30, 180 и
600 секунд. Толщина пластины L = 0.3м . Начальная температура
T0 = 50 С . На границе ( x = 0 и) x = L пластина контактирует с внешней средой (κ =1000 Вт м21
⋅0 С , T e1 = −30 0C и κ2 = 500 Вт (м2 ⋅0 С), T e1 = 10 0C ). (пластина медная: ламда = 384, ро = 8800, с = 381)

Мой код на JS
JavaScript
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
    let N = 50;
    let i,j;
    
    let T = [], alfa = [], beta = [];
    let ai, bi, ci, fi;
    let a, lamda, ro, c, h, tau;
    let kapa1, kapa2, Te1, Te2;
    let T0, L, t_end, time;
 
    t_end = 180.0000;
    L = 0.3000;
    lamda = 384.000;
    ro = 8800.000;
    c = 381.000;
    kapa1 = 1000.000;
    kapa2 = 500.000;
    Te1 = -30.000;
    Te2 = 10.00;
    T0 = 50.000;
    
    h = L / (N - 1);
    a = lamda / (ro * c);
    tau = t_end / 100.0;
 
    for(i = 0; i < N; i++) {
        T[i] = T0;
    }
    console.log(T);
    let Bi = (kapa1 * h) / lamda;
    time = 0.0;
    
    while(time < t_end) {
        time = time + tau;
 
        alfa[0] = (2 * a * tau * lamda) / (2 * a * tau * (lamda + kapa1*h) + lamda * Math.pow(h,2));
        beta[0] = (lamda * Math.pow(h,2) * T[0] + 2 * a * tau * kapa1 * h * Te1) /
                   (2 * a * tau * (lamda + kapa1 * h) + lamda * Math.pow(h,2)); 
        
        for (i = 1; i < N - 1; i++) {
            ai = lamda / h ** 2;
            bi = 2 * lamda / h ** 2 + ro * c / tau;
            ci = lamda / h ** 2;
            fi = - ro * c * T[i] / tau;
 
            alfa[i] = ai / (bi - ci * alfa[i -1]);
            beta[i] = (ci * beta[i - 1] - fi) / (bi - ci * alfa[i-1]);
        }
 
        T[N] = (lamda * h ** 2 * T[N] + 2 * a * tau * (lamda * beta[N-1] + kapa2*h*Te2))/
                (lamda * h ** 2 + 2 * a * tau * (lamda * (1 - alfa[N-1] + kapa2 * h)));
    
        for(i = N - 1; i > 0; i--) {
            T[i] = alfa[i] * T[i] + beta[i];
        }
    }
Миниатюры
Перевести с PascalABC.net на JS  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.12.2019, 14:01
Помогаю со студенческими работами здесь

Перевести с Delphi на PascalABC.net
Помогите перевести этот маленький фрагмент кода if i&lt;n then for j:= i+1 to Balls.Count-1 do ...

Построение графиков функций (перевести в PascalABC.NET)
программа была набрана в турбо паскале, помогите перевести его в PascalABC.NET program chukreev; uses graph,crt; var y:array of...

В чем разница PascalABC.net и PascalABC
Скажите в чем разница PascalABC.net И PascalABC. Помню когда-то давно программы работающие в PascalABC у меня не работали в .net

Установится ли PascalABC.NET на систему, где установлен только .NET 4.6.1?
Привет всем. Вопрос, собственно, озвучен выше. Конкретнее: есть компьютер со свежеустановленной Win10 x64, на которой присутствует...

Перевести код с PascalABC.NET
Помогите перевести код в Паскаль. var str1: array of string; str2: array of string := (',', ' ', '.', #13); chr1: char;...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
PowerShell и онлайн сервисы. Валюта (floatrates.com руб.)
iNNOKENTIY21 11.11.2025
PowerShell функция floatrates-rub Примеры вызова: # Указанная валюта 'EUR' floatrates-rub -Code 'EUR' # Список имеющихся кодов валют floatrates-rub -Available function floatrates-rub {
PowerShell и онлайн сервисы. Погода (RP5.ru)
iNNOKENTIY21 11.11.2025
PowerShell функция Get-WeatherRP5rss для получения погоды с сервиса RP5 Примеры вызова Get-WeatherRP5rss с указанием id 5484 — Москва (восток, Измайлово) и переносом строки:. . .
PowerShell и онлайн сервисы. Погода (wttr)
iNNOKENTIY21 11.11.2025
PowerShell Функция для получения погоды с сервиса wttr Примеры вызова: Погода в городе Омск с прогнозом на день, можно изменить прогноз на более дней, для этого надо поменять запрос:. . .
PowerShell и онлайн сервисы. Валюта (ЦБР)
iNNOKENTIY21 11.11.2025
# Получение курса валют function cbr (] $Valutes = @('USD', 'EUR', 'CNY')) { $url = 'https:/ / www. cbr-xml-daily. ru/ daily_json. js' $data = Invoke-RestMethod -Uri $url $esc = 27 . . .
И решил я переделать этот ноут в машину для распределенных вычислений
Programma_Boinc 09.11.2025
И решил я переделать этот ноут в машину для распределенных вычислений Всем привет. А вот мой компьютер, переделанный из ноутбука. Был у меня ноут асус 2011 года. Со временем корпус превратился. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru