Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Вопросы программирования на FORTRAN (ФОРТРАН)

Модерирует : ShIvADeSt

 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 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 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330

Открыть новую тему     Написать ответ в эту тему

akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Обсуждаются все вопросы, связанные с программированием на ФОРТРАН, как общего так и конкретного характера.
Постарайтесь дать как можно больше информации о возникшей проблеме -- это в конце концов в ваших же интересах чтобы вам помогли...

прежде чем просить помощи в задании
платное решение задач

ресурсы этого топика
ссылка на подборку ресурсов, собранных посетителями этого форума
 
то, чем мы решили поделиться
ссылка на страничку программ etc собственного изготовления, которыми любезно делятся наши форумчане


если вам вдруг не отвечают или ответ вас не устраивает
и вообще полезно прочитать всем спрашивающим
 
просьба к пишущим и отвечающим все большие листинги оформлять тегом more
и отключать графические смайлики при размещении фортран-кода

Всего записей: 24112 | Зарегистр. 06-12-2002 | Отправлено: 18:11 14-01-2007 | Исправлено: akaGM, 09:47 01-03-2020
Andrew10

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
akaGM

Цитата:
для аккуратного фурье у меня FFTpack
 

Тогда тем более непонятно, зачем самому огород городить?

Всего записей: 780 | Зарегистр. 26-02-2005 | Отправлено: 19:42 06-03-2012
XPEHOMETP

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andrew10
В том-то самый смак, чтобы понимать, как эта штука работает! А с пониманием по поводу FFTW - проблематично. Как и с пониманием любых программ, написанных по методу псевдо-динамического распределения памяти. Когда объявляют некий рабочий массив, в качестве такой братской могилы, и успешно валят туда и вещественные данные, и целочисленные. Да там вообще волосы дыбом встанут, если в этом FFTW попытаться хоть чуток разобраться.
 
По поводу программы по разложению Фурье. Выкладывал на одном из форумов. Это несколько доработанный вариант по сравнению с тем, по которому я реально работал. Но я его не компилировал. Просто отказался потом от этого в пользу вариантов, найденых в сети.

Код:
      subroutine foft(dat,nft,ftcoef,free,start)
c---------------------------------------
c    dat - входной массив данных удвоенной точности
c    nft - число точек в массиве dat
c    ftcoef - массив коэффициентов разложения Фурье размерности (nft/2 * 2) - на выход
c       Один столбец у него для косинусов, другой для синусов
c       Тут для простоты примем, что nft - четное число, тогда длина ftcoef будет ровно nft/2
c    free - свободный член разложения Фурье (умные дяди программеры стандартно запихивают его  
c       в выходной массив, но мы так делать не будем, чтобы все было как в формуле) - на выход
c
      implicit none
      integer nft,j,n,m,pos
      real*8 datt(nft),trig(nft,2),ftcoef(nft/2,2),free,x,twopi
      parameter (twopi = 6.28318530717959)
 
 
c     cчитаем свободный член как среднее арифметическое:
c----------------------------------------------------------
           x = 0.0
         do 5 j = 1, nft
  5      x = x + dat(j)
           free = x/nft
 
c   Инициируем trig(nft,2) - рабочий массив косинусов-синусов:
c----------------------------------------------------------
 
          trig(1,1) = 1.0d
          trig(1,2) = 0.0d
      do 10 j = 2,nft
          trig(j,1) = cos(twopi*(j-1)/nft)
 10       trig(j,2) = sin(twopi*(j-1)/nft)
 
 
      do 30 m = 1,2
      do 30 j = 1, nft/2-1
          x = 0.0
          do 20 n = 1, nft
          pos = mod((n-1)*j,nft)+1
 20       x = x + trig(pos,m)*dat(n)
      ftcoef(j,m) = 2*x/nft
 30   continue
 
      ftcoef(nft/2,2) = 0.0d
          x = 0.0d
      do 40 n = 1, nft
        pos = mod((n-1)*nft/2,nft)+1
 40   x = x + trig(pos,1)*dat(n)
          ftcoef(nft/2,1) = 2*x/nft
 
c   Boт поскольку коэффициент ftcoef(nft/2,2) всегда и везде будет 0, ушлые программеры на
c   его место запихивают свободный член разложения. Но мы так не сделаем.
 
      return
      end
 

Всего записей: 2485 | Зарегистр. 21-06-2005 | Отправлено: 19:44 06-03-2012
Andrew10

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
XPEHOMETP

