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

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в 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

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

akaGM

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

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

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


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

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

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

Цитата:
[/q]
[q]Intel Fortran поддерживает числа точностью real(16).

Это я знаю, но ее реализация в Intel Fortran является чрезвычайно медленной: в Intel С++ эта возможность реализована, но долбаным заказчикам фортран нужен.
 
terminat0r
 
Выяснил: если subroutine в другом файле, то inline не работает.

Всего записей: 403 | Зарегистр. 19-11-2008 | Отправлено: 09:39 12-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Уважаемый terminat0r,
правильно ли я понял, что добавить интерфейс надо в module NEWmodel до implicit none
 
При таком оно компилируется и работает, просто меня немного напрягает использование use NEWmodel внутри определения этого самого модуля, да ещё и до определения констант. Второе, что смущает: подпрограмма же определена уже после модуля (end module). Это правильно, что определение интерфейса вне модуля (допустим, в начале файли или перед определением подпрограммы) вызывает ошибку (unnamed element does not have the end statement)?
 
Добавлено.
Опс. Невнимательно прочел "добавьте в функции, на которые он ругается". Я думал, что добавить в эту самую HWMupdate. Задним числом понял, что надо-то в те функции, в которых HWMupdate вызывается... Тогда вопрос: а насколько "законно" это сделать через модуль... т.е. я добавил это интерфейс в модуль NEWmodel, а сам это модуль подключается через use  в тех функциях (от того вроде теперь и не ругается). Правда, тогда получается какая-то дурацкая рекурсия - использование USE MODULE внутри самого этого модуля (точнее, интерфейса, определяемого внутри...).

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 12:03 12-08-2012 | Исправлено: BagaBaga, 12:08 12-08-2012
terminat0r



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Vostrikovskiy
gfortran supports as REAL(KIND=10)
 
Добавлено:
BagaBaga
Вы все правильно делаете, если добавили интерфейс в модуль то там в нем не нужно уже указывать use module. Где интерфейс изначально - не очень важно, главное что компилятор получит его.

Всего записей: 2084 | Зарегистр. 31-03-2002 | Отправлено: 16:03 12-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Любопытно. Теперь при попытке откомпилировать c f90 выдаёт ошибку - модуль не может использовать сам себя. А при f95 компилировалось нормально (с такой дикой рекурсией). Для собственного спокойствия создал новый модуль - только с интерфейсом - и подключаю его (был бы уверен, что этот интерфейс потребуется только один раз - прописал бы ручками в той подпрограмме, а так проще использовать use).

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 23:13 12-08-2012
akaGM

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

Всего записей: 24056 | Зарегистр. 06-12-2002 | Отправлено: 23:51 13-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Пытаюсь разобраться (ок - пока просто заставить компилироваться) вот с таким кодом
Подробнее...
 
