NAME
UMLS::Interface README
SYNOPSIS
This package provides a Perl interface to UMLS, a taxonomy of
medical concepts. The package is set up to access UMLS present in
a mysql database. The package was essentially created for use with
the Semantic::Similarity package for measuring the semantic
relatedness of concepts.
INSTALL
To install the module, run the following magic commands:
perl Makefile.PL
make
make test
make install
This will install the module in the standard location. You will, most
probably, require root privileges to install in standard system
directories. To install in a non-standard directory, specify a prefix
during the 'perl Makefile.PL' stage as:
perl Makefile.PL PREFIX=/home/sid
It is possible to modify other parameters during installation. The
details of these can be found in the ExtUtils::MakeMaker
documentation. However, it is highly recommended not messing around
with other parameters, unless you know what you're doing.
Next set the UMLSINTERFACE environment variable
DATABASE SETUP
The interface assumes that the UMLS is present as a mysql database.
The names of these databases can be passed as configuration options
at initialization. However, if the names of the database is not
provided at initialization, then default values are used -- the
database for the UMLS is called 'umls'.
The UMLS database must contain four tables:
1. MRREL
2. MRCONSO
3. MRSAB
4. MRDOC
All other tables in the databases will be ignored, and any of these
tables missing would raise an error.
The mysql server can be on the same machine as the module or could
be on a remotely accessible machine. The location of the server can
be provided during initialization of the module.
INITIALIZING THE MODULE
To create an instance of the interface object, using default values for
all configuration options:
use UMLS::Interface;
my $interface = UMLS::Interface->new();
Configuration options can be included in the MySQL my.cnf
file. This is preferable. The directions for this are in
the INSTALL file. It is Stage 5 Step D.
The following configuration options are also provided though:
'driver' -> Default value 'mysql'. This option specifies the
Perl DBD driver that should be used to access the
database. This implies that the some other DBMS
system (such as PostgresSQL) could also be used,
as long as there exist Perl DBD drivers to
access the database.
'umls' -> Default value 'umls'. This option specifes the name
of the UMLS database.
'hostname' -> Default value 'localhost'. The name or the IP
address of the machine on which the database
server is running.
'socket' -> Default value '/tmp/mysql.sock'. The socket on
which the database server is using.
'port' -> The port number on which the database server
accepts connections.
'username' -> Username to use to connect to the database server.
If not provided, the module attempts to connect as
an anonymous user.
'password' -> Password for access to the database server. If not
provided, the module attempts to access the server
without a password.
USING THE MODULE
Once the object of module is successfully created after following the
steps described in the previous section, a number of methods can be
called upon this object:
getError() -- Returns the error code and error string from
the last method call on the object.
root() -- Returns the concept ID of the root of the tree.
depth() -- Returns the depth of the tree.
version() -- Return the version of UMLS.
exists() -- Determines if a CUI exists
validCui() -- Checks if CUI is a valid concept
getSab() -- Returns the list of sources the concept
exists in
getConceptList() -- Returns the list of all concept IDs preset in
the database.
getTermsList() -- Returns the list of terms corresponding to a
particular concept ID.
getParents() -- Returns the parent of a given CUI
getChildren() -- Returns the children of a given CUI
pathsToRoot() -- Returns a list of concept IDs that denote
the path from the input concept ID to the
root
concept of the taxonomy.
findShortestPath() -- Returns the shortest path between two CUIs
findLeastCommonSubsumer() -- Returns the least common subsumer between
two CUIs
getCuiDef -- Returns the definition(s) of a given CUI
getStDef -- Returns the definition of a given ST
dropTable -- Drops the temporary table created by
the UMLS-Interface module of path information
for a specified set of sources
These methods essentially expose an interface as required by the
UMLS::Similarity modules. The UMLS::Similarity modules require
that any interface to a taxonomy provide the above methods.
SOFTWARE COPYRIGHT AND LICENSE
Copyright (C) 2004-2009 Bridget T McInnes, Siddharth Patwardhan, Serguei
Pakhomov and Ted Pedersen
This suite of programs is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
Note: The text of the GNU General Public License is provided in the
file 'GPL.txt' that you should have received with this distribution.