Цитата:
В том-то самый смак, чтобы понимать, как эта штука работает! А с пониманием по поводу FFTW - проблематично.

 
А если разбираться, то стоит разбираться на лучших алгоритмах, а именно, на примере алгоритма быстрого преобразования Фурье Кули-Тьюки,  алгоритмов для числа отсчетов, равных простым числам, алгоритма Винограда. Есть наверняка и более современные. Я с этим возился лет 20 назад, молодой был, горячий .
Если нужно один раз посчитать Фурье от короткой последовательности, то, конечно, проще напрямую. Но если ДПФ является существенной частью мат. алгоритма, как, например, при решении краевых задач для эллиптических уравнений, то нужно стремиться к наиболее эффективному алгоритму.
 
ИМХО, конечно.
 

Всего записей: 780 | Зарегистр. 26-02-2005 | Отправлено: 20:12 06-03-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
XPEHOMETP

Цитата:
Просто отказался потом от этого в пользу вариантов, найденых в сети.
и чему же было отдано предпочтение?
 
start
а это для чего?

Всего записей: 24112 | Зарегистр. 06-12-2002 | Отправлено: 20:34 06-03-2012 | Исправлено: akaGM, 21:19 06-03-2012
XPEHOMETP

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
akaGM

Цитата:
start  
а это для чего?

Подозреваю, что указатель: прямое или обратное преобразование. Я говорю, что была рабочая программа, но малость дубовая. Из нее сделал упрощенный вариант, для примера на форуме. Сейчас сложно сказать, надо исходники искать.
 
Да я говорил тут уже. Поставил на fftpack, точнее, на ezfft (прямую и обратную).

Всего записей: 2485 | Зарегистр. 21-06-2005 | Отправлено: 21:45 06-03-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
XPEHOMETP
да, FFTpack...
 
 
не вижу никакого преимущества в расчёте предварительной тригонометрии по сравнению с "по требованию"...
 
если нужна кому-то твоя п/п то вот она поправленная (в смысле компилится):
Подробнее...
 
один вопрос по ней:
 
а если число точек нечётное, то что изменится?

Всего записей: 24112 | Зарегистр. 06-12-2002 | Отправлено: 23:34 06-03-2012 | Исправлено: akaGM, 23:47 06-03-2012
XPEHOMETP

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Не знаю, никогда не пробовал!

Всего записей: 2485 | Зарегистр. 21-06-2005 | Отправлено: 11:56 07-03-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
XPEHOMETP
ezfft()
являлась простой обёрткой к rfft1() и исчезла в версиях 5.х
 
не помнишь случайно откуда у меня могут быть 90- и double- версии fftpack'a ?
:)

Всего записей: 24112 | Зарегистр. 06-12-2002 | Отправлено: 12:45 07-03-2012
terminat0r



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
akaGM
http://people.sc.fsu.edu/~jburkardt/f_src/fftpack5.1d/fftpack5.1d.html

Всего записей: 2084 | Зарегистр. 31-03-2002 | Отправлено: 13:50 07-03-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
terminat0r
действительно отсюда, спасибо за напоминание...
 
а то у меня старая ссылка была:
http://orion.math.iastate.edu/burkardt/

Всего записей: 24112 | Зарегистр. 06-12-2002 | Отправлено: 15:10 07-03-2012 | Исправлено: akaGM, 16:48 07-03-2012
Vskazka

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
akaGM
Вопрос, мб и не очень важный - какое там ядро. 11 есть или даже больше?

Всего записей: 382 | Зарегистр. 24-11-2003 | Отправлено: 05:07 08-03-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Vskazka
это ты о чём :)

Всего записей: 24112 | Зарегистр. 06-12-2002 | Отправлено: 14:08 08-03-2012
XPEHOMETP

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Скачал сегодня очередную версию (6.20) FTN95. Теперь с ним идет Simdem - демонстрационный пакет для показа возможностей Simfit. Возможности огроменные, я посмотрел и прямо офигел. Simfit имеет статус OpenSource, в смысле, все дают с исходниками и задарма. Неприятный момент: все GUI и рисование завязано на Clearwin+ от FTN95. Поскольку Clearwin+ - та еще фигня, граждане предложили обертку из своих функций, более удобных в использовании, и вызываемых из Фортрана. Обертка закатана в DLL (их несколько, но для разных целей); соответственно, программа вызывает функции одной из этих DLL, та вызывает функции Clearwin+ из DLL от FTN95, они уже выходят на функции WinAPI в своих DLL, причем там, фактически, интерпретация в ран-тайм... Не очень хороший такой конвейер получается...  
 
