Skip to main content

creates smooth gifs of rotating molecules

Project description

molgif

create smooth gifs of rotating molecules

Examples

Use auto_rotate to find the best viewing angle

import molgif
import ase.build

# load in molecule (ase.Atoms object)
molecule = ase.build.molecule('biphenyl')

# specify save path
save_path = 'biphenyl.gif'

# create rotating gif with rot_gif function
molgif.rot_gif(molecule, save_path, auto_rotate=True)

Add a legend

molgif.rot_gif(molecule, save_path, add_legend=True)

Specify the color of each atom

# can be a string for one color or a list of custom colors
rainbow = ['red', 'orange', 'yellow',
           'green', 'blue', 'violet'] * 4

# list much match number of atoms
rainbow = rainbow[:len(molecule)]

molgif.rot_gif(molecule, save_path, colors=rainbow)

Use a dictionary to quickly color by atom type

# default colors will be used for types not specified
molgif.rot_gif(molecule, save_path, colors=dict(C='hotpink'),
               add_legend=True)

Anchor an atom to be at the center of rotation

# define index of atom to anchor
anchor = 3

colors = ['white'] * len(molecule)
colors[anchor] = '#0892d0'

molgif.rot_gif(molecule, save_path, colors=colors,
               anchor=anchor)

Adjust loop time and FPS

# loop_time = time to complete one rotation (seconds)
molgif.rot_gif(molecule, save_path, loop_time=2, fps=60)

Turn off bonds and scale atomic sizes

molgif.rot_gif(molecule, save_path, add_bonds=False,
               scale=0.9)

Change rotation axis

# switch between x, y (Default), or z
molgif.rot_gif(molecule, save_path, rot_axis='z')

Switch rotation direction

# counterclockwise (ccw)[Default] or clockwise (cw)
# based on rot_axis
# 'x': view from left
# 'y': view from top
# 'z': view into screen
molgif.rot_gif(molecule, save_path, direction='cw')

Visualize charges

import random

# random charges [-1, 1]
chgs = [-1 + 2 * random.random() for i in molecule]

# manually set the colorbar range (optional)
cb_range = (-1, 1)

molecule.set_initial_charges(chgs)

molgif.rot_gif(molecule, save_path, use_charges=True,
               cb_range=cb_range)

Requirements

  • ase
  • matplotlib
  • ImageMagick (command line tools must be installed)

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

molgif-0.1.5.tar.gz (10.4 kB view details)

Uploaded Source

File details

Details for the file molgif-0.1.5.tar.gz.

File metadata

  • Download URL: molgif-0.1.5.tar.gz
  • Upload date:
  • Size: 10.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.7.1

File hashes

Hashes for molgif-0.1.5.tar.gz
Algorithm Hash digest
SHA256 de7b63aef88e6a1f257842a9e2d931596f3c31e512918b7d1ca8771b348d0f2c
MD5 768b1f24f01b0eab26f6e9f74a80948e
BLAKE2b-256 30dbfc7079e07af26a0064ebf1f5efce84fdf6d3d5d327ff37b035196c70d308

See more details on using hashes here.

Supported by

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