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

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в 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
и отключать графические смайлики при размещении фортран-кода

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

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

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 17:37 21-01-2012 | Исправлено: akaGM, 17:41 21-01-2012
knkd

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

Цитата:
тогда мне осталось только дать "общеподчинёнский" совет

Уже исполняю :)
 
С "кластером" то кстати не он, а наш любимый ВЦ, наполненный профессионалами своего дела.

Всего записей: 196 | Зарегистр. 15-01-2008 | Отправлено: 17:53 21-01-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
knkd
тогда я немного не понимаю...
 
есть "гектары" старинного, неудобоваримого, но необходимого фортрановского кода
 
1) они просто есть?
тогда их можно потихоньку переделывать/адаптировать/осваивать
 
2) эти гектары генерит начальник...
причём такими темпами, что его г..., пардон, подчинённые не успевают усваивать
 
последнее, по-моему, неразрешимo простыми и быстрыми методами...
 
прошу прощения за свои сплошные фекальные темы  :)

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 18:03 21-01-2012 | Исправлено: akaGM, 18:05 21-01-2012
knkd

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

Цитата:
тогда их можно потихоньку

Ну а чем я занимаюсь, в свободное от ковыряния в носу время? :)
 

Цитата:
 эти гектары генерит начальник

Он тоже генерит... не гектары конечно... но его шесть соток заперты на семь замков (шоп всякие лоботрясы картошку не копали), что в общем-то и правильно :)
 
В общем, всё сложно. Всё требует времени. Может к пенсии и справлюсь (а меня будут шпынять за то, что не умею пользоваться 1024-разрядным компилятором) :D

Всего записей: 196 | Зарегистр. 15-01-2008 | Отправлено: 18:14 21-01-2012
akaGM

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

Цитата:
Может к пенсии и справлюсь а меня будут шпынять...

ты к тому времени будешь сам уже начальником с хардкордным знанием 32/64-разрядного компилятора и доскональными знаниями СиПиПей всего лишь с двумя (в наше-то время!) крестами, ну и (живее-всех-живых!) фортрана
 
что ж...
удачи!

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 18:35 21-01-2012 | Исправлено: akaGM, 17:22 26-01-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
что-то я залип...
 
нужно получить случайку в диапазоне [lorange .. uprange]
пишу
 
  x = lorange + (uprange - lorange) * random(0)
 
но ведь так я не получу никогда x == uprange
из-за random(0) = [0 .. 1)
 
т.е.
  x = lorange + (uprange - lorange) * random(0)
x = [lorange .. uprange)
 
а так
  x = uprange - (uprange - lorange) * random(0)
x = (lorange .. uprange]
 