Понятно, обладатели FTN95 имеют меньше всех хлопот. Авторы компилируют также бинарники под NAG, с остальными компиляторами желающие пользоваться этой штукой должны проделать сей процесс самостоятельно. Исходники даются, как я уже сказал.
 
Вот сижу сейчас и штудирую...  

Всего записей: 2485 | Зарегистр. 21-06-2005 | Отправлено: 16:28 10-03-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
нда...
 
XPEHOMETP
соберёшь первый "hello world", кинь шаблон, плиз...

Всего записей: 24112 | Зарегистр. 06-12-2002 | Отправлено: 18:34 10-03-2012
XPEHOMETP

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
А... Там в комплекте Simdem идет несколько программок в качестве примеров использования этой библиотеки. То есть Simfit - это как бы программа для студентов, для обработки данных, а Simdem - это демо для программеров с показом возможности библиотеки. Они, как я понял, функционал программы перекинули на объяснение фишек программирования с этой штукой. Можно просматривать исходный код файлов примеров (и не только их), читать мануал и т.п.

Всего записей: 2485 | Зарегистр. 21-06-2005 | Отправлено: 19:40 10-03-2012
terminat0r



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
XPEHOMETP

Installing and running the Simfit package in Linux, Step 1 - WINE installation
нет, нам такой не нужен

Всего записей: 2084 | Зарегистр. 31-03-2002 | Отправлено: 20:37 10-03-2012
XPEHOMETP

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Ну так там все завязано на FTN95, который для Винды. Отсюда и следствия.

Всего записей: 2485 | Зарегистр. 21-06-2005 | Отправлено: 22:27 10-03-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
добавил в шапку...

Всего записей: 24112 | Зарегистр. 06-12-2002 | Отправлено: 03:20 11-03-2012
TeXpert



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
   Господа, требуется совет
 
    Есть работающая программа на FORTRAN'е. Программа считывает некоторые параметры и массив данных из текстового файла. Описания этих параметров и массивов вынесены в отдельный модуль, который, естественно подключается (в основной программе и подпрограммах и функциях)
 
    Теперь требуется следующее: я решил расчетную часть загнать в lib-файл (все еще на FORTRAN'е) и подключить эту библиотеку к основной программе, которая теперь уже будет написана на C++, с визуальным интерфейсом. Теперь матрица и параметры будут передаваться из основной программы на C++ в подпрограммы, которые вызываются из библиотеки. В связи с чем и вопрос: как лучше организовать такую передачу (параметров и матриц)? То есть, как организовать разделение глобальных данных? Не хотелось бы передавать их в качестве параметров вызываемых процедур
 
    Заранее благодарен

----------
Майкудук, Пришахтинск не предлагать!:)
А на Пирогова приходит снова весенний гомон...

Всего записей: 3604 | Зарегистр. 08-02-2003 | Отправлено: 04:26 12-03-2012
XPEHOMETP

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
С матрицами не все так хорошо, они по-разному кодируются в Си и в Фортране. Начиная с того, что нумерация столбцов и строк меняется местами (это вполне решаемо!), там еще с самими массивами проблемы: по-разному задаются. Вариант, который на 100% прокатит, при межъязыковом программировании: запихнуть массив (и все нужные переменные) в структуру (пользовательский тип), они между Фортраном и другими языками передаются без малейших проблем. Но тут возникает нехороший момент: в структурах массивы должны быть фиксированного размера. Но, наверняка в неких частных случаях можно передать массив из Фортрана в С++ (или наоборот) без особых проблем, если не считать обращение нумерации строк-столбцов. Это надо спрашивать по каждому конкретному компилятору, что он позволяет реально. Наверняка некий конкретный производитель что-то сделал, чтобы облегчить задачу обмена массивами между Фортраном и С++-компиляторами его производства.  
 
Конечно, как бы есть некие вещи вроде C-binding, и даже прописанные в новейших стандартах. Но не все производители успели это все воплотить в жизнь.

Всего записей: 2485 | Зарегистр. 21-06-2005 | Отправлено: 13:07 12-03-2012
Открыть новую тему     Написать ответ в эту тему

Страницы: 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 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Вопросы программирования на FORTRAN (ФОРТРАН)


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru