Extensible markup language (XML) is used to encode documents in a format readable both by machines and people. Though a document encoded in XML often will not cause a computer to do anything on its own, in combination with an application designed to interpret the XML document, the XML document can cause that application to perform certain functions, display certain information, use certain formatting, and so forth, based on the tags used when encoding the XML document. Consequently, XML standards have been developed to facilitate communication between applications and devices in formats that are agnostic to the specific devices being used. The standards may specify certain keywords or “tags” that will trigger specific functions to be performed. These functions can then be implemented in devices and/or applications in a manner appropriate to that device and/or application.
The present application may be more fully appreciated in connection with the following detailed description taken in conjunction with the accompanying drawings, in which like reference characters refer to like parts throughout, and in which:
Systems, methods, and equivalents associated with extensible markup language (XML) file condensing are described. In various examples it may be desirable to store XML files on devices or items that do not have a large amount of available memory. These items may be designed to be low cost, and therefore it may be impractical to include larger memory storage space without impacting the cost of producing these items. For example, print containers (e.g., ink cartridges) are a mass market item and pricing of the containers may be competitive, and therefore employing memory resources with excessive space may be wasteful and unnecessarily expensive.
Consequently, an XML file stored on a print container may be condensed in a manner that facilitates reducing the memory impact of the XML file. Though it may take some time for a printer to decondense the file when the print container is installed in the printer, this processing time may be negligible considering that much of the time involved with printing revolves around moving mechanical components of the printer. Though examples involving print containers are described, the techniques described herein may be usable in other fields and/or applications.
Consequently, a manner of condensing an XML file for storing these XML files is disclosed, Ultimately, the XML file may be stored as a set of indexes and a condensed version of the XML file. The indexes may be created by dividing the text of the XML file into three types of indexes: tags, attributes, and values. The XML file may then be translated according to the indexes. The indexes and the condensed XML file may then be stored in, for example, a print container. When the print container is inserted into a printer, the printer may decondense the condensed XML file into the original XML file using the indexes, allowing the printer to use the XML file to perform actions described in the XML file.
As used herein, tags generally refer to instructions that define an action to be performed, In XML file 100, for example, “<defaults>”, “<spit . . . />” and “<routines>” are examples of tags. Tags may include other nested tags. Two tag syntaxes are illustrated in XML file 100. The “<defaults>” tag opens on L00 and ends on L10 with a closing tag “</defaults>”, while the “<spit . . . />” tag begins and ends on the same line. In this example, each tag is illustrated on a different line for illustrative purposes, though multiple tags could be written on the same line.
Tags may also include attributes. In XML file 100, “mode”, “frequency”, and “granularity” are examples of attributes. As used herein, an attribute of a tag may be used to specify a parameter of the unique action triggered by that tag. Further, the attributes may be assigned values. In XML file 100, “1”, “normal” and “thermal_mode” are examples of values. As used herein, values may be used in association with attributes to specify the parameter of the unique action triggered by a tag the attribute is modifying. By way of illustration, the “<wiper-action . . . />” tag has a “speed” attribute that is set to the value “1”. Using the “speed” attribute with the “<wiper-action . . . />” tag in this way may cause the action associated with the “<wiper-action . . . />” tag to behave in a certain way. For example, the “<wiper-action . . . />” tag may cause wipers associated with a printer to turn on, and the “speed” attribute may be used to define the speed at which the wipers will operate, which in this case is “1”.
To facilitate certain condensation and compression techniques described above, it may be desirable for XML file 100 to have a specific known set of syntaxes. This set of syntaxes may be a subset of possible XML syntaxes. For example, though XML might support values having space characters in them, it may be desirable to ensure that values in XML file 100 use underscores or dashes instead of space characters (e.g., the “thermal_mode” value in line L03, “action-defaults” in line L02). Using a subset of syntaxes may make it easier and/or more, efficient to condense, compress, decompress, and decondense XML file 100 by making it easier to ensure that there is not collision due to two phrases having two different syntaxes compressing to the same compressed phrase.
As discussed above, it may be desirable to store XML file 100 in a condensed format. Though XML file 100 as illustrated may be short enough that condensation would be unwarranted, for longer XML files that contain more thorough instructions with more repetition of tags, attributes, and values, condensation may be desirable. To condense XML file 100, first an index 110 may be created. This may be achieved by identifying the tags, attributes, and values in XML file 100 and separating them into their separate categories. Here, XML file 100 includes 8 tags, 5 attributes, and 6 values. In various examples, it may be desirable to further sort the tags attributes and values to assist in condensation and/or a later compression pass of XML file 100. Here, tags, attributes and values are sorted first by their term frequency, and then alphabetically. For example, the “mode” attribute appears in lines L03, and L09, while the “frequency” attribute appears only in line L03. Similarly, tag “<defaults>” appears in lines L00 and L10, while tag “<progress . . . /> appears only in line L08.
Though one method of indexing the tags, attributes, and values is shown, others may be used instead. By way of illustration, in index 110, the tags, attributes, and values all use the same range of index numbers 1-8. In other examples, indexes may be designed instead where the tags, attributes, and values are each assigned non-overlapping index ranges. Other index assignments may also be appropriate.
Once index 110 has been created, encoding of the index into encoded index 115 and condensation of XML file 100 into condensed XML file 120 may begin. In
As discussed above, in the example index 110 illustrated, tags, attributes, and values each use the same index range, and that index range begins from a known value. Consequently, encoded index 115 may not need to identify index values of the tags, attributes, and keys within encoded index 115. Instead, this information may be reconstructed as a part of a process of decondensing condensed XML file 120. In example implementations where tags, attributes, and values are assigned varying indexes, this information may also be stored in encoded index 115.
To create condensed XML file 120, XML file 100 may be translated according to index 110. Here, XML file 100 has been translated so that each pair of characters (e.g., “T2”) in condensed XML file 120 corresponds to a specific tag, attribute, or value of XML file 100. This correspondence can be seen by examining index 110. Specifically, the first “<defaults>” tag is identified as having index 2 in index 110. Thus, the first T2 of condensed XML file 120 corresponds to the first “<defaults>” tag in XML file 100 because it is tag (indicated by the T) number 2 in index 110. Similarly, the phrase “<spit frequency=“6000” mode=“thermal_mode”/>” from line LO3 of XML file 100 corresponds to the portion of condensed XML file 120 that reads “T7 A2 V2 A1 V6 TE” that spans the first and second lines of condensed XML file 120. It is worth noting that condensed XML file 120 and encoded index 115 may have more or fewer characters depending on how these items are created, including additional symbols that could serve a variety of purposes.
In this example version of condensed XML file 120, a specialized symbol indicating a tag end is used. This symbol, represented as “TE”, is used to indicate to an application interpreting condensed XML file 120, that the most recent open tag here should be dosed. By way of illustration, the very last “TE” in condensed XML file 120 corresponds to the close of the “</defaults>” tag on line L10 of XML file 100. In various examples, using the TE tag may be desirable because certain forms of compression are more efficient the more that characters repeat. This is also a reason why sorting the tag index by term frequency is useful, as increased usage of the same indexes can further increase compression efficiency.
Consequently, once XML file 100 has been condensed into encoded index 115 and condensed XML file 120, the combination of which will be referred to as a translated file, the translated file may be further reduced in size by employing a compression technique. Which compression technique is used may depend on how encoded index 115 and condensed xml file 120 are created as the creation of these items may be designed to be optimal for a specific data compression technique.
Whether the translated file has been further compressed or not, the translated file may then be stored on a memory of an item with which XML file 100 is associated. One example item where this type of condensation of XML file 100 may be desirable is a print container containing a supply of print material, The print material and/or the print container may be designed to work with a specific type of printer. The printer may be two dimensional printers ranging such as a desktop printer designed for home or office use, an industrial scale printers that can output thousands of items per hour, and so forth. The printer could also be a three-dimensional printer. As mentioned above, these techniques involving condensing XML files may also be applied outside of the printing field.
Depending on the type of printer with which the print container is associated with, the print material may include ink, toner, cleaning fluid, build material for a 3D printer, and so forth. Thus, in this example, XML file 100 may contain instructions for the printer into which the print container is installed. These instructions may tell the printer how to operate efficiently using the print material. Consequently, these instructions may be related to cleaning the printer, otherwise servicing the printer, printing using the print material, and so forth. Other information could be conveyed to the printer in this manner, (e.g., security information, general updates).
Once the print container is installed into a printer, that printer may retrieve the translated file from the memory of the print container, and then begin decompressing, and decondensing the translated file back into XML file 100. How the file is decompressed will depend on the compression technique used. Decondensing the translated file may operate in reverse of creating the condensed XML file. Because syntaxes may be limited to a known set of syntaxes, XML file 100 may be recreated by filling in the syntaxes based on the specific ordering of tags, attributes, and values in condensed XML file 120. After decondensing the translated file back into XML file 100, the printer may then use the instructions to perform a function described by XML file 100 (e.g., cleaning the printer, servicing the printer, printing using a material in the print container).
In some examples, after decompressing and decondensing the translated file back into XML file 100, the printer may combine the instructions from XML file 100 with a set of stored instructions. These stored instructions may be a set of default instructions that the printer may use regardless of which print material is installed, unless overwritten by an instruction from an XML file such as XML file 100.
It is appreciated that, in the following description, numerous specific details are set forth to provide a thorough understanding of the examples. However, it is appreciated that the examples may be practiced without limitation to these specific details. In other instances, methods and structures may not be described in detail to avoid unnecessarily obscuring the description of the examples. Also. the examples may be used in combination with each other.
“Module”, as used herein, includes but is not limited to hardware. firmware, software stored on a computer-readable medium or in execution on a machine, and/or combinations of each to perform a function(s) or an action(s), and/or to cause a function or action from another module, method, and/or system. A module may include a software controlled microprocessor, a discrete module, an analog circuit, a digital circuit, a programmed module device, a memory device containing instructions, and so on. Modules may include gates, combinations of gates, or other circuit components. Where multiple logical modules are described, it may be possible to incorporate the multiple logical modules into one physical module. Similarly, where a single logical module is described, it may be possible to distribute that single logical module between multiple physical modules.
Method 200 includes generating indexes from an extensible markup language (XML) file at 210. In various examples, the XML file may contain instructions that control operation of a printer. The XML file may contain instructions that control operation of the printer based on a type of printing material stored in a printing material container (e.g., ink cartridge). By way of illustration, different materials may affect components of a printer in different manners and may cause those components to have different maintenance needs. Thus, an XML file associated with a print container storing a particular print material may be able to control the printer to perform various functions, including maintenance functions, suitable for the particular print material. The XML file may also include other instructions related to, for example, cleaning the printer, servicing the printer, printing using the printing material, and so forth.
The set of indexes may include several indexes including a tag index, an attribute index, and a value index. The tag index may index tag terms used in the XML file. The attribute index may index attribute terms in the XML file. The value index may index value terms in the XML file. In some examples, the terms in the tag index, attribute index, and value index may be ordered within their respective indexes according to the frequency of the terms within the XML file. Ordering the indexes according to term frequencies may be desirable because certain compression techniques achieve greater compression rates the more terms are repeated. Consequently, when index ranges overlap, the repeated use of these indexes may help achieve greater compression rates.
In various examples, the XML file may contain instructions that control operation of a printer. The XML file may contain instructions that control operation of the printer based on a type of printing material stored in a printing material container (e.g., ink cartridge). By way of illustration, different materials may affect components of a printer in different manners and may cause those components to have different maintenance needs. Thus, an XML file associated with a print container storing a particular print material may be able to control the printer to perform various functions, including maintenance functions, suitable for the particular print material. The XML file may also include other instructions related to, for example, cleaning the printer, servicing the printer, printing using the printing material, and so forth.
Method 200 also includes condensing the XML file into a condensed version of the XML file at 220. The condensed version of the XML file may be condensed by translating the XML file according to the indexes. In some examples, to facilitate creation of the indexes at 210, condensation of the XML file at 220, and the potential decondensation of the XML file at a later point, the XML file may use a known subset of XML syntaxes. These syntaxes may be preselected so that, for example, for any two given different XML statements, the condensed version of these two statements be different. Similarly, the syntaxes may also be selected so that for any two given different condensed statements, decondensed versions of these statements will also be different.
Method 200 also includes generating a translated file. The translated file may be made up of the set of indexes created at action 210, and the condensed version of the XML file created at action 220. By way of illustration, the indexes and the condensed version of the XML file may be concatenated into a single file to create the translated file.
Method 300 also includes compressing the translated file at 340. Compressing the translated file may further reduce the total file size of the translated file. Method 300 also includes storing the translated file on a memory at 350. In an example where the XML file contains instructions that control operation of a printer in association with a printing material, the translated file may be stored on a memory of a printing material container that holds a supply of printing material. This may allow a printer to be specifically configured for using a variety of printing materials without having to store this information in the printer itself. This may be desirable when, for example, configuring the printer to use a new printing material, saving memory space within the printer, and so forth.
Print container also includes a memory 430. Memory 430 includes a tag index 432. Tag index 432 may contain a list of tag terms from an extensible markup language (XML) file. The tag terms may be organized according to the frequency of the tag terms in the XML file. Memory 430 also includes an attribute index 434. Attribute index 434 may contain a list of attribute terms from the XML file. The attribute terms may be organized in attribute index 434 according to the frequency of the attribute terms in the XML file. Memory 430 also includes a value index 436. Value index 436 may contain a list of value terms from the XML file. The value terms may be organized in value index 436 according to the frequency of the value terms in the XML file.
Memory 430 also includes a condensed XML file 438. Condensed version of the XML file 438 may be created by translating the XML file according to the tag index, the attribute index and the value index. In some examples, tag index 432, attribute index 434, value index 436, and condensed XML file 438 may be stored in memory 430 in a compressed format. In various examples, a printer into which print container 400 is inserted may use the tag index, the attribute index, the value index, and the condensed version of the XML file to recreate the XML file. Consequently, the recreated XML file may control an operation of the printer in association with one or more of, print material 410, print container 400, print material distributer 420, and so forth.
Printer 500 also includes a communication module 520. Communication module 520 may obtain a set of indexes and a condensed XML file from print container 599. The condensed XML file may have been created from the set of indexes as well as an original XML file that is not stored on print container 599. In various examples, communication module 520 may retrieve the set of indexes and condensed XML file from a memory on print container 599. Consequently, in this example, enclosure 510 and print container 599 may contain appropriate electronic couplings to facilitate communication between communication module 520 and the memory on print container 599.
Printer 500 also includes an extraction module 530. Extraction module 530 may generate a decondensed XML file. The decondensed XML file may be generated by translating the condensed XML file according to the set of indexes.
Printer 500 also includes a control module 540. Control module 540 may control an operation of printer 500 according to instructions retrieved from the decondensed XML file. In various examples, control module 540 may control one or more of, cleaning a component of the printer, servicing a component of the printer, printing using the print material contained in print container 599, and so forth.
Printer 600 also includes a decompression module 650. Decompression module 650 may decompress the set of indexes and the condensed XML file. Decompression of the condensed XML file and the indexes may be performed when these items are stored on a memory of print container 699 in a compressed format to further reduce the amount of data stored on print container 699.
Printer 600 also includes a memory 660. Memory 660 may store a set of default instructions. Consequently, control module 640 may control the operation of the printer according to instructions retrieved from the decondensed XML file when the decondensed XML file modifies the default instructions. As discussed above, the operation of the printer may relate to cleaning the printer, servicing the printer, printing using the print material, and so forth.
The instructions may also be presented to computer 700 as data 750 and/or process 760 that are temporarily stored in memory 720 and then executed by processor 710. The processor 710 may be a variety of processors including dual microprocessor and other multi-processor architectures. Memory 720 may include non-volatile memory (e.g., read only memory) and/or volatile memory (e.g., random access memory). Memory 720 may also be, for example, a magnetic disk drive, a solid state disk drive, a floppy disk drive, a tape drive, a flash memory card, an optical disk, and so on. Thus, memory 720 may store process 760 and/or data 750. Computer 700 may also be associated with other devices including computers, printers, peripherals, and so forth in numerous configurations (not shown).
It is appreciated that the previous description of the disclosed examples is provided to enable any person skilled in the art to make or use the present disclosure. Various modifications to these examples will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other examples without departing from the spirit or scope of the disclosure. Thus, the present disclosure is not intended to be limited to the examples shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2015/061864 | 11/20/2015 | WO | 00 |