Archon - A Digital Library that Federates Physics Collections
K. Maly, M. Zubair, M. Nelson, X. Liu, H. Anan, J. Gao, J. Tang, and Y. Zhao
{maly,zubair,mln,liu_x,anan,gao_j,tang_j,yzhao}@cs.odu.edu
Old Dominion University, Norfolk, Virginia, USAA, 23529
Abstract
Archon is a federation of physics collections with varying degrees of metadata richness. Archon uses the Open Archives Initiative Protocol for Metadata Harvesting (OAI-PMH) to harvest content metadata from distributed archives. The architecture of Archon services is largely based on another OAI-PMH digital library: Arc, a cross archive search service. However, Archon provides some new services that are specifically tailored for the physics community. Of these services we will discuss the approaches we used to search and browse equations and formulae. Also, we will discuss and a citation linking service for arXiv and American Physical Society (APS) archives.
Keywords: Digital Library,Open Archives Initiative, Heterogeneous Metadata, Metadata Services
1Introduction
Archon is a federation of physics digital libraries. Archon is a direct extension of the Arc digital library (Liu, Maly, Zubair & Nelson, 2001). Its architecture provides the following basic services: a storage service for the metadata of collected archives; a harvester service to collect data from other digital libraries using the Open Archives Initiative Protocol for Metadata Harvesting (OAI-PMH) (Lagoze & Van de Sompel, 2001); a search and discovery service; and a data provider service to expose the collected metadata to other OAI harvesters.
However, for Archon we have developed services especially for physics collections, based on metadata available from the participating archives that go beyond the required (by the OAI-PMH) unqualified Dublin Core (DC)(Weibel, Kunze, Lagoze & Wulf, 1998)set, designed especially for physics collections. For example, we provide a service to allow searching on equations embedded in the metadata. Currently this service is based on LaTeX (Lamport & Bibby, 1994) representation of the equations (due to the nature of archives used), but we are planning to extended forinclude MathML (Ion & Miner, 1999) representations in the near future. We also used context-based data to search for equations related to specific keywords or subjects. By intelligent template matching, Aacross-archive citation service has been developed to integrate heterogeneous collections into one unified linking environment.that applies intelligent template matching and is designed to provide fast access for documents referenced by another document.
The rest of this paper is organized as follows. Section 3 describes the overall architecture and services of Archon. Section 4 describes how equations are searched and browsed. Section 5 discusses citation management and provides some results of applying this service on arXiv and American Physical Society (APS) archives. Finally section 6 discusses conclusions and future work.
2Overview of Archon Services
The Archon architecture is based on the Java Servlets-based search service that was developed for Arc and earlier for the Joint Training, Analysis and Simulation Center (JTASC) (Maly et al., 2000). This architecture is platform independent and can work with any web server (Figure 1). Moreover, the changes required to work with different databases are minimal. In the following subsections we will present four basic services of Archon.
Figure 1111.: Overall Architecture
2.1Search Service
The search server is implemented in Java using Servlets. The components of the search server are shown in (Figure 2) Figure 2Figure 2Figure 2Figure 2. The session manager maintains one session per user per query. It is responsible for creating new sessions for new queries (or for queries for which a session has expired). Sessions are used because queries can return more results (hits) than can be displayed on one page, Caching results makes browsing through the hits faster. The session manager receives two types of requests from the client: either a request to process a new query (search); or a request to retrieve another page of results for a previously submitted query (browsing). For a search request, the session manager calls the index searcher that formulates a query (based on the search parameters) and submits it to the database server (using JDBC) then retrieves the search results. The session manager then calls the result displayer to display the first page. For a browsing request, the session manager checks the existence of a previous session (sessions expire after a specific time of inactivity). If an expired session is referenced, a new session is created, the search re-executed, and the required page displayed. In the case where the previous session still exists, the required page is displayed based on the cached data (which may require additional access to the database).
Figure 1. Overall Architecture
Figure 2. Search Server Implementation
Figure 2222.: Search Server Implementation
2.2Storage Service
The OAI-PMH uses unqualified Dublin Core (DC) as the default metadata set. Currently, Archon services are implemented based on the data provided in the DC fields, but we are planning to usein the prototype implementation we are already using richerusing richer metadata sets. in the near future. All DC attributes are saved in the database as separate fields. The archive name and set information are also treated as separate fields in the database for supporting search and browse functionality. In order to improve system efficiency, most fields are indexed using full-text properties of the database, such as the Oracle InterMedia Server (Oracle, 2001) and MySQL full-text search (MySQLKofler, 2001). The search engine communicates with the database using JDBC (Reese, 2000) and Connection Pool (Moss, 1999).
2.3Harvester
Similar to a web crawler, the Archon harvester (same as the Arc harvester) traverses the data providers automatically and extracts metadata. The significant differences include metadata normalization, and exploiting the incremental, selective harvesting defined by the OAI-PMH. Data providers are different in data volume, partition definition, service implementation quality, and network connection quality; \all these factors influence the harvesting procedure. Historical and newly published data harvesting have different requirements. When a service provider harvests a data provider for the first time, all past data (historical data) needs to be harvested, followed by periodic harvesting to keep the data current. Historical data harvests are high-volume and more stable. The harvesting process can run once, or, as is usually preferred by large archives, as a sequence of chunk-based harvests to reduce data provider overhead. To harvest newly published data, data size is not the major problem but the scheduler must be able to harvest new data as soon as possible and guarantee completeness -- even if data providers provide incomplete data for the current date. The OAI-PMH provides flexibility in choosing the harvesting strategy; theoretically, one data provider can be harvested in one simple transaction, or one is harvested as many times as the number of records in its collection. But in reality only a subset of this range is possible; choosing an appropriate harvesting method has not yet been made into a formal process. We define four harvesting types for Arc:
- bulk-harvest of historical data
- bulk-harvest of new data
- one-by-one-harvest of historical data
- one-by-one-harvest of new data
Bulk harvesting is ideal because of its simplicity for both the service provider and data provider. It collects the entire data set through a single http connection, thus avoiding a great deal of network traffic. However, bulk harvesting has two problems. First, the data provider may not implement the resumptionToken flow control mechanism of the OAI-PMH, and thus may not be able to correctly process large (but partial) data requests. Secondly, XML syntax errors and character-encoding problems were surprisingly common and can invalidate entire large data sets.
One-by-one harvesting is used when bulk harvesting is infeasible. However, this approach imposes significant network traffic overhead for both the service and data providers since every document requires a separate http connection. The default harvesting method for every data provider begins as bulk harvest. We keep track of all harvesting transactions and if errors are reported, we determine the cause and manually tune the best harvesting approach for that data provider.
The Arc harvester is implemented as a daemon written in Java and running on a Windows NT computerapplication. At the initialization stage, it reads the system configuration file, which includes properties such as user-agent name, interval between harvests, data provider URL, and harvesting method. The harvester then starts a scheduler, which periodically checks and starts the appropriate task. .
Some archives such as Emilio (refemilio) were not OAI-PMH compliant. To overcome this problem, we created an gateway which collects data fromcrawlsthe HTML pages of Emilio web sites and acts as an data provider to provide metadata that is harvested into Archon (see Figure 3x).
2.4Data Provider Service
The data provider service manages OAI-PMH requests coming to Archon and allows Archon to act as an aggregator for the metadata contents it harvested from other digital libraries.
3Equations-Based Search
In Archon, many metadata records contain equations. Most of these equations are written in LaTeX. Issues we had to resolve to enable Archon to search and browse equations include:
- Rendering of equations and embedding them into the HTML display.
- Identifying equations inside the metadata.
- Filtering common meaningless equations (such as a single n) and incomplete equations.
- Equation storage.
Figure x3. Archon Interface for Searching
2.4Figure 4: Equation Search and Display Service Architecture Data Provider Service
The data provider service manages OAI-PMH requests coming to Archon and allows Archon to act as an aggregator for the metadata contents it harvested from other digital libraries.
3Equations-Based Search
In Archon, many metadata records contain equations. Most of these equations are written in LaTeX,. Issues we had to resolve to enable Archon to search and browse equations include:
Rendering of equations and embedding them into the HTML display.
Identifying equations inside the metadata.
Filtering common meaningless equations (such as a single n,..) and incomplete equations.
Equation storage.
Figure 3344: Equation Search and Display Service Architecture
3.1Rendering of Eequations
Most of the equations available on Archon are written in LaTeX. However, viewing LaTeX equation encodings is not as intuitive as viewing the equations themselvessww, so, it is very useful to provide a visual tool to view the equations. There are several alternatives to display equations in a HTML page. One alternative is to represent equations using HTML tags. This is anthe appropriate choice if we only need to display simple expressions. However, using this method severely limits what can be displayed with the usual notation. Your A browser may not be able to properly display some special symbols, such as integral or summation symbols or Greek characters.
The alternative we chose is to write a program to convert the LaTeX equations into an image and embed it inside the HTML page. We implemented this tool as a Java applet.
3.2Identifying Equations
LaTeX equations have special characters (such as $) that mark the start and end of LaTeX strings. However, the presence of these symbols does not automatically indicate the presence of equation. Moreover, an equation can be written as a sequence of LaTeX strings instead of as a whole LaTeX string. This is why we implemented a simple state machine based program to identify equations.
Some of the rules used in this state machine are:
………………
- Isolate the unpaired ‘$’ symbol;
- Glue the small pieces together into the whole formula;
Check the close neighbors (both ends) of a LaTeX string to obtain a complete equations.
- …….
3.3Filtering Equations
Despite our progress to date, there are many situations which cannot be solved by the methods described above, because it is impossible to distinguish if whether a string is a part of formula or not if when it is not quoted with ‘$’ symbols. We have some “broken” formulas due to this reason. We worked around these limitations by filtering those formulaes out. We set established a “rule book” . where Every every rule in this book is a pattern of the regular expression, which describes what kind of LaTeX string is going to be dropped. Every collected LaTeX string is checked against the rules. Any matched LaTeX string is removed.
Furthermore, there are also some formulas formulae with ‘illegal’ LaTeX symbols. Some of these ‘illegal’ symbols are misspellings, such as a missing space or mistaken use of the backslash (\). Some of these symbols are user defined. A general-purpose LaTeX string parser cannot properly handle them. All of these will cause a blank image or a formula with missing parts, because the image converter cannot pick up the corresponding display element for it. To solve this problem, each extracted LaTeX string is screened. and The sstringswith thehaving ‘illegal’ symbolsis are dropped, so it cannot cause us trouble any more..
3.4Equation Storage
For fast browsing, we stored the extracted equation we into a relational database. 4is shows the schematic class diagram that shows the relationships between the classes used in this work and the relationships between the classes and the database.
Overall, we provided a novel search function—search with equation -to our digital library. To realize this function, LaTeX strings that wereare used to express equations are extracted from the metadata records. The extracted LaTeX strings are filtered and cleaned to eliminate errors and illegal symbols. Then the clean LaTeX strings are converted into GIF imagess.
We have provided three search alternatives for the user (provided in the search interface 5,Figure Figure 5FigurFigure 5).e 56):
- Search for the LaTeX string directly
- Display a list of all equations and the user can select an equation visually.
- Search for equations by subject or abstract keywords
In particular, when a user types in a word such as ‘Newton’ into the ‘abstract ‘field in Figure 5. We will present to the user all images of formulae that occur in the abstract of papers that contain the keyword ‘Newton’. Once a user has selected a subject entry in the box shown in Figure 5, we again display all formulae that occur in papers categorized as having that subject. Finally, by clicking on the formula such as shown in Figure 6, users will receive all the records related to this formula. (5)
Figure 5. Formula Search Interface
Finally, by clicking on the formula, users receive all the records related to this formula. In particular, when a user types in a word such as ‘Netwton’ into the ‘abstract ‘field in Figure 54. Wwe will present to the user all images of formulae that occur in the abstract of papers that contain the keyword ‘Newton’. Once a user has selected a subject entry in the box shown in Figure 45, we again display all formulae that occur in papers categorized as having that subject. Finally, by clicking on the formula such as shown in Figure 65, users will receive all the records related to this formula.
Figure 445
Figure 5576. Formula Search Result Page
At this point we have completed this service for arXive and are in the process to include the other archives shown in Figure x3. Our approach is to convert all local representation to Latex and then use the currently implemented scheme. For instance, APS will export its equation in the metadata records in MathML format through OAI-PMH’s parallel metadata harvesting scheme and we will translaste them to LatexLaTeX and store them in our database. CERN already uses Latex so it is only a matter of time to usinge their metadata records.
4Reference Linking Service
The reference linking service provides a convenient method to access references in a document. It provides the references information for a document as well as links from the references to their corresponding documents.
There are several kinds of reference linking services. One method is to provide reference links within one collection. The feature of our reference linking service is to provide reference-linking service among several collections. We will provide reference linking within a collection as well as cross-linking between collections. The service architecture is shown in . In addition to providing reference service for Archon users, we will consider extending our approach for:
1)OAI Citation Provider: Implementing an OAI layer to let other service provider to harvest the citation information from our collections.
2)Public Cross-linking Service: Users can get the reference information by issuing an OpenURL request (Van de Sompel & Beit-Arie, 2001).
The following sub-sections describe our approach in implementing reference linking along with a number of issues that we addressed.
Figure 7: Service Architecture for Reference Linking in Archon
4.1Obtaining Reference information
In order to acquire reference information, we divided the sources into three categories:
1)OAI-Compliant Data Provider
Some data providers, such as APS and CiteBase ( provide reference information in some of their metadata formats. CiteBase extracts citation information from LaTeX source files in arXiv. In this case, we harvest reference information directly.