Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
OpenDAS
OpenFold
Commits
4ca64437
"examples/python_rs/vscode:/vscode.git/clone" did not exist on "ccd153afb2b530d01945857095bfc7c5dc9ef1f0"
Commit
4ca64437
authored
Aug 02, 2023
by
Christina Floristean
Browse files
Merge branch 'multimer' of
https://github.com/aqlaboratory/openfold
into multimer
parents
fdcb72e8
8332aa0e
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
15 additions
and
7 deletions
+15
-7
openfold/utils/loss.py
openfold/utils/loss.py
+11
-4
openfold/utils/validation_metrics.py
openfold/utils/validation_metrics.py
+1
-1
train_openfold.py
train_openfold.py
+3
-2
No files found.
openfold/utils/loss.py
View file @
4ca64437
...
...
@@ -691,9 +691,13 @@ def compute_tm(
n
=
residue_weights
.
shape
[
-
1
]
pair_mask
=
residue_weights
.
new_ones
((
n
,
n
),
dtype
=
torch
.
int32
)
if
interface
:
if
interface
and
(
asym_id
is
not
None
):
if
len
(
asym_id
.
shape
)
>
1
:
assert
len
(
asym_id
.
shape
)
<=
2
batch_size
=
asym_id
.
shape
[
0
]
pair_mask
=
residue_weights
.
new_ones
((
batch_size
,
n
,
n
),
dtype
=
torch
.
int32
)
pair_mask
*=
(
asym_id
[...,
None
]
!=
asym_id
[...,
None
,
:]).
to
(
dtype
=
pair_mask
.
dtype
)
predicted_tm_term
*=
pair_mask
pair_residue_weights
=
pair_mask
*
(
...
...
@@ -1440,7 +1444,10 @@ def violation_loss(
+
l_clash
)
return
loss
# Average over the batch dimension
mean
=
torch
.
mean
(
loss
)
return
mean
def
compute_renamed_ground_truth
(
...
...
@@ -1563,7 +1570,7 @@ def experimentally_resolved_loss(
)
->
torch
.
Tensor
:
errors
=
sigmoid_cross_entropy
(
logits
,
all_atom_mask
)
loss
=
torch
.
sum
(
errors
*
atom37_atom_exists
,
dim
=-
1
)
loss
=
loss
/
(
eps
+
torch
.
sum
(
atom37_atom_exists
,
dim
=
(
-
1
,
-
2
)))
loss
=
loss
/
(
eps
+
torch
.
sum
(
atom37_atom_exists
,
dim
=
(
-
1
,
-
2
))
.
unsqueeze
(
-
1
)
)
loss
=
torch
.
sum
(
loss
,
dim
=-
1
)
loss
=
loss
*
(
...
...
openfold/utils/validation_metrics.py
View file @
4ca64437
...
...
@@ -29,7 +29,7 @@ def drmsd(structure_1, structure_2, mask=None):
if
(
mask
is
not
None
):
drmsd
=
drmsd
*
(
mask
[...,
None
]
*
mask
[...,
None
,
:])
drmsd
=
torch
.
sum
(
drmsd
,
dim
=
(
-
1
,
-
2
))
n
=
d1
.
shape
[
-
1
]
if
mask
is
None
else
torch
.
sum
(
mask
,
dim
=-
1
)
n
=
d1
.
shape
[
-
1
]
if
mask
is
None
else
torch
.
min
(
torch
.
sum
(
mask
,
dim
=-
1
)
)
drmsd
=
drmsd
*
(
1
/
(
n
*
(
n
-
1
)))
if
n
>
1
else
(
drmsd
*
0.
)
drmsd
=
torch
.
sqrt
(
drmsd
)
...
...
train_openfold.py
View file @
4ca64437
...
...
@@ -88,9 +88,10 @@ class OpenFoldWrapper(pl.LightningModule):
)
for
k
,
v
in
other_metrics
.
items
():
assert
(
len
(
v
.
shape
)
==
1
)
self
.
log
(
f
"
{
phase
}
/
{
k
}
"
,
v
,
f
"
{
phase
}
/
{
k
}
"
,
torch
.
mean
(
v
),
on_step
=
False
,
on_epoch
=
True
,
logger
=
True
)
...
...
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