New type of chimera structures in a ring of bistable FitzHugh–Nagumo oscillators with nonlocal interaction
阅读
下载地址:https://chinazhang-my.sharepoint.com/:b:/g/personal/rep_rebirth_zh_zhangwenhao_icu/ETsX-FYc0ANPi7tCgLHDDSsBO-rPXZxqfdNDTcRRa8lAhw?e=iixX5y
- 研究了双稳区非局域耦合Fitzhugh-Nagumo振子环的时空动力学。在无噪声网络中发现了一种新类型的奇异态图案,当孤立的元件不振荡时。探讨了当网络单元之间的耦合范围和耦合强度不同时,这些结构的存在范围。
- 本文研究了非局域相互作用对双稳区FHN振子环的时空动力学的影响。我们注意到,环的每个孤立(未耦合)元素都有两个稳定的平衡点,并且不振荡。我们的数值模拟表明,对于非局域耦合,不仅可以产生行波。我们还发现了一种特殊类型的奇异态模式,这与以前的研究不同。虽然环单元不是自维持振荡器,但观察到的奇异态结构可以在没有随机或其他外力的情况下存在。
复现
data:image/s3,"s3://crabby-images/e4fe9/e4fe953d89e01c86c2f67c052671a29bad4f01c4" alt="figure 1"
- FHN oscillator model具有三个解,两个稳定焦点,一个鞍点。
data:image/s3,"s3://crabby-images/dc95d/dc95d6572902e2dff5a2378059fc848832ad8be4" alt="maple 解"
module FHN
implicit none
real :: h=0.002,x,y
contains
subroutine fnf()
implicit none
real :: func_x,func_y,epsilon=0.2,gamma=0.7,beta=0.0001
func_x=x+h*((x-x**3.0/3.0-y)/epsilon)
func_y=y+h*(gamma*x-y-beta)
x=func_x
y=func_y
write(20,*) x,y
return
end subroutine fnf
end module FHN
program main
use FHN
implicit none
integer :: i,a,b
open(20,file="data_x_y.txt")
do a=-10,-10,1
do b=-5,15,1
x=a*0.1-1.0
y=b*0.1-0.5
do i=1,4000,1
call fnf()
end do
end do
end do
do a=-10,30,1
do b=-5,-5,1
x=a*0.1-1.0
y=b*0.1-0.5
do i=1,4000,1
call fnf()
end do
end do
end do
do a=30,30,1
do b=-5,15,1
x=a*0.1-1.0
y=b*0.1-0.5
do i=1,4000,1
call fnf()
end do
end do
end do
do a=-10,30,1
do b=15,15,1
x=a*0.1-1.0
y=b*0.1-0.5
do i=1,4000,1
call fnf()
end do
end do
end do
do a=-10,10,1
x=a*0.1
y=x-(x**3)/3.0-0.08
do i=1,4000,1
call fnf()
end do
end do
do a=-10,10,1
x=a*0.1
y=x-(x**3)/3.0+0.08
do i=1,4000,1
call fnf()
end do
end do
close(20)
end program main
data:image/s3,"s3://crabby-images/9fb9e/9fb9ef5ab94a849a8770bbce8af75a9b5a4df654" alt="figure 1.1"
data:image/s3,"s3://crabby-images/8083a/8083afd05ce4e1324ec9e6d9cf46af656dd7dcb8" alt="figure 1.2"
module FHN
implicit none
real :: h=0.002,x,y
contains
subroutine fnf()
implicit none
real :: func_x,func_y,epsilon=0.2,gamma=0.7,beta=0.0001
func_x=x+h*((x-x**3.0/3.0-y)/epsilon)
func_y=y+h*(gamma*x-y-beta)
x=func_x
y=func_y
return
end subroutine fnf
end module FHN
program main
use FHN
implicit none
integer :: i,a,b,status=0
real :: x1,y1
open(20,file="data_x_y_status.txt")
do a=-200,200,1
do b=-100,100,1
x=a*0.01
y=b*0.01
x1=x
y1=y
do i=1,10000,1
call fnf()
end do
if(abs(x-0.9488)<=0.01.and.abs(y-0.6641)<=0.01) then
status=1
elseif(abs(x+0.9485)<=0.01.and.abs(y+0.6641)<=0.01) then
status=2
end if
write(20,*) x1,y1,status
end do
end do
close(20)
end program main
data:image/s3,"s3://crabby-images/5153a/5153ac7060ae81b2bc98d78dc499328b6870154f" alt="figure 1"
data:image/s3,"s3://crabby-images/fa478/fa478e1df77338ab1448351d6e6748d2020b30fc" alt="figure 2"
- 疑问(待解决):在不知道figure 3的情况下,怎么画figure 2,知道figure 3,未解决如何框住figure 3的A,B,C,D四种情况,特别是A和D。
module FHN
implicit none
real,parameter :: h=0.001
integer,parameter :: N=300,MaxT=10000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p
real :: func_x(N),func_y(N),epsilon=0.2,gamma=0.7,beta=0.0001,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0
do j=1,N
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(i==100.and.t==10000) then
write(20,*) p/real(N),sigma,x(i)
write(*,*) p/real(N),sigma,x(i)
end if
x=func_x
y=func_y
end do
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: a,b,p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_r_sigma_x.txt")
call x0_y0()
do a=1,30,1
do b=1,100,1
p=nint(N*(a*0.01))
sigma=b*0.01
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
end do
end do
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/193c0/193c0899e0a8e1a9497384794825ad7b8d95bc67" alt="figure 3"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=300000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(mod(t,50)==0.and.t>100000) then
write(20,*) i,t*h-100,x(i)
write(*,*) i,t*h-100,x(i)
end if
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_t_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.38D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/c96c2/c96c26c1054f3e9e6d00453135364c9be20cc837" alt="figure 3_A"
data:image/s3,"s3://crabby-images/d2eed/d2eed7cec76554e9af6cb92f7dcf6985e0e08ccd" alt="figure 3_B"
data:image/s3,"s3://crabby-images/aba69/aba692a87b87c2d941f0511f2541a631859584f8" alt="figure 3_C"
data:image/s3,"s3://crabby-images/c1445/c14456ef79964426e91cf529f2342387c2b73b19" alt="figure 3_D"
data:image/s3,"s3://crabby-images/e6991/e699134b5a914146fcd9aca38b191dd92bae7674" alt="figure 4"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=200000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(t==200000) then
write(20,*) i,x(i)
write(*,*) i,x(i)
end if
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.34D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/c322d/c322dda84f217709a5ca23a61c6523e2ec8efc22" alt="figure 4_A"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=450000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p,a
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
do a=0,150000,5000
if(t==200000+a) then
write(20,*) i,x(i)
write(*,*) i,x(i)
end if
end do
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.34D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/bb0bd/bb0bd323d3b1211692447733fcb6a33e535d284c" alt="figure 4_B"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=450000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p,a
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(i==180.and.t>150000) then
write(20,*) t*h,x(i)
write(*,*) t*h,x(i)
end if
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.34D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/5181b/5181bcff6b4145f7bf62f18c247d12ba1cbe5568" alt="figure 4_C"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=450000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p,a
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
do a=300000,300000,6000
if(i==180.and.t>150000.and.mod(t,50)==0) then
write(20,*) x(i),y(i)
write(*,*) t*h,x(i),y(i)
end if
end do
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.34D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/7befa/7befaab79ddee3eba044c03166b3bc3488a23740" alt="figure 4_D"
data:image/s3,"s3://crabby-images/54717/547170c431bf4bc25818868700e783a61fbf9225" alt="figure 5"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=202000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N),delta_x(N)=0.0
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(t==202000) then
write(40,*) i,x(i)
end if
if(t>200000.and.t<=202000) then
if(i==1) then
call delta_i(i,x(i),x(i+1),x(N))
else
call delta_i(i,x(i),x(i+1),x(i-1))
end if
end if
if(t==202000) then
write(20,*) i,delta_x(i)/2000.0
write(*,*) i,delta_x(i)/2000.0
end if
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine delta_i(i,x1,x2,x3)
implicit none
integer :: i
real :: x1,x2,x3
delta_x(i)=delta_x(i)+(2.0*x1-x2-x3)**2
return
end subroutine delta_i
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_delta_i.txt")
open(40,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.38D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/4be5e/4be5e402ce26edd9b69ab0bc6fd369e4860a6c1f" alt="figure 5_A(1)"
data:image/s3,"s3://crabby-images/61fc2/61fc2747ad68240a06beeec1ff30a4dbf0d51d68" alt="figure 5_A"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=600000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,a,p,count_number(N)=0,N_pulse(N)=0
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(t>100000.and.mod(t,50)==0) then
if(i==216) then
write(40,*) t*h,x(i)
end if
if(func_x(i)>1.0) then
count_number(i)=count_number(i)+1
else if(count_number(i)>20.and.func_x(i)<-1.0) then
N_pulse(i)=N_pulse(i)+1
count_number(i)=0
end if
end if
end do
x=func_x
y=func_y
if(t==600000) then
do a=1,N,1
write(20,*) a,N_pulse(a)/500.0
write(*,*) a,N_pulse(a)
end do
end if
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_f_i.txt")
open(40,file="data_216_t.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.38D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/0bd39/0bd392261ac81e7e5f937ce9f6b1502f65c7c5f9" alt="figure 5_B_x"
data:image/s3,"s3://crabby-images/5089f/5089f17158c05102533df4100947e9c8db7aec5a" alt="figure 5_B_39"
data:image/s3,"s3://crabby-images/a6001/a600157c12948a2ba4f9c577e1294724ea1bebdc" alt="figure 5_B_187"
data:image/s3,"s3://crabby-images/2cb4a/2cb4a29fecb9e11b87672f19cc25a11a94426bb9" alt="figure 5_B_190"
data:image/s3,"s3://crabby-images/b587b/b587b616f844021a974411b6f4bdd2ca872f0665" alt="figure 5_B_216"
data:image/s3,"s3://crabby-images/00b48/00b486f34e0be5be1269b5a3a0d21603659406b8" alt="figure 5_B"
module FHN
implicit none
real,parameter :: h=0.01D0
integer,parameter :: N=300,MaxT=20000,L=90
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p,a
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect,xi_average(N)=0.0&
&,XX(N,MaxT),xi(N)
do t=1,MaxT+1,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
XX(i,t)=x(i)
end do
x=func_x
y=func_y
end do
call Rn_i(XX)
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
return
end subroutine neighbour
subroutine Rn_i(XX)
implicit none
integer :: i,T_mid=10000
real :: XX(N,MaxT),x_aver(N,MaxT),R_i(N)
x_aver=0.0
R_i=0.0
do i=1,N
x_aver(i,T_mid:MaxT)=XX(i,T_mid:MaxT)-real(sum(XX(i,T_mid:MaxT)))/real(MaxT-T_mid+1)
write(*,*) sum(XX(i,T_mid:MaxT))
end do
do i=1,N
R_i(i)=(sum(x_aver(i,T_mid:MaxT)*x_aver(90,T_mid:MaxT)))/real(MaxT-T_mid+1)/&
&sqrt(sum(x_aver(i,T_mid:MaxT)**2)/real(MaxT-T_mid+1)*sum(x_aver(90,T_mid:MaxT)**2)/real(MaxT-T_mid+1))
write(20,*) i,R_i(i)
end do
return
end subroutine Rn_i
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_R.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.38D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/d90f3/d90f303f0a27350acbb61911f00c4afc4a8b085b" alt="figure 5_C"
data:image/s3,"s3://crabby-images/f32ca/f32cad2894e8d1a4135c080ddeec629ff6b2d0c3" alt="figure 6"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=100000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(t==100000) then
write(20,*) i,x(i)
write(*,*) i,x(i)
end if
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.14D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/91d96/91d96d64155ff05a4433aa7d2305cc39a67f8e94" alt="figure 6_A"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=450000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p,a
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
do a=0,150000,5000
if(t==200000+a) then
write(20,*) i,x(i)
write(*,*) i,x(i)
end if
end do
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.14D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/9a3b0/9a3b0cf3b30b57b1a9146f1eb2876b63132c153f" alt="figure 6_B"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=450000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(i==221.and.t>150000) then
write(20,*) t*h-150,x(i)
write(*,*) t*h,x(i)
end if
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.14D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/d526b/d526b463cc4cde218a01cf019dba71249c2726e6" alt="figure 6_C"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=450000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(i==221.and.t>150000.and.mod(t,50)==0) then
write(20,*) x(i),y(i)
write(*,*) t*h,x(i),y(i)
end if
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.14D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/598d8/598d85d59f4f52ffc1b7b78d956dd5976debf867" alt="figure 6_D"
data:image/s3,"s3://crabby-images/809ae/809aee3beb8a3d7bce6f0a87a9efd1c5cd324874" alt="figure 7"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=102000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N),delta_x(N)=0.0
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(t==102000) then
write(40,*) i,x(i)
end if
if(t>100000.and.t<=102000) then
if(i==1) then
call delta_i(i,x(i),x(i+1),x(N))
else
call delta_i(i,x(i),x(i+1),x(i-1))
end if
end if
if(t==102000) then
write(20,*) i,delta_x(i)/2000.0
write(*,*) i,delta_x(i)/2000.0
end if
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine delta_i(i,x1,x2,x3)
implicit none
integer :: i
real :: x1,x2,x3
delta_x(i)=delta_x(i)+(2.0*x1-x2-x3)**2
return
end subroutine delta_i
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_delta_i.txt")
open(40,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.14D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/88cab/88cab963e355bdb460f413787a6ba0b82b9f3cce" alt="figure 7_A_x"
data:image/s3,"s3://crabby-images/e9a62/e9a62ad4a0f36edbd57d203a9dd20c2c551fd419" alt="figure 7_A"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=600000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,a,p,count_number(N)=0,N_pulse(N)=0
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
if(t>100000.and.mod(t,50)==0) then
if(i==216) then
write(40,*) t*h,x(i)
end if
if(func_x(i)>1.0) then
count_number(i)=count_number(i)+1
else if(count_number(i)>20.and.func_x(i)<-1.0) then
N_pulse(i)=N_pulse(i)+1
count_number(i)=0
end if
end if
end do
x=func_x
y=func_y
if(t==600000) then
do a=1,N,1
write(20,*) a,N_pulse(a)/500.0
write(*,*) a,N_pulse(a)
end do
end if
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_f_i.txt")
open(40,file="data_216_t.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.14D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/14a38/14a38b44be94d9d483fc8cb6a842f2928e4d60a4" alt="figure 7_B_X"
data:image/s3,"s3://crabby-images/ca56d/ca56d02c88f4a662aa857d678305177b2ef5afac" alt="figure 7_B"
module FHN
implicit none
real,parameter :: h=0.01D0
integer,parameter :: N=300,MaxT=20000,L=90
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p,a
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect,xi_average(N)=0.0&
&,XX(N,MaxT),xi(N)
do t=1,MaxT+1,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
XX(i,t)=x(i)
end do
x=func_x
y=func_y
end do
call Rn_i(XX)
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
return
end subroutine neighbour
subroutine Rn_i(XX)
implicit none
integer :: i,T_mid=10000
real :: XX(N,MaxT),x_aver(N,MaxT),R_i(N)
x_aver=0.0
R_i=0.0
do i=1,N
x_aver(i,T_mid:MaxT)=XX(i,T_mid:MaxT)-real(sum(XX(i,T_mid:MaxT)))/real(MaxT-T_mid+1)
write(*,*) sum(XX(i,T_mid:MaxT))
end do
do i=1,N
R_i(i)=(sum(x_aver(i,T_mid:MaxT)*x_aver(90,T_mid:MaxT)))/real(MaxT-T_mid+1)/&
&sqrt(sum(x_aver(i,T_mid:MaxT)**2)/real(MaxT-T_mid+1)*sum(x_aver(90,T_mid:MaxT)**2)/real(MaxT-T_mid+1))
write(20,*) i,R_i(i)
end do
return
end subroutine Rn_i
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_R.txt")
call random_seed()
call x0_y0()
p=25
sigma=0.38D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/a64d1/a64d106ac288430f5eefecf78a9abe4f871cc38e" alt="figure 7_C"
data:image/s3,"s3://crabby-images/1fb9c/1fb9c2db74214208be3f182cbe3482f827a8de55" alt="figure 8"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=450000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p,a
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
do a=0,150000,5000
if(t==200000+a) then
write(20,*) i,x(i)
write(*,*) i,x(i)
end if
end do
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=15
sigma=0.19D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/89669/896699742df0b5f1e6455de7b2b2f9c236cbe937" alt="figure 8_A"
module FHN
implicit none
real,parameter :: h=0.001D0
integer,parameter :: N=300,MaxT=450000
integer,allocatable :: neighbour_matrix(:,:)
real :: x(N),y(N)
contains
subroutine x0_y0()
implicit none
integer :: i
real :: x0,y0
do i=1,N,1
read(10,*) x(i),y(i)
end do
end subroutine x0_y0
subroutine fnf(p,sigma)
implicit none
integer :: i,j,t,p,a
real :: func_x(N),func_y(N),epsilon=0.2D0,gamma=0.7D0,beta=0.0001D0,sigma,effect
do t=1,MaxT,1
do i=1,N,1
effect=0.0D0
do j=1,N,1
effect=effect+neighbour_matrix(i,j)*(x(j)-x(i))
end do
func_x(i)=x(i)+h*((x(i)-(x(i)**3)/3.0-y(i)+epsilon*(sigma/(2.0*p))*effect)/epsilon)
func_y(i)=y(i)+h*(gamma*x(i)-y(i)-beta)
do a=0,150000,5000
if(t==200000+a) then
write(20,*) i,x(i)
write(*,*) i,x(i)
end if
end do
end do
x=func_x
y=func_y
end do
return
end subroutine fnf
subroutine neighbour(K)
implicit none
integer :: K
integer :: i,j,number
allocate(neighbour_matrix(N,N))
neighbour_matrix=0
do i=1,N-1,1
do j=i+1,N,1
if(abs(i-j)<=K/2.or.abs(i-j)>=N-K/2) then
neighbour_matrix(i,j)=1
neighbour_matrix(j,i)=1
end if
end do
end do
end subroutine neighbour
end module FHN
program main
use FHN
implicit none
integer :: p
real :: sigma
open(10,file="data_x0_y0.txt")
open(20,file="data_i_x.txt")
call random_seed()
call x0_y0()
p=15
sigma=0.19D0
call neighbour(2*p)
call fnf(p,sigma)
deallocate(neighbour_matrix)
close(10)
close(20)
end program main
data:image/s3,"s3://crabby-images/04e40/04e407c6c801b6343626551f700264d0b34ab1b0" alt="figure 8_B"