Source code for stk._internal.functional_groups.ring_amine

"""
Ring Amine
==========

"""

from .functional_group import FunctionalGroup


[docs] class RingAmine(FunctionalGroup): """ Represents an amine bonded to a ring. The structure of the functional group is given by the pseudo-SMILES ``[hydrogen1][nitrogen]([hydrogen2])[carbon1][carbon2] ([hydrogen3])[carbon3]``. """ def __init__( self, nitrogen, hydrogen1, hydrogen2, carbon1, carbon2, hydrogen3, carbon3, ): """ Initializes a :class:`.RingAmine` instance. Parameters ---------- nitrogen : :class:`.N` The ``[nitrogen]`` atom. hydrogen1 : :class:`.H` The ``[hydrogen1]`` atom. hydrogen2 : :class:`.H` The ``[hydrogen2]`` atom. carbon1 : :class:`.C` The ``[carbon1]`` atom. carbon2 : :class:`.C` The ``[carbon2]`` atom. hydrogen3 : :class:`.H` The ``[hydrogen3]`` atom. carbon3 : :class:`.C` The ``[carbon3]`` atom. """ self._nitrogen = nitrogen self._hydrogen1 = hydrogen1 self._hydrogen2 = hydrogen2 self._hydrogen3 = hydrogen3 self._carbon1 = carbon1 self._carbon2 = carbon2 self._carbon3 = carbon3 atoms = ( nitrogen, hydrogen1, hydrogen2, carbon1, carbon2, hydrogen3, carbon3, ) super().__init__( atoms=atoms, placers=(nitrogen,), core_atoms=(nitrogen,), )
[docs] def get_nitrogen(self): """ Get the ``[nitrogen]`` atom. Returns ------- :class:`.N` The ``[nitrogen]`` atom. """ return self._nitrogen
[docs] def get_hydrogen1(self): """ Get the ``[hydrogen1]`` atom. Returns ------- :class:`.H` The ``[hydrogen1]`` atom. """ return self._hydrogen1
[docs] def get_hydrogen2(self): """ Get the ``[hydrogen2]`` atom. Returns ------- :class:`.H` The ``[hydrogen2]`` atom. """ return self._hydrogen2
[docs] def get_carbon1(self): """ Get the ``[carbon1]`` atom. Returns ------- :class:`.C` The ``[carbon1]`` atom. """ return self._carbon1
[docs] def get_carbon2(self): """ Get the ``[carbon2]`` atom. Returns ------- :class:`.C` The ``[carbon2]`` atom. """ return self._carbon2
[docs] def get_hydrogen3(self): """ Get the ``[hydrogen3]`` atom. Returns ------- :class:`.H` The ``[hydrogen3]`` atom. """ return self._hydrogen3
[docs] def get_carbon3(self): """ Get the ``[carbon3]`` atom. Returns ------- :class:`.C` The ``[carbon3]`` atom. """ return self._carbon3
[docs] def clone(self): clone = super().clone() clone._nitrogen = self._nitrogen clone._hydrogen1 = self._hydrogen1 clone._hydrogen2 = self._hydrogen2 clone._hydrogen3 = self._hydrogen3 clone._carbon1 = self._carbon1 clone._carbon2 = self._carbon2 clone._carbon3 = self._carbon3 return clone
[docs] def with_atoms(self, atom_map): clone = super().with_atoms(atom_map) clone._nitrogen = atom_map.get( self._nitrogen.get_id(), self._nitrogen, ) clone._hydrogen1 = atom_map.get( self._hydrogen1.get_id(), self._hydrogen1, ) clone._hydrogen2 = atom_map.get( self._hydrogen2.get_id(), self._hydrogen2, ) clone._hydrogen3 = atom_map.get( self._hydrogen3.get_id(), self._hydrogen3, ) clone._carbon1 = atom_map.get( self._carbon1.get_id(), self._carbon1, ) clone._carbon2 = atom_map.get( self._carbon2.get_id(), self._carbon2, ) clone._carbon3 = atom_map.get( self._carbon3.get_id(), self._carbon3, ) return clone
def __repr__(self): return ( f"{self.__class__.__name__}(" f"{self._nitrogen}, {self._hydrogen1}, {self._hydrogen2}, " f"{self._carbon1}, {self._carbon2}, {self._hydrogen3}, " f"{self._carbon3})" )