:(
 
что делать?
 

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 17:29 26-01-2012 | Исправлено: akaGM, 17:44 26-01-2012
MERCURY127



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

Всего записей: 11564 | Зарегистр. 03-08-2008 | Отправлено: 18:34 26-01-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
MERCURY127
два вызова random?
 
ну должен же быть какой-то выход...

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 18:46 26-01-2012
terminat0r



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
akaGM
я тоже что то в ступоре
а подсмотреть в nag g05daf?
вот была дискуссия когда-то
http://coding.derkeiler.com/Archive/Fortran/comp.lang.fortran/2005-08/msg00104.html

Всего записей: 2084 | Зарегистр. 31-03-2002 | Отправлено: 19:39 26-01-2012 | Исправлено: terminat0r, 19:42 26-01-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
terminat0r
брал и у кнута и в imsl, но как-то фигово...

Код:
 
      DOUBLE PRECISION FUNCTION GGRAND(DSEED)
C
C DOUBLE PRECISION UNIFORM RANDOM NUMBER GENERATOR
C
C CONSTANTS: A = 7**5
C            B = 2**31 - 1
C            C = 2**31
C
C REFERENCE: IMSL MANUAL, CHAPTER G - GENERATION AND TESTING OF
C                                     RANDOM NUMBERS
C
C---SPECIFICATIONS FOR ARGUMENTS---
      DOUBLE PRECISION DSEED
C
C---SPECIFICATIONS FOR LOCAL VARIABLES---
      DOUBLE PRECISION A,B,C,S
C
      DATA A,B,C/16807.0D0, 2147483647.0D0, 2147483648.0D0/
C
      S=DSEED
      S=DMOD(A*S, B)
      GGRAND=S/C
      DSEED=S
      RETURN
      END

по твоей ссылке, тоже как-то неаккуратненько, в НАГ сейчас загляну...
 


 
NAG G05DAF
 
первая строка
      DOUBLE PRECISION                 ONE, X, Y, Z
...
      X = G05CAF(X) ! G05CAF(X) == Random(X)
 
фигня какая-то, 0-инициализация что ли?

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 19:58 26-01-2012 | Исправлено: akaGM, 20:05 26-01-2012
MERCURY127



Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
сложение и деление тоже не помогло бы увы надо так (r = random(0)):
 
if( r > 0.5) x = u - (u - l) * r;
else x = l + (u - l) * r;

Всего записей: 11564 | Зарегистр. 03-08-2008 | Отправлено: 20:07 26-01-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
NAG понравился, одна проверка, кот. можно убрать:

Код:
 
      DOUBLE PRECISION FUNCTION G05DAF(A,B)
C     THIS RETURNS A REAL NUMBER, UNIFORMLY DISTRIBUTED
C     BETWEEN A AND B.
C     .. Scalar Arguments ..
      DOUBLE PRECISION                 A, B
C     .. Local Scalars ..
      DOUBLE PRECISION                 ONE, X, Y, Z
C     .. External Functions ..
      DOUBLE PRECISION                 G05CAF
      EXTERNAL                         G05CAF
C     .. Intrinsic Functions ..
      INTRINSIC                        MAX, MIN
C     .. Data statements ..
      DATA                             ONE/1.0D0/
C     .. Executable Statements ..
      X = G05CAF(X)
      IF (A.GT.B) GO TO 20
      Y = A
      Z = B
      GO TO 40
   20 Y = B
      Z = A
   40 G05DAF = MIN(MAX(Y*(ONE-X)+Z*X,Y),Z)
      RETURN
      END

 
MERCURY127
ну да...
тоже ничего, спасибо...

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 20:12 26-01-2012 | Исправлено: akaGM, 20:34 26-01-2012
Andrew10

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Вопрос знатокам стандарта:
Есть код
 
INTEGER I
REAL A(1:10)
...
...
DO I = 1, 10
    IF( I .EQ.1 .OR. (A(I) .NE. A(I-1))) THEN
       .....
       .....
    END IF
....
END DO
 
...
 
Вопрос:  на первом шаге цикла DO переменная цикла I=1. Первая часть условия в IF  
выполняется. Что говорит стандарт, должна ли при этом вычисляться вторая часть условия т.е. проверка
A(I) .NE. A(I-1),
не должна, или это стандартом не определено. До версии Intel Fоrtran 12 все работало, т.е.  
вторая проверка не вычислялась. В 12-й вылетает с сообщением, что индекс массива меньше нижней границы массива.  
 

Всего записей: 780 | Зарегистр. 26-02-2005 | Отправлено: 00:21 27-01-2012 | Исправлено: Andrew10, 00:21 27-01-2012
akaGM

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

Цитата:
В 12-й вылетает с сообщением, что индекс массива меньше нижней границы массива.

отключи :)
 
самому интересно, а читать, наверное, придётся в iso-доках

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 01:06 27-01-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
MERCURY127  
только всё-таки:
 
  if( r < 0.5) x = u - (u - l) * r
  else x = l + (u - l) * r
 
иначе верхнего предела не достигнуть...
 
а теперь нижний...
блин, опять запутался...

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 03:23 27-01-2012
akaGM

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

