20.05.2015, 14:20 | #11 (permalink) | |
Специалист
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
|
Цитата:
P.S. Какие-то странные у Вас значения K и ħ. Это в каких единицах? |
|
20.05.2015, 14:20 | |
Helpmaster
Member
Регистрация: 08.03.2016
Сообщений: 0
|
Разумеется, на нашем форуме так же нашлись и похожие темы Помогите найти интеграл и задачу коши операционным методом Виснет комп при запуске чего либо Подвержены ли вы каким-либо фобиям? Как задать число pi, e , определенный интеграл? |
20.05.2015, 14:38 | #12 (permalink) |
Member
Регистрация: 18.05.2015
Сообщений: 29
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
|
Шкалу частот я принял равномерно увеличивающейся с шагом 0.033E12.
Постоянную Больцмана брал в эВ*К^-1 Планка эВ*с Подбирал размерности таким образом, чтобы гиперболический синус был безразмерным. |
20.05.2015, 15:02 | #13 (permalink) | |
Специалист
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
|
Цитата:
Написал я программку и прокрутил. Вот: Код:
Const h=6.582119E-16; K=8.6173324E-5; N=239; Var t:text; w,g:Array [1..239] of real; i,Tem:integer; Function Sh(r:real):real; begin Sh:=(Exp(r)-Exp(-r))/2; end; Function F(v,T:real):real; begin F:=K*Sqr(h*v/(K*T*2))/Sqr(Sh(h*v/(K*T*2))); end; Function Cv(T:real):Real; var Sum:Real; j:Integer; begin Sum:=0; for j:=1 to N-1 do Sum:=Sum+F((w[j+1]+w[j])/2,T)*(g[j+1]+g[j])/2*(w[j+1]-w[j]); Cv:=Sum; end; begin Assign(t,'D:\g.txt'); Reset(t); Readln(t); for i:=1 to N do readln(t,w[i],g[i]); Close(t); Assign(t,'D:\res.txt'); Rewrite(t); for Tem:=1 to 10 do Writeln(t,Tem:3,' ',Cv(1.0*Tem)); Close(t) End. Вывод: что-то напортачено с единицами в константах. Сейчас попробую разобраться. |
|
20.05.2015, 15:15 | #14 (permalink) |
Специалист
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
|
А, нет, прошу прощения - отбой! Константы поставлены правильно, проверил. Это просто я чудак на букву "м" - забыл домножить частоту на 10^12. Если это сделать, получается вполне разумно. Вот исправленный текст:
Код:
Const h=6.582119E-16; K=8.6173324E-5; N=239; Var t:text; w,g:Array [1..239] of real; i,Tem:integer; Function Sh(r:real):real; begin Sh:=(Exp(r)-Exp(-r))/2; end; Function F(v,T:real):real; begin F:=K*Sqr(h*v/(K*T*2))/Sqr(Sh(h*v/(K*T*2))); end; Function Cv(T:real):Real; var Sum:Real; j:Integer; begin Sum:=0; for j:=1 to N-1 do Sum:=Sum+F((w[j+1]+w[j])/2,T)*(g[j+1]+g[j])/2*(w[j+1]-w[j]); Cv:=Sum; end; begin Assign(t,'D:\g.txt'); Reset(t); Readln(t); for i:=1 to N do begin readln(t,w[i],g[i]); w[i]:=w[i]*1E12; end; Close(t); Assign(t,'D:\res.txt'); Rewrite(t); for Tem:=1 to 10 do Writeln(t,Tem:3,' ',Cv(1.0*Tem)); Close(t) End. |
20.05.2015, 16:18 | #15 (permalink) |
Member
Регистрация: 18.05.2015
Сообщений: 29
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
|
Спасибо, Владимир. Сейчас буду списывать вашу программу и проверять) Интересно, что я попробовал на пальцах проверить свою программу (только интеграл взял полегче, чтоб вручную подсчитать), и вроде бы все работает. А с изначальным интегралом брехня получается=)
|
Ads | |
Member
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
|
20.05.2015, 16:47 | #17 (permalink) |
Специалист
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
|
Нет. В Паскале (да и, по-моему, в любом ЯП) умножение и деление имеют равный приоритет, и цепочка вида a*b/c/d*e означает: a умножается на b, результат делится на c, результат делится на d, результат умножается на e.
|
20.05.2015, 16:51 | #18 (permalink) |
Специалист
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
|
Для пущей наглядности: программа
Код:
Begin Writeln(2*3/2*3); Readln End. |
21.05.2015, 14:49 | #20 (permalink) |
Member
Регистрация: 18.05.2015
Сообщений: 29
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
|
|
Ads | |
Member
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
|
|
|