Class: Chem::XYZ::XyzMolecule
- Inherits:
-
Object
- Object
- Chem::XYZ::XyzMolecule
- Includes:
- Molecule
- Defined in:
- lib/chem/db/xyz.rb
Constant Summary
Constants included from Molecule
Molecule::DESCRIPTORNAME, Molecule::ELEMNUM, Molecule::EpsHeader, Molecule::MDLCountLineFormat, Molecule::MDLHeaderLine2Format
Instance Attribute Summary
Attributes included from Molecule
#cdk2atom, #cdk_mol, #name, #ob_mol, #source
Attributes included from Graph
Instance Method Summary collapse
-
#initialize ⇒ XyzMolecule
constructor
A new instance of XyzMolecule.
- #open_xyz(filename) ⇒ Object
Methods included from Molecule
#-, #adjacent_index, #assign_2d_geometry, #bit_mat, #box_size, #breadth_first_search, #canonical_ring, #cdk_BCUT, #cdk_CPSA, #cdk_RotatableBondsCount, #cdk_calc_descriptor, #cdk_calc_descriptors, #cdk_find_all_rings, #cdk_fingerprint, #cdk_gasteiger_marsili_partial_charges, #cdk_generate_2D, #cdk_generate_randomly, #cdk_generate_vicinity, #cdk_hose_code, #cdk_hueckel, #cdk_mcs, #cdk_properties, #cdk_rule_of_file, #cdk_save_as, #cdk_setup, #cdk_sssr, #cdk_wiener_numbers, #cdk_xlogp, #composition, #connected?, #deep_dup, #delete, #delete_bond, #depth_first_search, #divide, #f_dfs, #find_smallest_ring, #find_sssr, #fingerprint, #generate_pubchem_subskey, #hilight, #induced_sub, #match, #match_by_ullmann, #method_missing, #molecular_weight, #n_hydrogen, #ob_export_as, #ob_save_as, #oxidation_number, #pubchem_subskeys, #remove_hydrogens!, #save, #save_as_mdl, #save_as_pdf, #subset_in_composition?, #to_cansmi, #to_eps, #to_inchi, #to_sybyl, #typ_str, #use_open_babel
Methods included from Graph
#adjacent_to, #clustering_coefficient, #each, #morgan, #terminal_nodes
Constructor Details
#initialize ⇒ XyzMolecule
Returns a new instance of XyzMolecule.
16 17 18 19 |
# File 'lib/chem/db/xyz.rb', line 16 def initialize super @nodes = [] end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Chem::Molecule
Instance Method Details
#open_xyz(filename) ⇒ Object
21 22 23 24 25 26 27 28 29 30 31 32 |
# File 'lib/chem/db/xyz.rb', line 21 def open_xyz filename xyz = open(filename, "r") n_atoms = xyz.readline.to_i title = xyz.readline n_atoms.times do |n| array = xyz.readline.split a = XyzAtom.new a.element, a.x, a.y, a.z = array[0].intern, array[1].to_f, array[2].to_f, array[3].to_f @nodes.push(a) end self end |