Skip to main content

Graph Neural Networks for Molecular Machine Learning

Project description

molcraft-logo

Deep Learning on Molecules: Graph Neural Networks for Molecular Machine Learning.

[!IMPORTANT] Under active development.

Examples

Context-Aware Graph Neural Network

Implement a context-aware graph neural network by embedding context features in the super node. The super node is a virtual node bidirectionally linked to all atomic nodes, allowing both efficient information propagation and inclusion of context features. Context features may be continuous or discrete (categorical); for discrete context features, specify the number of categories expected via num_categories of the AddContext layer.

from molcraft import features
from molcraft import featurizers 
from molcraft import layers
from molcraft import models

import keras
import pandas as pd

featurizer = featurizers.MolGraphFeaturizer(
    atom_features=[
        features.AtomType(),
        features.NumHydrogens(),
        features.Degree(),
    ],
    bond_features=[
        features.BondType(),
        features.IsRotatable(),
    ],
    super_node=True,
    self_loops=True,
)

df = pd.DataFrame({
    'smiles': [
        'N[C@@H](C)C(=O)O', 'N[C@@H](CS)C(=O)O' 
    ],
    'label': [3.5, -1.5],
    'ph': [7.2, 4.5],
    'temperature': [35., 45.],
})

graph = featurizer(df)

model = models.GraphModel.from_layers(
    [
        layers.Input(graph.spec),
        layers.NodeEmbedding(dim=128),
        layers.EdgeEmbedding(dim=128),
        layers.AddContext(field='ph'),
        layers.AddContext(field='temperature'),
        layers.GraphConv(units=128),
        layers.GraphConv(units=128),
        layers.GraphConv(units=128),
        layers.GraphConv(units=128),
        layers.Readout(mode='mean'),
        keras.layers.Dense(units=1024, activation='elu'),
        keras.layers.Dense(units=1024, activation='elu'),
        keras.layers.Dense(1)
    ]
)

model.compile(
    keras.optimizers.Adam(1e-4), keras.losses.MeanSquaredError()
)
model.fit(graph, epochs=30)
pred = model.predict(graph)

# Uncomment below to save and load model (including featurizer)
# featurizers.save_featurizer(featurizer, '/tmp/featurizer.json')
# models.save_model(model, '/tmp/model.keras')

# loaded_featurizer = featurizers.load_featurizer('/tmp/featurizer.json')
# loaded_model = models.load_model('/tmp/model.keras')

Hybrid Model for Peptides

Implement a GNN-RNN hybrid model for peptides.

from molcraft import features
from molcraft import featurizers 
from molcraft import layers
from molcraft import models

import keras
import pandas as pd

featurizer = featurizers.PeptideGraphFeaturizer(
    atom_features=[
        features.AtomType(),
        features.NumHydrogens(),
        features.Degree(),
    ],
    bond_features=[
        features.BondType(),
        features.IsRotatable(),
    ],
)

# Allow modified amino acids:
# featurizer.monomers.update({
#     "C[Carbamidomethyl]": "N[C@@H](CSCC(=O)N)C(=O)O"
# })

df = pd.DataFrame({
    'sequence': [
        'CYIQNCPLG', 'KTTKS' 
    ],
    'label': [1.0, 0.0],
})

graph = featurizer(df)

model = models.GraphModel.from_layers(
    [
        layers.Input(graph.spec),
        layers.NodeEmbedding(dim=128),
        layers.EdgeEmbedding(dim=128),
        layers.GraphConv(units=128),
        layers.GraphConv(units=128),
        layers.GraphConv(units=128),
        layers.GraphConv(units=128),
        layers.PeptideReadout(),
        keras.layers.Masking(),
        keras.layers.Bidirectional(
            keras.layers.LSTM(units=128, return_sequences=True)
        ),
        keras.layers.GlobalAveragePooling1D(),
        keras.layers.Dense(units=1024, activation='elu'),
        keras.layers.Dense(units=1024, activation='elu'),
        keras.layers.Dense(1, activation='sigmoid')
    ]
)

model.compile(
    keras.optimizers.Adam(1e-4), keras.losses.BinaryCrossentropy()
)
model.fit(graph, epochs=30)
pred = model.predict(graph)

# Uncomment below to save and load model (including featurizer)
# featurizers.save_featurizer(featurizer, '/tmp/featurizer.json')
# models.save_model(model, '/tmp/model.keras')

# loaded_featurizer = featurizers.load_featurizer('/tmp/featurizer.json')
# loaded_model = models.load_model('/tmp/model.keras')

Installation

For CPU users:

pip install molcraft

For GPU users:

pip install molcraft[gpu]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

molcraft-0.8.0.tar.gz (57.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

molcraft-0.8.0-py3-none-any.whl (56.7 kB view details)

Uploaded Python 3

File details

Details for the file molcraft-0.8.0.tar.gz.

File metadata

  • Download URL: molcraft-0.8.0.tar.gz
  • Upload date:
  • Size: 57.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for molcraft-0.8.0.tar.gz
Algorithm Hash digest
SHA256 9280d9a4ff1108b1d9dcc5437fdb038c1542e926c9445b4819dd39b6624927d9
MD5 aa395556ea21168baf798f8c3d4b7423
BLAKE2b-256 f59883175441fe9e3b50c70f8de3cea5618225c99d85d17626d0439f0e3ae0d4

See more details on using hashes here.

File details

Details for the file molcraft-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: molcraft-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 56.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for molcraft-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5154042cb44266bbe878988370916c54abf5e7e0dc5bbc3606b2779272ca6ca8
MD5 1e491855af4129b9f735f39fd06e2f8c
BLAKE2b-256 08f7e362741afb06ba9670985f6e0bad7d33b12e2e41bbcec48d68f999d60ba1

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page