This invention relates generally to medical imaging and navigation systems and more particularly to a system and method for capturing, recording, storing and replaying full resolution video of procedures occurring on medical imaging and navigation systems.
Mobile fluoroscopy imaging and surgical navigation are two high technology tools used in operating rooms (OR) around the world to provide interventional imaging and image guidance during surgery. An integrated fluoroscopy imaging and navigation system provides the physician with fluoroscopic images during diagnostic, surgical and interventional procedures. The integrated system with a single workstation reduces hardware and electronics duplications that occur with two separate workstations with very similar user requirements. A single workstation that integrates imaging and navigation, uses less operating room real estate, and has the potential to improve the workflow by integrating applications.
The recording of full resolution video is not an option in both surgical navigation and fluoroscopic imaging systems. Currently, there is no way to capture and replay a full resolution video clip in a surgical navigation system, a fluoroscopic imaging system or an integrated fluoroscopy/imaging and navigation system. External video ports provide down sampled low resolution video (NTSC and PAL) for off-line recording and playback. The high resolution digital data is converted to low resolution analog data, and much image fidelity is lost. A low resolution sequence can be captured with a VCR or frame capture device in NTSC or PAL format. In surgical navigation, applications with native SXGA (1280×1024) or UXGA (1600×1200) graphics resolutions can be found in most systems. Although it is possible to export single image snapshots at full resolution, using digital computer standard file formats, motion video capture is still provided at National Television Standards Committee (NTSC) or at Phase Alternation Line (PAL) standard resolution through an analog video port.
For the reasons stated above, and for other reasons stated below which will become apparent to those skilled in the art upon reading and understanding the present specification, there is a need in the art for the capture, recording, storage and replay of full resolution video in surgical navigation and fluoroscopic imaging systems. There is also a need for a recording method or apparatus that effectively allows a user to decide to record an event after the event has taken place.
The above-mentioned shortcomings, disadvantages and problems are addressed herein, which will be understood by reading and studying the following specification.
In accordance with an aspect, a method for recording images obtained by a fluoroscopic imaging and navigation apparatus, the method comprising receiving a plurality of digital images from the fluoroscopic imaging and navigation apparatus; capturing the plurality of digital images from the fluoroscopic imaging and navigation apparatus; and buffering the captured plurality of digital images.
In accordance with another aspect, a system for recording of images obtained by a fluoroscopic imaging and navigation apparatus comprising a processor; a storage device coupled to the processor; and software means operative on the processor for receiving a plurality of digital images from the fluoroscopic imaging and navigation apparatus; capturing the plurality of digital images from the fluoroscopic imaging and navigation apparatus; and buffering the captured plurality of digital images from the imaging and navigation apparatus.
In accordance with yet another aspect, a computer-accessible medium having executable instructions for recording of images obtained by a fluoroscopic imaging and navigation apparatus, the executable instructions capable of directing a processor to perform receiving a plurality of digital images from the fluoroscopic imaging apparatus; capturing the plurality of digital images from the fluoroscopic imaging apparatus; buffering the captured plurality of digital images in an acquisition buffer having a predetermined size on a recording medium; replacing the captured plurality of digital images in the acquisition buffer with a next captured plurality of digital images in the acquisition buffer when a total plurality of digital images exceeds the size of the recording medium; wherein the captured plurality of digital images is acquired at one or more of a full frame rate, a lower frame rate, or at a navigation system sample rate.
In accordance with a further aspect, a system for recording of images obtained by a fluoroscopic imaging apparatus comprising: a processor; a storage device coupled to the processor; and software means operative on the processor for: receiving a plurality of digital images from the fluoroscopic imaging apparatus; and capturing the plurality of digital images from the fluoroscopic imaging apparatus.
In accordance with another further aspect, a system for recording of images obtained by a medical navigation apparatus comprising: a processor; a storage device coupled to the processor; and software means operative on the processor for receiving a plurality of digital images from the medical navigation apparatus; and capturing the plurality of digital images from the medical navigation apparatus.
Systems, clients, servers, methods, and computer-readable media of varying scope are described herein. In addition to the aspects and advantages described in this summary, further aspects and advantages will become apparent by reference to the drawings and by reading the detailed description that follows.
In the following detailed description, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific embodiments which may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the embodiments, and it is to be understood that other embodiments may be utilized and that logical, mechanical, electrical and other changes may be made without departing from the scope of the embodiments. The following detailed description is, therefore, not to be taken in a limiting sense.
The tracking subsystem 18 monitors the position of the patient 22, the detector 34, and an instrument or tool 24 used by a medical professional during a diagnostic or interventional surgical procedure. The tracking subsystem 18 provides tracking component coordinates 26 with respect to each of the patient 22, detector 34, and instrument 24 to the controller 20. The controller 20 uses the tracking component coordinates 26 to continuously calculate the positions of the detector 34, patient 22, and instrument 24 with respect to a coordinate system defined relative to a coordinate system reference point. The reference point for the coordinate system is dependent, in part, upon the type of tracking subsystem 18 used. The controller 20 sends control or trigger commands 28 to the x-ray generator 14 that in turn causes one or more exposures to be taken by the x-ray source 36 and detector 34. The controller 20 provides exposure reference data 30 to the image processor 16. The control or trigger commands 28 and exposure reference data 30 are generated by the controller 20, as explained in more detail below, based on the tracking component coordinates 26 as the imaging apparatus is moved along an image acquisition path.
By way of example, the imaging apparatus 12 may be manually moved between a first and second positions (P1, P2) as a series of exposures are obtained. The image acquisition path may be along the orbital rotation direction and the detector 34 may be rotated through a range of motion from zero (0) to 145 degrees or from 0 to 190 degrees.
The image processor 16 collects a series of image exposures 32 from the detector 34 as the imaging apparatus 12 is rotated. The detector 34 collects an image exposure 32 each time the x-ray source 36 is triggered by the x-ray generator 14. The image processor 16 combines each image exposure 32 with corresponding exposure reference data 30 and uses the exposure reference data 30 to construct a three-dimensional volumetric data set as explained below in more detail. The three-dimensional volumetric data set is used to generate images, such as slices, of a region of interest from the patient. For instance, the image processor 16 may produce from the volumetric data set saggital, coronal and/or axial views of a patient spine, knee, and the like.
The tracking subsystem 18 receives position information from detector, patient and instrument position sensors 40, 42 and 44, respectively. The sensors 40-44 may communicate with the tracking subsystem 18 via hardwired lines, infrared, wireless or any known or to be discovered method for scanning sensor data. The sensors 40-44 and tracking subsystem 18 may be configured to operate based on one or more communication medium such as electromagnetic, optics, or infrared.
As shown an electromagnetic (EM) implementation a field transmitter/generator is provided with up to three orthogonally disposed magnetic dipoles. The magnetic fields generated by each of these dipoles are distinguishable or ID from one another through phase, frequency or time division multiplexing. The magnetic fields may be relied upon for position detection. The field transmitter/generator may form any one of the patient position sensor 42, detector position sensor 40 or instrument position sensor 44. The field transmitter/generator emits EM fields that are detected by the other two of the position sensors 40-44. By way of example, the patient position sensor 42 may comprise the field transmitter/generator, while the detector and instrument position sensors 40 and 44 comprise one or more field sensors each.
The sensors 40-44 and tracking subsystem 18 may be configured based on optical or infrared signals. A position monitoring camera 46 can be added to monitor the position of the sensors 40-44 and to communicate with the tracking subsystem 18. An active infrared light may be periodically emitted by each sensor 40-44 and detected by the position monitoring camera 46. Alternatively, the sensors 40-44 may operate in a passive optical configuration, whereby separate infrared emitters are located at the camera 46 and/or about the room. The emitters are periodically triggered to emit infrared light. The emitted infrared light is reflected from the sensors 40-44 onto one or more cameras 46. The active or passive optical information collected through the cooperation of the sensors 40-44 and position monitoring camera 46 is used by the tracking subsystem 18 define tracking component coordinates for each of the patient 22, detector 34 and instrument 24. The position information may define six degrees of freedom, such as x, y, z coordinates and pitch, roll and yaw angular orientations. The position information may be defined in the polar or Cartesian coordinate systems.
Notwithstanding the communication medium used, the tracking subsystem 18 generates a continuous stream of tracking component coordinates, such as the Cartesian coordinates, pitch, roll and yaw for the instrument (I(x, y, z, pitch, roll, yaw)), for the detector 34 D(x, y, z, pitch, roll, yaw), and/or patient 22 P(x, y, z, pitch, roll, yaw). When the patient position sensor 42 is provided with an EM transmitter therein, the coordinate reference system may be defined with the origin at the location of the patient position sensor 42. When an infrared tracking system is used, the coordinate system may be defined with the point of origin at the patient monitoring camera 46.
The controller 20 continuously collects the stream of tracking component coordinates 26 and continuously calculates the position of the patient 22, detector 34 and instrument 24 relative to a reference point. The controller 20 may calculate rotation positions of the imaging apparatus and store each such position temporarily. Each new rotation position may be compared with a target position, representing a fixed angular position or based on a fixed accurate movement. When a 3-D acquisition procedure is initiated, the controller 20 establishes a reference orientation for the imaging apparatus 12. For instance, the controller 20 may initiate an acquisition process once the detector 34 is moved to one end of an image acquisition path with beginning and ending points corresponding to a 0 degree angle and 190 degree angle, respectively. Alternatively, the controller 20 may initialize the coordinate reference system with the imaging apparatus 12 located at an intermediate point along its range of motion. In this alternative embodiment, the controller 20 defines the present position of the detector 34 as a starting point for an acquisition procedure. Once the controller 20 establishes the starting or initial point for the image acquisition procedure, a control or trigger command 28 is sent to the x-ray generator 14 and initial exposure reference data 30 is sent to the image processor 16. An initial image exposure 34 is obtained and processed.
After establishing an initial position for the detector 34, the controller 20 continuously monitors the tracking component coordinates 26 for the detector 34 and determines when the detector 34 moves a predefined distance. When the tracking component coordinates 26 indicate that the detector 34 has moved the predefined distance from the initial position, the controller 20 sends a new control or trigger command 28 to the x-ray generator 14 thereby causing the x-ray source 36 to take an x-ray exposure. The controller 20 also sends new exposure reference data 30 to the image processor 16. This process is repeated at predefined intervals over an image acquisition path to obtain a series of images. The image processor 16 obtains the series of image exposures 32 that correspond to a series of exposure reference data 30 and combines the data into a volumetric data set that is stored in memory.
The controller 20 may cause the x-ray generator 14 and image processor 16 to obtain image exposures at predefined arc intervals during movement of the detector 34 around the orbital path of motion. The orbital range of motion for the detector 34, over which images are obtained, may be over a 145 degree range of motion or up to a 190 degree range of motion for the imaging apparatus 12. Hence, the detector 34 may be moved from a zero angular reference point through 145 degree of rotation while image exposures 32 are taken at predefined arc intervals to obtain a set of image exposures used to construct a 3-D volume. Optionally, the arc intervals may be evenly spaced apart at 1 degree, 5 degree, 10 degree and the like, such that approximately 100, 40, or 15, respectively, image exposures or frames are obtained during movement of the detector 34 through rotation. The arc intervals may be evenly or unevenly spaced from one another. In the alternative, the operator at any desired speed may manually move the detector 34. The operator may also move the detector 34 at an increasing, decreasing, or at a variable velocity since exposures are triggered only when the detector 34 is located at desired positions that are directly monitored by the tracking subsystem 18.
Integrated within the fluoroscopy imaging and navigation system 10 is the video subsystem 50 for capturing, recording, storing and replaying full resolution video of procedures occurring on the fluoroscopy imaging and navigation system 10. The video subsystem 50 is coupled to image processor 16, tracking subsystem 18, controller 20 and computer 302.
Integrated within the fluoroscopy imaging system 100 is the video subsystem 150 for capturing, recording, storing and replaying full resolution video of procedures occurring on the fluoroscopy imaging system 100. The video subsystem 150 is coupled to image processor 116, controller 120 and computer 302.
The tracking subsystem 218 receives position information from sensors 242 and 244. The sensors 242 and 244 may communicate with the tracking subsystem 218 via hardwired lines, infrared, wireless or any known or to be discovered method for scanning sensor data. The sensors 242 and 244 and tracking subsystem 218 may be configured to operate based on one or more communication medium such as electromagnetic, optics, or infrared.
Integrated within the medical navigation system 200 is the video subsystem 250 for capturing, recording, storing and replaying full resolution video of procedures occurring on the medical navigation system 200. The video subsystem 250 is coupled to tracking subsystem 218, controller 220 and computer 302.
The video subsystem is designed specifically for medical imaging and navigation applications, and not as an offshoot of commercial or home entertainment components. The video subsystem conveniently integrates with existing imaging modalities such as X-ray, ultrasound, computed tomography (CT), and magnetic resonance (MR) imaging systems for capturing, recording, storing and replaying full resolution medical images and video to recordable media or storage media. Additionally, the video subsystem has the capability of compressing the images and video using various compression formats, such as MPEG compression, JPEG compression, vector graphics compression, Huffman coding, or H.261 compression, for example.
The video subsystem provides a compact integrated system for use with both portable or mobile imaging and medical navigation systems, and fixed imaging modalities. For fixed imaging modalities, the video subsystem may be coupled directly to the imaging modality or coupled to a network that interfaces with the imaging modality for recording medical images and video from the fixed imaging modality onto storage media or a recording medium. In the case of a mobile imaging system or a medical navigation system, the video subsystem may be coupled to the mobile imaging system or the medical navigation system for recording medical images and video from the mobile imaging system or the medical navigation system onto storage media or a recording medium. The recorded medical images and video is available for replay and viewing during or after a procedure. The recording of this video of procedures could be maintained in a digital repository for auditing the performance of the operator, surgeon, or procedure. The video subsystem simplifies the video recording process allowing a user to easily record still images, loops and cine continuously, with the touch of a button, or with the use of a footswitch. Offering both retrospective and prospective record modes supports the capture of user specified seconds or minutes of image data immediately preceding or following the desired event. The video subsystem also allows for continuous linear recording of long dynamic runs or one-button capture of single frames directly from streaming video data. The video subsystem efficiently and automatically manages the image recording process allowing the user to concentrate on observation, diagnosis, and performing the procedure. The video subsystem eliminates the tedious and time consuming review and rewinding process to get to a few seconds of important data. Using various recording modes reduces the amount of non-essential image data captured, and allows a user to focus on the most crucial clinical data.
Computer 302 includes a processor 304, random-access memory (RAM) 306, read-only memory (ROM) 308, and one or more mass storage devices 310, and a system bus 312, that operatively couples various system components to the processor 304. The memory 306, 308, and mass storage devices, 310, are types of computer-accessible media. Mass storage devices 310 are more specifically types of nonvolatile computer-accessible media and can include one or more hard disk drives, floppy disk drives, optical disk drives, and tape drives. The processor 304 executes computer programs stored on computer-accessible media.
Computer 302 can be communicatively connected to the Internet 314 via a communication device 316. Internet 314 connectivity is well known within the art. In one embodiment, a communication device 316 is a modem that responds to communication drivers to connect to the Internet via what is known in the art as a “dial-up connection.” In another embodiment, a communication device 316 is an Ethernet or similar hardware network card connected to a local-area network (LAN) that itself is connected to the Internet via what is known in the art as a “direct connection” (e.g., T1 line, etc.).
A user enters commands and information into the computer 302 through input devices such as a keyboard 318 or a pointing device 320. The keyboard 318 permits entry of textual information into computer 302, as known within the art, and embodiments are not limited to any particular type of keyboard. Pointing device 320 permits the control of the screen pointer provided by a graphical user interface (GUI) of operating systems, such as versions of Microsoft Windows®. Embodiments are not limited to any particular pointing device 320. Such pointing devices include mice, touch screens, touch pads, trackballs, remote controls and point sticks. Other input devices (not shown) can include a microphone, joystick, game pad, satellite dish, scanner, or the like.
In some embodiments, computer 302 is operatively coupled to a display device 322. Display device 322 is connected to the system bus 312. Display device 322 permits the display of information, including computer, video and other information, for viewing by a user of the computer. Embodiments are not limited to any particular display device 322. Such display devices include cathode ray tube (CRT) displays (monitors), as well as flat panel displays such as liquid crystal displays (LCD's). In addition to a monitor, computers typically include other peripheral input/output devices such as printers (not shown). Speakers 324 and 326 provide audio output of signals. Speakers 324 and 326 are also connected to the system bus 312.
Computer 302 also includes an operating system (not shown) that is stored on the computer-accessible media RAM 306, ROM 308, and mass storage device 310, and is and executed by the processor 304. Examples of operating systems include Microsoft Windows®, Apple MacOS®, Linux®, UNIX®. Examples are not limited to any particular operating system, however, and the construction and use of such operating systems are well known within the art.
Embodiments of computer 302 are not limited to any type of computer 302. In varying embodiments, computer 302 comprises a PC-compatible computer, a MacOS®-compatible computer, a Linux®-compatible computer, or a UNIX®-compatible computer. The construction and operation of such computers are well known within the art.
Computer 302 can be operated using at least one operating system to provide a graphical user interface (GUI) including a user-controllable pointer. Computer 302 can have at least one web browser application program executing within at least one operating system, to permit users of computer 302 to access intranet or Internet world-wide-web pages as addressed by Universal Resource Locator (URL) addresses. Examples of browser application programs include Netscape Navigator® and Microsoft Internet Explorer®.
The computer 302 can operate in a networked environment using logical connections to one or more remote computer 328. These logical connections are achieved by a communication device coupled to, or a part of, the computer 302. Embodiments are not limited to a particular type of communications device. The interface 350 can be a remote computer, a server, a router, a network PC, a client, a peer device or other common network node. The logical connections depicted in
When used in a LAN-networking environment, the computer 302 and interface 350 are connected to the local network 330 through network interfaces or adapters 334, which is one type of communications device 316. The interface 350 may also include a network device 336. When used in a conventional WAN-networking environment, the computer 302 and remote computer 328 communicate with a WAN 332 through modems (not shown). The modem, which can be internal or external, is connected to the system bus 312. In a networked environment, program modules depicted relative to the computer 302, or portions thereof, can be stored in a remote computer.
Computer 302 also includes power supply 338. The power supply 338 may be an internal power supply or a battery.
In the previous descriptions of embodiments, (
Method 400 includes the capturing of video at action 402 and a buffering at action 406 of the captured video.
In action 402 video capturing is performed. The action of video capture is the receiving of a plurality of video signals from a medical imaging system, a medical navigation system, or an integrated imaging and navigation system. A video subsystem coupled to a medical imaging system, a medical navigation system, or an integrated imaging and navigation system includes a frame grabber or video capturing device for capturing a plurality of video images from the medical imaging system, a medical navigation system, or an integrated imaging and navigation system and converting the plurality of video images into a plurality of digital images. The video capturing can be at full range of medical video sources. The video capturing can also be interlaced and non-interlaced video sources as well as VGA and other video signals. The video capturing is able to capture the broadcast standard formats, such as S-Video and color composite sources. The ability to capture video at such high resolution results in the playback of images that are identical to the original source and without the drawbacks of scan conversion or reduced image resolution. The video capturing without introducing a loss of image quality results in output that is equal to that of the original imaging exam data. The imaging data is received and recorded at the highest bandwidth from the imaging modality so that each exam copy is exactly like the original. The video capturing can accommodate many desired rates such as full frame rates, lower frame rates, navigation system sample rates, or other defined rates. The video capturing may also be triggered by a data variation between frame T(n) and T(n−1), or controlled by an external event, such as “x-ray on” or “tracking on”. Once the video has been capture in action 402 control passes to action 404 for further processing.
In action 404, buffering is performed. The buffering process 404 is the act of recording information. A user can set or the system can come preset from the factory with a finite buffer in the video subsystem. The finite buffer will store all information (video, text, images) for a fixed period of time.
Method 500 includes the capturing of video at action 502, the determination of a triggering event at action 504, a determination if the triggering event had been activated at action 506, and a buffering at action 508 of the captured video upon the triggering event being activated.
In action 502 video capturing is performed. Once the video is captured control passes to action 506 for further processing.
In action 504, a triggering event is determined. This determination can be based on an ‘x-ray on’ signal, tracking on signal, statistical decision signal, or a switch signal initiated by the user. The statistical decision can be based on comparing the information content of frames (variation) or a series of frames to determine if a change has occurred. When there is no significant change between successive frames there is no need to store the video. This action prevents static video from being stored and to an increase of storage capacity available for preserving video data after a triggering condition. Once the triggering condition has been determined at action 504 control passes to action 506 for further processing.
In action 506, a static video condition is determined. The static video condition is based ideally on having captured video from action 502 and a negative triggering event from action 505. However, in the current arrangement if a triggering event is not indicated then the assumption is that a static video condition is present and control is returned to action 502 for further processing. When there is an indication that a triggering event is present (‘x-ray on’, tracking on, a switch is activated) control is passed to action 508 for further processing.
In action 508, buffering is performed. The buffering process 508 is the act of recording information after the triggering event has happened. A user can set or the system can come preset from the factory with a finite buffer on the video capturing system 100. The finite buffer will store all information (video, text, images) for a fixed period of time.
Method 600 begins with receipt of the captured video data in action 402. The capture data is referred to as a video stream to highlight the fact that data is being continuously streamed. In operation, an incoming video stream is buffered in a FIFO buffer at a predetermined frame rate. The video stream consists of a series of frames. As shown in methods 400 and 500 the streaming video is buffered (action 608) until a determination is made (actions 604 and 606) that a permanent recording of the video should be undertaken. Action 604 registers the selection for permanent storage of the captured video. The selection could be based on a stimulus received through a user interface preferably having VCR like functions, a physical switch, or system activated signal such as a triggering event (action 504). In an embodiment, a user can select through an interface to permanently record an event. When an event is selected for recording all buffered data would be transferred to a permanent storage such as a hard disk drive, DVD or CDROM (610, 612, 614). In general, recorded video data may be preserved by writing the video data to any storage medium, such as a hard disk, tape, RAM, flash memory, or non-volatile solid-state memory. Recorded video data may be preserved at any time between the decision to capture (triggering event 504) and the time that the data is overwritten in the circular buffer; however, deferring storage until the acquisition buffer is about to be overwritten facilitates giving the user the ability to cancel the decision to capture a block of data. The capture interval and the time interval that may be captured before the user's decision to record is a function of the quantity of recording medium and the recording density. If captured data, rather than being transferred out of the acquisition buffer, is stored in a newly reserved area of the acquisition buffer, then the capture interval will diminish as this area becomes filled with captured data. This newly reserved area can be dynamically acquired by simply re-mapping that portion of memory outside of the FIFO buffer, so that the buffer will not be overwritten with data from the incoming video stream.
The video subsystem described in the various embodiments above, may reduce x-ray dose and may possibly reduce the amount of contrast agent used in imaging, by reducing the number of “re-takes” due to operator error, and/or transient radiographic events like contrast agent dissipation. In addition, the video subsystem described above, solves the problem of not knowing what or when to record video by continuously buffering large amounts of video data to a buffer for recording and storage.
In some embodiments, methods 400, 500, and 600 are implemented as a computer data signal embodied in a carrier wave, that represents a sequence of instructions which, when executed by a processor, cause the processor to perform the respective method. In other embodiments, methods 400, 500, and 600 are implemented as a computer-accessible medium having executable instructions capable of directing a processor to perform the respective method. In varying embodiments, the medium is a magnetic medium, an electronic medium, or an optical medium.
The system components of the video subsystem can be embodied as electronic circuitry or components, as a computer-readable program, or a combination of both.
More specifically, in the computer-readable program embodiment, the programs can be structured in an object-orientation using an object-oriented language such as Java, Smalltalk or C++, and the programs can be structured in a procedural-orientation using a procedural language such as COBOL or C. The software components communicate in any of a number of means that are well-known to those skilled in the art, such as application program interfaces (API) or interprocess communication techniques such as remote procedure call (RPC), common object request broker architecture (CORBA), Component Object Model (COM), Distributed Component Object Model (DCOM), Distributed System Object Model (DSOM) and Remote Method Invocation (RMI). The components execute on as few as one computer, or on at least as many computers as there are components.
A video subsystem for a medical imaging and navigation system has been described. Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement which is calculated to achieve the same purpose may be substituted for the specific embodiments shown. This application is intended to cover any adaptations or variations. For example, although described in object-oriented terms, one of ordinary skill in the art will appreciate that implementations can be made in a procedural design environment or any other design environment that provides the required relationships.
In particular, one of skill in the art will readily appreciate that the names of the methods and apparatus are not intended to limit embodiments. Furthermore, additional methods and apparatus can be added to the components, functions can be rearranged among the components, and new components to correspond to future enhancements and physical devices used in embodiments can be introduced without departing from the scope of embodiments. One of skill in the art will readily recognize that embodiments are applicable to future communication devices, different file systems, and new data types.