Intel Fortran такое компилирует. Sun Fortran ругается на использование ENDIF в Качестве ENDDO (самое начало кода.
 
Я правлю это дело путём замены

Код:
 
        DO 1 K=1,NL
          IF(NTSL(K).NE.NTSL(1)) THEN
            NI=K
            GO TO 2
   1      ENDIF
 

 
на

Код:
 
        DO 1 K=1,NL
          IF(NTSL(K).NE.NTSL(1)) THEN
            NI=K
            GO TO 2
          ENDIF
   1    ENDDO
 

 
По идее, это вроде как правильно, но вот по коду не могу понять ... не попортил ли я алгоритм?
 

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 11:54 15-08-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
BagaBaga
ну а зачем смешивать 66/77/90 стиль?
 
  DO 1 K=1,NL
          IF(NTSL(K).NE.NTSL(1)) THEN
            NI=K
            GO TO 2
          ENDIF
   1    continue
 
почему не так?
или почему в твоём фортране жёстко не выбрать какую-нибудь опцию для старого стиля?

Всего записей: 24056 | Зарегистр. 06-12-2002 | Отправлено: 12:49 15-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Тут есть две проблемы (обе в области моей компетентности, точнее, некомпетентности):
Я не знаю Фортран (на уровне чтения Бартеньев О.В., Современный фортран). Но мне его нужно использовать, и пришло время переезжать на новый компилятор. В процессе работы (и "погружения" в фортран) компилятор ругается, и мне приходится эту ругань учитывать. Из "умений" у меня только зачатки Fortran-90. Мне куда больше нравится free form, да и сами конструкции. В то же время дорабатывать приходится исходник, происхождение которого весьма замысловатое: от советской машины ВЕКТОР к БЭСМ-6, а затем (в 90х) портирован под x286... Так что исходный код изначально представляет из себя смесь Fortran 66/77 и - эпизодически - 90. Так что, делать "в одном стиле" надо, но ... не всегда получается
 
Раз уж всё равно приходится править, то есть желание заставить это работать на Intel Fortran, Oracle Fortran, Open64 (собственно, если править под оракл, то двое оставшихся такой код кушают без вопросов).
 
Добавлено:
Вот такой вопрос: обратный слеш (\) в строках в Фортране (77 vs 90) является спецсимволом, или же нет?
 
В том смысле, что должен ли Fortran90 ругаться на отсутствие закрывающей кавычки у строки '\'
?

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 14:06 15-08-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
BagaBaga
насколько я знаю, не является, пока ты не говоришь, что это -- Си-строка:
 
call somefunction('one\ttwo\n'С)
и то -- это проблемы "принимащей стороны"...

Всего записей: 24056 | Зарегистр. 06-12-2002 | Отправлено: 17:49 15-08-2012 | Исправлено: akaGM, 17:50 15-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Есть вот такой код

Код:
 
DO 10 I=1,KZ
           IF(K2.GT.NPG) K2=NPG
           READ(4,REC=ISP,ERR=20) (PGL1(K),K=K1,K2)
           ISP=ISP+1
           K1=K2+1
           K2=K2+MDOR
   10   CONTINUE
 

 
Так вот (откомпилировано пока только Ifort под Oracle Linux), на строке read на этапе выполнения программы происходит какая-то ошибка (которая передаёт управление на метку 20, которая и печатает что "не могу читать"). Если я правильно понял, то это сокращённая форма записи "прочитать в массив PGL с позиции K1 по K2 из файла номер 4". Так вот, при компиляции этого же кода, но под виндой и FPS4 этот же файл читается нормально. В чём может быть проблема? (разные размеры для хранения элемента массива? файл бинарный).
 
PS
Понимаю, что похоже на призыв к телепату, но тогда хоть направление "подскажите". Сам более внятно сформулировать пока не готов.

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 20:43 15-08-2012
terminat0r



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
BagaBaga
* номера до десяти в идентификаторах использовать не рекомендуется
* покажите как открывался прежде в программе файл с идентификатором 4, т е open(4,...) и чему равно isp  в момент чтения файла
вот неплохие мыслишки на тему http://fortranwiki.org/fortran/show/Modernizing+Old+Fortran
 
проблема может быть в длине записи, тоесть recl=  или точнее в ее разнице по дефолту для разных компиляторов
 
и вообще бинарный неформатированный файл - это немного гемморой, лучше использовать netcdf или даже текстовый но пожатый zip-ом

Всего записей: 2084 | Зарегистр. 31-03-2002 | Отправлено: 21:28 15-08-2012 | Исправлено: terminat0r, 21:58 15-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Ок. Покажу каплю позже. Сейчас пойду читать ссылку и пытаться "завести" этот же код на Oracle Fortran... так сказать, для возможности сравнения.
 
Уйти от бинарного неформатированного файла пока нет возможности. Это потребует переработки всей системы запуска (формирования начальных и загрузки граничных условий) расчёта, а также переделки всех программ "вытаскивания" данных (вокруг которых уже понастроена куча "обёрток" для автоматизации процесса). А одновременно проводить расчёты в старой версии и ковырять новую без нового (с т.з. моделирования) результата просто не потянуть по времени (всё же надо дописать-таки этот кирпич). Подключить же, например, NetCDF, в "старое" не получится - библиотека не компилируется FPS4. В текстовом формате тоже не фонтан - будет чудовищно медленный ввод-вывод (который и сейчас-то при частом сохранении небыстрый). Да и файлик в 80Мб тогда распирает на полгига как минимум...

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 22:41 15-08-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
open(4,...)
обязательно покажи...
+
нужен тип PGL1()

Всего записей: 24056 | Зарегистр. 06-12-2002 | Отправлено: 23:27 15-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Немного вопросов по ERRORS от Oracle Fortran
При компиляции

Код:
 
/opt/oracle/solarisstudio12.3/bin/f77  -c m6_98a.f    -o m6_98a.o
 

выдает

Код:
 
 path='arch\'
           ^        
"m6_98a.f", Line = 32, Column = 12: ERROR: This token is missing the ' delimiter
 
...
 
      i1=scan(FileName,'\',.true.)
                       ^            
"m6_98a.f", Line = 2284, Column = 24: ERROR: This token is missing the ' delimiter.
 

У него, получается, обратный слеш (\) - как в С, требует экранирования?
 
Добавлено:
akaGM, PGL1

Код:
 
      SUBROUTINE GLOBRW(READFL,PGL1,KDFN,NPG,MDOR)
      LOGICAL READFL
      DIMENSION PGL1(NPG)
      KZ=NPG/MDOR
      KOST=NPG-KZ*MDOR
      IF(KOST.NE.0)KZ=KZ+1
      ISP=KDFN+1
      K1=1
      K2=MDOR
 
...
 

 
Добавлено:
open(4,

Код:
 
      SUBROUTINE OpenMDF(POLE,MDOR)
C Model Data File opening
      real POLE(1024)
      open(4,FILE='MOD4',ACCESS='DIRECT',STATUS='OLD',RECL=4*1024)
        read(4,REC=1) POLE
        call RLABEL(POLE)
        MDOR  = POLE(82)
      close(4)
      open(4,FILE='MOD4',ACCESS='DIRECT',STATUS='OLD',RECL=4*MDOR)
      return
      end
 

Сначала есть "область заголовка", из которой читаются количества и размерности хранящихся там массивов данных. В самом начале лежит magic number (по нему проверяется, файл ли это модели)

Код:
 
      SUBROUTINE RLABEL(POLE)
      REAL POLE(1024),METKA(3)
      DATA METKA/'GLOB','AL M','ODEL'/
      DO 1 I=1,3
 1    IF(POLE(1020+I).NE.METKA(I))STOP 'This is NOT Model data file!'
      RETURN
      END
 

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 23:29 15-08-2012 | Исправлено: BagaBaga, 00:00 16-08-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
     real POLE(1024)
      open(4,FILE='MOD4',ACCESS='DIRECT',STATUS='OLD',RECL=4*1024)
      read(4,REC=1) POLE
 
а ты уверен, что POLE занимает ровно 4096 байт?
для начала надо делать хотя бы вот так:
RECL=size(POLE)
+
последний опен зачем, впрок?
open(4,FILE='MOD4',ACCESS='DIRECT',STATUS='OLD',RECL=4*MDOR)
 
SUBROUTINE GLOBRW(READFL,PGL1,KDFN,NPG,MDOR)
      LOGICAL READFL
      DIMENSION PGL1(NPG)
ну и какого типа здесь PGL1 ?
 

Цитата:
У него, получается, обратный слеш (\) - как в С, требует экранирования?  

скорее всего да и не только в нём...
это, наверное, из-за твоего любимого фри-формата, компилятор его как символ переноса воспринимает...

Всего записей: 24056 | Зарегистр. 06-12-2002 | Отправлено: 00:51 16-08-2012 | Исправлено: akaGM, 01:29 16-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
В программе упрощённое примерно такая структура
 
1. инициализация (загрузка начальных условий, в т.ч. чтение заголовка, открытие файла)
2. цикл по времени  
    (внутри которого с заданным интервалом происходит сбрасывание состояния на диск - чтобы не получилось "полсуток обсчитали, вылетело -допустим, добрый дядя на ночь дёрнул рубильник - считай сначала".)
3. закрытие файла
 
PGL1 описывается только в той подпрограмме, код которой я представил. И используется тоже только там.
Вызывается вот таким образом:
CALL GLOBRW(.TRUE.,PAR(1,IZAN),KDF(NFSN),KPARS*NNodeS,MDOR)
 
Где сам Par  объявлен вот таким образом (на сохранение передаётся "одномерный подмассив")
REAL PAR(KPARS,NH,ITS,IDT)
 
Добавлено:
Правда, для его представление в качестве "одномерного" используется определение
real PAR(*)
 
Добавлено:
для двумерной
real PAR(NH*ITS*IDT,*)

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 10:03 16-08-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
BagaBaga
ты вообще представляешь о чём я спрашиваю?
 
 

Цитата:
это, наверное, из-за твоего любимого фри-формата, компилятор его как символ переноса воспринимает...  
это я с & спутал...

Всего записей: 24056 | Зарегистр. 06-12-2002 | Отправлено: 11:05 16-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Возможно, я запутался.
>ну и какого типа здесь PGL1 ?  
 
PGL1 - это массив, количество элементов в массиве (его длинна) передается в   функцию через NPG. Явно тип этих значений (элементов массива) в коде не описан. На сколько я могу судить (из правил выведения типа по имени, а также по логике работы программы) - это массив значений типа REAL. В программе везде используется просто REAL (т.е. не используются определения типа REAL*4 или REAL(KIND=2)), но это должно быть REAL*4, т.е. "по умолчанию".
 
>ты вообще представляешь о чём я спрашиваю?  
Я вполне могу не понять или запутаться. Тогда, если можно, поясни.

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 11:20 16-08-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
BagaBaga
ну так на разных платформах/ОСях real не всегда real*4
 
write (*,*) sizeof(real)
end
 
что пишется?
 

Код:
 
      SUBROUTINE GLOBRW(READFL,PGL1,KDFN,NPG,MDOR)
      LOGICAL READFL
      DIMENSION PGL1(NPG)
      KZ=NPG/MDOR
      KOST=NPG-KZ*MDOR
      IF(KOST.NE.0)KZ=KZ+1
      ISP=KDFN+1
      K1=1
      K2=MDOR
здесь PGL1 _не описано_, а только задан размер _того что придёт_
а дефолтом может быть что угодно...
hello, implicit!

Всего записей: 24056 | Зарегистр. 06-12-2002 | Отправлено: 11:29 16-08-2012
BagaBaga

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
write (*,*) sizeof(real)
end  
даёт на ifort под Linux

Код:
 
[oracle@localhost test-model]$ /opt/intel/bin/ifort test.f -o test
[oracle@localhost test-model]$ ./test
           4
 

 
FPS4 под win7 не линкует

Код:
 
t.obj : error LNK2001: unresolved external symbol _SIZEOF@4
t.exe : fatal error LNK1120: 1 unresolved externals
 

но по _SIZEOF@4 есть подозрение, что это 4
 
Про implicit. К сожалению, модель почти вся на implicit.

Всего записей: 463 | Зарегистр. 14-11-2005 | Отправлено: 13:10 16-08-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

Компьютерный форум 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