Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
LGPU FPP
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Fernando Pérez Panadero
LGPU FPP
Commits
d14447cf
Commit
d14447cf
authored
1 year ago
by
Fernando Pérez Panadero
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Typo one
parent
a494d346
master
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
69 additions
and
4 deletions
+69
-4
src/Dirac/Dirac.jl
src/Dirac/Dirac.jl
+3
-3
src/Solvers/CG.jl
src/Solvers/CG.jl
+66
-1
No files found.
src/Dirac/Dirac.jl
View file @
d14447cf
...
@@ -53,7 +53,7 @@ struct DiracWorkspace{T}
...
@@ -53,7 +53,7 @@ struct DiracWorkspace{T}
end
end
export
DiracWorkspace
,
DiracParam
export
DiracWorkspace
,
DiracParam
function
Dw
!
(
so
,
U
,
si
,
dpar
::
DiracParam
,
lp
::
SpaceParm
{
4
,
6
,
B
,
D
},
ymws
::
YM
W
orkspace
)
where
{
B
,
D
}
function
Dw
!
(
so
,
U
,
si
,
dpar
::
DiracParam
,
lp
::
SpaceParm
{
4
,
6
,
B
,
D
},
ymws
::
YM
w
orkspace
)
where
{
B
,
D
}
if
B
==
BC_SF_AFWB
||
B
==
BC_SF_ORBI
if
B
==
BC_SF_AFWB
||
B
==
BC_SF_ORBI
...
@@ -94,7 +94,7 @@ function Dw!(so, U, si, dpar::DiracParam, lp::SpaceParm{4,6,B,D}, ymws::YMWorksp
...
@@ -94,7 +94,7 @@ function Dw!(so, U, si, dpar::DiracParam, lp::SpaceParm{4,6,B,D}, ymws::YMWorksp
return
nothing
return
nothing
end
end
function
DwdagDw
!
(
so
,
U
,
si
,
dpar
::
DiracParam
,
st
,
lp
::
SpaceParm
{
4
,
6
,
B
,
D
},
ymws
::
YM
W
orkspace
)
where
{
B
,
D
}
function
DwdagDw
!
(
so
,
U
,
si
,
dpar
::
DiracParam
,
st
,
lp
::
SpaceParm
{
4
,
6
,
B
,
D
},
ymws
::
YM
w
orkspace
)
where
{
B
,
D
}
if
B
==
BC_SF_AFWB
||
B
==
BC_SF_ORBI
if
B
==
BC_SF_AFWB
||
B
==
BC_SF_ORBI
@timeit
"DwdagDw"
begin
@timeit
"DwdagDw"
begin
...
@@ -183,7 +183,7 @@ function DwdagDw!(so, U, si, dpar::DiracParam, st, lp::SpaceParm{4,6,B,D}, ymws:
...
@@ -183,7 +183,7 @@ function DwdagDw!(so, U, si, dpar::DiracParam, st, lp::SpaceParm{4,6,B,D}, ymws:
end
end
function
g5Dw
!
(
so
,
U
,
si
,
dpar
,
lp
::
SpaceParm
{
4
,
6
,
B
,
D
},
ymws
::
YM
W
orkspace
)
where
{
B
,
D
}
function
g5Dw
!
(
so
,
U
,
si
,
dpar
,
lp
::
SpaceParm
{
4
,
6
,
B
,
D
},
ymws
::
YM
w
orkspace
)
where
{
B
,
D
}
if
B
==
BC_SF_AFWB
||
B
==
BC_SF_ORBI
if
B
==
BC_SF_AFWB
||
B
==
BC_SF_ORBI
@timeit
"SF fix"
begin
@timeit
"SF fix"
begin
...
...
This diff is collapsed.
Click to expand it.
src/Solvers/CG.jl
View file @
d14447cf
...
@@ -34,7 +34,7 @@ return sum(sumf)
...
@@ -34,7 +34,7 @@ return sum(sumf)
end
end
function
CG
!
(
si
,
U
,
A
,
dpar
::
DiracParam
,
lp
::
SpaceParm
,
dws
::
DiracWorkspace
{
T
},
ymws
::
YM
W
orkspace
,
maxiter
::
Int64
=
10
,
tol
=
1.0
)
where
{
T
}
function
CG
!
(
si
,
U
,
A
,
dpar
::
DiracParam
,
lp
::
SpaceParm
,
dws
::
DiracWorkspace
{
T
},
ymws
::
YM
w
orkspace
,
maxiter
::
Int64
=
10
,
tol
=
1.0
)
where
{
T
}
dws
.
sr
.=
si
dws
.
sr
.=
si
dws
.
sp
.=
si
dws
.
sp
.=
si
...
@@ -78,3 +78,68 @@ function CG!(si, U, A, dpar::DiracParam, lp::SpaceParm, dws::DiracWorkspace{T},
...
@@ -78,3 +78,68 @@ function CG!(si, U, A, dpar::DiracParam, lp::SpaceParm, dws::DiracWorkspace{T},
return
niter
return
niter
end
end
function
CG_Dw
!
(
si
,
U
,
A
,
dpar
::
DiracParam
,
lp
::
SpaceParm
,
dws
::
DiracWorkspace
{
T
},
ymws
=
"ymws"
,
gp
=
"gp"
,
maxiter
::
Int64
=
10
,
tol
=
1.0
)
where
{
T
}
# r -> sr , s -> sp , p -> si , B^+ r -> st
iterations
=
0
sumf
=
scalar_field
(
Complex
{
T
},
lp
)
tol
=
tol
*
CUDA
.
mapreduce
(
x
->
norm2
(
x
),
+
,
si
)
nini
=
CUDA
.
mapreduce
(
x
->
norm2
(
x
),
+
,
si
)
dws
.
sr
.=
si
fill!
(
si
,
zero
(
eltype
(
si
)))
err
=
0.0
A
(
dws
.
sp
,
U
,
dws
.
sr
,
dpar
,
lp
,
ymws
,
gp
)
dws
.
st
.=
dws
.
sp
Brn
=
CUDA
.
mapreduce
(
x
->
norm2
(
x
),
+
,
dws
.
st
)
niter
=
0
print
(
"Normalized tol (tol*|v|^2) = "
,
tol
,
"
\n
"
)
for
i
in
1
:
maxiter
A
(
dws
.
sAp
,
U
,
dws
.
sp
,
dpar
,
lp
,
ymws
,
gp
)
prod
=
field_dot
(
dws
.
sAp
,
dws
.
sAp
,
sumf
,
lp
)
alpha
=
Brn
/
prod
si
.=
si
.+
alpha
.*
dws
.
sp
dws
.
sr
.=
dws
.
sr
.-
alpha
.*
dws
.
sAp
A
(
dws
.
st
,
U
,
dws
.
sr
,
dpar
,
lp
,
ymws
,
gp
)
err
=
CUDA
.
mapreduce
(
x
->
norm2
(
x
),
+
,
dws
.
sr
)
print
(
i
,
" : |r_n|/|v| = "
,
sqrt
(
err
/
nini
)
,
"
\n
"
)
if
err
<
tol
niter
=
i
break
end
Brn
=
CUDA
.
mapreduce
(
x
->
norm2
(
x
),
+
,
dws
.
st
)
beta
=
Brn
/
(
alpha
*
prod
)
dws
.
sp
.=
dws
.
st
.+
beta
.*
dws
.
sp
end
if
err
>
tol
error
(
"CG! not converged after
$
maxiter iterations (Residuals:
$
err)"
)
end
return
niter
end
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment