Я получаю следующую ошибку при компиляции кода на C , Я использую Numerical Recipes 2nd ed. функций rk4() для решения дифференциального уравнения первого порядка.Ошибка при решении обычного дифференциального уравнения численно в C - ошибка: ожидается '=', ',', ';', 'asm' или '__attribute__' перед '{' токеном
Я не эксперт в этой области. Любая помощь будет высоко оценена.
Ошибка:
first_order_DE_RK4_example1.c:75: error: expected ‘=’, ‘,’, ‘;’, ‘asm’ or ‘__attribute__’ before ‘{’ token
код:
#include "nrutil.h"
#include <stdio.h>
#include <math.h>
void rk4(float y[], float dydx[], int n, float x, float h, float yout[],
void (*derivs)(float, float [], float []));
void (*derivs)(float, float[], float[]);
int main()
{
int n; float h; float x;
float y[1];
float dydx[1];
n=1;
h=0.2;
x=0;
y[0] = 1;
dydx[0] = 5.0;
void rk4(float y[], float dydx[], int n, float x, float h, float yout[],
void (*derivs)(float, float [], float []));
return 0;
}
void rk4(float y[], float dydx[], int n, float x, float h, float yout[],
void (*derivs)(float, float [], float []))
{
int i;
float xh,hh,h6,*dym,*dyt,*yt;
dym=vector(1,n);
dyt=vector(1,n);
yt=vector(1,n);
hh=h*0.5;
h6=h/6.0;
xh=x+hh;
for (i=1;i<=n;i++)
{
yt[i]=y[i]+hh*dydx[i];
(*derivs)(xh,yt,dyt);
}
for (i=1;i<=n;i++)
{ yt[i]=y[i]+hh*dyt[i];
(*derivs)(xh,yt,dym);
}
for (i=1;i<=n;i++)
{
yt[i]=y[i]+h*dym[i];
dym[i] += dyt[i];
}
(*derivs)(x+h,yt,dyt);
for (i=1;i<=n;i++)
{
yout[i]=y[i]+h6*(dydx[i]+dyt[i]+2.0*dym[i]);
}
free_vector(yt,1,n);
free_vector(dyt,1,n);
free_vector(dym,1,n);
}
void (*derivs)(float x, float y, float dydx)
{
float rhs;
rhs = 1-x+4*y;
}
'void (* производные) (float x, float y, float dydx) {...}' -> 'void производные (float x, float y, float dydx) {...}' Или удалить это. – BLUEPIXY
Вы хотите, по крайней мере, прочитать главу 1.2 этой книги, если не потратить время на использование C-праймера. – alk
при компиляции всегда включайте все предупреждения, затем фиксируйте эти предупреждения. Выложенный код заставляет компилятор выводить около 3 десятков сообщений о проблемах. (для 'gcc', при минимальном использовании:' -Wall -Wextra -pedantic' Я также использую: '-Wconversion -std = gnu99) – user3629249