Код:
real*8 function randomrange(lr, ur)
! [lowlimit .. uplimit]
  use ifport
  implicit none
 
  real*8 lr, ur, r
  real*8 MIN_REAL_VALUE_/2.0e-07/
   
  r = Random(0)
   
  if (r < MIN_REAL_VALUE_) then
    randomrange = lr
  else
    randomrange = lr + (ur - lr) * r
  endif
end function randomrange

 
! main
  use ifport
  implicit none
 
  integer*4 i, iseed
  real*8 r, lr, ur
  real*8 MIN_REAL_VALUE_/2.0e-07/
  real*8 randomrange
  external randomrange
 
  call SEED(100)      
 
  lr = 1.d0
  ur = 5.d0
 
  i = 1
  r = 0.d0
  do while (.true.)
    r = randomrange(lr, ur)
    write(*,*) r
 
    if (r > (ur - MIN_REAL_VALUE_)) then
      write(*,*) r, ' upper limit at iteration #', i
      exit
    endif
 
    if (r < (lr + MIN_REAL_VALUE_)) then
      write(*,*) r, ' lower limit at iteration #', i
      exit
    endif
     
    i = i + 1
  enddo
 
  write(*,*)
  write(*,*) r, ' at iteration #', i
  write(*,*) 'Done!'
  read(*,*)
end

в общем пока ничего лучше не придумал, просьба покритиковать...
 
-----
господи, что за фигня, критика отменяется :)
 
надоело:
 
   randomrange = lr + (ur - lr) * Random(0)
 
всё...
 
НАГ-овская функа работает не лучше

Код:
 
      real*8 function randomrange(lolimit, uplimit)
! [lolimit .. uplimit]
      use ifport
      implicit none
 
      real*8 lolimit, uplimit
      real*8 r
 
      r = Random(0)
      randomrange = MIN(MAX(lolimit*(1.d0-r)+uplimit*r,lolimit),uplimit)
      end function randomrange

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 08:27 27-01-2012 | Исправлено: akaGM, 08:58 27-01-2012
XPEHOMETP

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

Цитата:
отключи  

Может, отключить оптимизацию - явно из-за нее порядок выполнения проверок поменялось местами?

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

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
запросто...
почти во всех компиляторах есть, а у интелов нет?, маловероятно, надо аккуратно все opt опции просмотреть
 
во, например, в дельфях:
 
B-  full boolean evaluation
как раз этот случай..

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 15:28 27-01-2012
terminat0r



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

Цитата:
Что говорит стандарт, должна ли при этом вычисляться вторая часть условия т.е. проверка
A(I) .NE. A(I-1),
не должна, или это стандартом не определено.

ISO/IEC1539-1:2010
 

Цитата:
7.1.7
Evaluation of operands
1 It is not necessary for a processor to evaluate all of the operands of an expression, or to evaluate entirely each
operand, if the value of the expression can be determined otherwise.
NOTE 7.28
This principle is most often applicable to logical expressions, zero-sized arrays, and zero-length strings, but
it applies to all expressions.
For example, in evaluating the expression
X > Y .OR. L (Z)
where X, Y, and Z are real and L is a function of type logical, the function reference L (Z) need not be
evaluated if X is greater than Y. Similarly, in the array expression
W (Z) + A
where A is of size zero and W is a function, the function reference W (Z) need not be evaluated.

 
не могу воспроизвести
какие опции оптимизации используются и версия компилятора?
а если так, тоже вылетает?
 if( i==1 .or. ( (i-1/=0) .and. (a(i) /= a(i-1))))  
 
Добавлено:
свежая подборка "ресурсов" по фортрану
www.fortranplus.co.uk/resources/fortran_resources.pdf
может быть интересно полистать

Всего записей: 2084 | Зарегистр. 31-03-2002 | Отправлено: 16:16 27-01-2012 | Исправлено: terminat0r, 16:32 27-01-2012
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
terminat0r
это есть кул...
 
06.01.2012
фигасе каникулы...
 
вфтопку в шапку!

Всего записей: 24116 | Зарегистр. 06-12-2002 | Отправлено: 17:57 27-01-2012 | Исправлено: akaGM, 17:57 27-01-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