US20100084468A1 - Method of imaging coding pattern comprising columns and rows of coordinate data - Google Patents

Method of imaging coding pattern comprising columns and rows of coordinate data Download PDF

Info

Publication number
US20100084468A1
US20100084468A1 US12/539,586 US53958609A US2010084468A1 US 20100084468 A1 US20100084468 A1 US 20100084468A1 US 53958609 A US53958609 A US 53958609A US 2010084468 A1 US2010084468 A1 US 2010084468A1
Authority
US
United States
Prior art keywords
tag
data
coding pattern
coordinate data
symbol
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US12/539,586
Inventor
Paul Lapstun
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Silverbrook Research Pty Ltd
Original Assignee
Silverbrook Research Pty Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Silverbrook Research Pty Ltd filed Critical Silverbrook Research Pty Ltd
Priority to US12/539,586 priority Critical patent/US20100084468A1/en
Assigned to SILVERBROOK RESEARCH PTY LTD reassignment SILVERBROOK RESEARCH PTY LTD ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: LAPSTUN, PAUL
Publication of US20100084468A1 publication Critical patent/US20100084468A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K19/00Record carriers for use with machines and with at least a part designed to carry digital markings
    • G06K19/06Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code
    • G06K19/06009Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking
    • G06K19/06037Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking multi-dimensional coding
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/10544Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation by scanning of the records by radiation in the optical part of the electromagnetic spectrum
    • G06K7/10712Fixed beam scanning
    • G06K7/10762Relative movement
    • G06K7/10772Moved readers, e.g. pen, wand
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light
    • G06K7/1404Methods for optical code recognition
    • G06K7/1408Methods for optical code recognition the method being specifically adapted for the type of code
    • G06K7/14172D bar codes

Definitions

  • the present invention relates to a position-coding pattern on a surface.
  • the Applicant has previously described a method of enabling users to access information from a computer system via a printed substrate e.g. paper.
  • the substrate has a coding pattern printed thereon, which is read by an optical sensing device when the user interacts with the substrate using the sensing device.
  • a computer receives interaction data from the sensing device and uses this data to determine what action is being requested by the user. For example, a user may make handwritten input onto a form or make a selection gesture around a printed item. This input is interpreted by the computer system with reference to a page description corresponding to the printed substrate.
  • the present invention provides a substrate having a first coding pattern disposed on a surface thereof, the first coding pattern comprising:
  • the registration symbols advantageously provide a means by which the first coding pattern can be distinguished from other coding pattern(s) of the same general type.
  • a number of cells contained in the first set identifies the first set and thereby the first coding pattern.
  • each of the registration symbols identifies the number of cells contained in the first set.
  • each registration symbol distinguishes the first coding pattern from a second coding pattern.
  • the registration symbols identify the first coding pattern by identifying the number of cells contained in each tag. For example, a first coding pattern have contain nine cells per tag, whilst a second coding pattern may have four cells per tag.
  • the first coding pattern and the second coding pattern are both readable and decodable by a same optical reader.
  • the Netpage pen can read and decode different Netpage position-coding patterns, irrespective of the actual number of cells per tag. This enables different position-coding patterns to be used and printed, depending on the print capabilities of a printer
  • the second coding pattern comprises:
  • the second-position coding pattern is typically of the same general type as the first position-coding pattern.
  • each cell of the first coding pattern and the second coding pattern comprises one or more registration symbols.
  • a large number of registration symbols in each tag provides a high degree of redundancy, meaning that the pen can robustly recognize a particular coding pattern.
  • the registration symbols in the first and second coding patterns are configured and positioned identically relative to target elements contained by each cell.
  • the relative positioning of the registration symbols in both the first and second coding patterns is the same, so that the pen can find the registrations symbols before it identifies which coding pattern it is reading.
  • the second coding pattern is adapted to be printed at a lower print resolution than the first coding pattern.
  • the second set contains a fewer number of cells than the first set.
  • each registration symbol identifies a translation of the cell relative to a tag containing the cell. This enables alignment of the tag(s) with the target grid.
  • a first translation codeword e.g. 0, 1, 2
  • a second translation codeword e.g. 3, 4
  • each cell comprises a pair of orthogonal registration symbols, each orthogonal registration symbol identifying a respective orthogonal translation of the cell relative to a tag containing the cell.
  • each registration symbol is identifies either an x-translation or a y-translation of a cell relative to a tag containing that cell.
  • each tag is square and comprises M 2 contiguous square cells, wherein M is an integer having a value of at least 2.
  • M 2 or 3.
  • M registration symbols in a row of M cells define a cyclic position code having minimum distance M, the code being defined by a first translation codeword.
  • M registration symbols in a column of M cells define a cyclic position code having minimum distance M, the code being defined by a second translation codeword.
  • each tag comprises N cells, and at least N registration symbols form a third translation codeword with minimum distance N, wherein N is an integer having a value of at least 4.
  • the first, second and/or third translation codewords enable robust alignment of the tag(s) with the target. For example, in a tag containing nine cells, four symbol errors in the third translation codeword may be corrected.
  • each registration symbol further identifies an orientation of a layout of the tag data with respect to the target grid.
  • the encoded orientation enables the Netpage pen to determine its orientation (yaw) relative to the tag data, and hence relative to the substrate.
  • the data elements are macrodots (i.e. readable marks in the form of dots).
  • a portion of data is represented by m macrodots, each of the macrodots occupying a respective position from a plurality of predetermined possible positions p within the cell, the respective positions of the macrodots representing one of a plurality of possible data values, wherein m is an integer of 1 or more (usually 2 or more), and p>m (typically p ⁇ 2m).
  • Encoding by multi-PPM in this way ensures uniform coverage of the substrate with macrodots, which helps to reduce visibility.
  • PPM encoding provides an internal luminescence reference for reading macrodots. For example, the darkest m macrodots in the p positions are taken to be the PPM data, without the need to refer to any external luminescence threshold value.
  • each cell defines a symbol group, each symbol group comprising a plurality of Reed-Solomon symbols encoded by a plurality of the data elements.
  • At least some of said tag data is encoded as a local codeword comprised of a set of the Reed-Solomon symbols.
  • the local tag data typically identifies a location of the tag.
  • a method of imaging either a first coding pattern or a second coding pattern disposed on a surface comprising the steps of:
  • each registration symbol identifies a translation of the cell relative to a tag containing the cell, the method further comprising the step of:
  • each registration symbol identifies an orientation of a layout of the tag data with respect to the target grid, the method further comprising the step of:
  • a system for imaging either a first coding pattern or a second coding pattern comprising:
  • target elements defining a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements;
  • each tag being defined by a set of contiguous cells, each tag comprising respective tag data encoded by a respective set of the data elements, wherein each cell comprises one or more registration symbols encoded by a respective set of the data elements;
  • an image sensor for capturing an image of a portion of the first or second coding pattern
  • a processor configured for performing the steps of:
  • each registration symbol identifies a translation of the cell relative to a tag containing the cell
  • the processor being configured to perform the further step of:
  • each registration symbol identifies an orientation of a layout of the tag data with respect to the target grid, the processor being configure to perform the further step of:
  • an optical reader for imaging either a first coding pattern or a second coding pattern, the first and second coding patterns each comprising:
  • target elements defining a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements;
  • each tag being defined by a set of contiguous cells, each tag comprising respective tag data encoded by a respective set of the data elements, wherein each cell comprises one or more registration symbols encoded by a respective set of the data elements;
  • the optical reader comprising:
  • an image sensor for capturing an image of a portion of either first or second coding pattern
  • a processor configured for performing the steps of:
  • optional embodiments of the first aspect may also be optional embodiments of the second, third or fourth aspects.
  • a substrate having a coding pattern disposed on a surface thereof, the coding pattern comprising:
  • each tag comprising x-coordinate data and y-coordinate data
  • each tag a plurality of data elements contained in each tag, the x-coordinate data being represented by a respective set of data elements and the y-coordinate data being represented by a respective set of data elements,
  • all the y-coordinate data is represented in a row of the tag parallel with an x-axis; and the column and the row each have a width v, such that any square portion of the coding pattern having a length (I+v) is guaranteed to contain the x-coordinate data and the y-coordinate data for a tag irrespective of whether a whole tag is contained in the portion.
  • the fifth aspect of the invention advantageously enables non-replication of coordinate data in each tag, which saves on tag space.
  • x-coordinate data should be replicated in each vertical half of tag
  • y-coordinate data should be replicated in each horizontal half of a tag.
  • the requirement for replication is obviated. If the column or row has a width v, then any square portion of length (l+v) is guaranteed to contain the relevant coordinate data.
  • width v corresponds to a width or length of a coordinate data symbol (depending on the shape and orientation of coordinate data symbols in the column or row), then it is ensured that any square portion of length (l+v) is guaranteed to contain the relevant coordinate data from spatially coherent samples i.e. from the same symbol, as opposed to partial symbols at opposite sides of a field of view.
  • a plurality of target elements define a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements and wherein each tag is defined by a plurality of contiguous cells.
  • each tag comprises M 2 contiguous square cells, wherein M is an integer having a value of at least 1.
  • M 2 or 3
  • the data elements are macrodots, which are readable dot-like marks formed by a plurality of contiguous printed dots.
  • v ts, wherein: s is defined as a spacing between adjacent macrodots; and t is an integer value of 2 or more.
  • the macrodots encode data values by pulse position modulation (PPM).
  • PPM pulse position modulation
  • a portion of data is represented by m macrodots, each of the macrodots occupying a respective position from a plurality of predetermined possible positions p within the cell, the respective positions of the macrodots representing one of a plurality of possible data values.
  • the x-coordinate data is encoded as an x-coordinate codeword comprised of a respective set of the X-Reed-Solomon symbols
  • the y-coordinate data is encoded as a y-coordinate codeword comprised of a respective set of the Y-Reed-Solomon symbols.
  • the X-Reed-Solomon symbols are configured and oriented in the column so as to have the width v
  • the Y-Reed-Solomon symbols are configured and oriented in the row so as to have the width v.
  • each tag comprises a plurality of common codewords, each common codeword being comprised of a respective set of the Reed-Solomon symbols, wherein the plurality of common codewords are defined as codewords common to a plurality of contiguous tags.
  • a common codeword typically encodes a region ID or page ID for the substrate.
  • each symbol group comprises a fragment of at least one of the common codewords
  • contiguous symbol groups are arranged such that any tag-sized portion of the coding pattern is guaranteed to contain the plurality of common codewords irrespective of whether a whole tag is contained in the portion.
  • each cell comprises a registration symbol encoded by a respective set of the data elements, the registration symbol identifying one or more of:
  • each cell comprises first and second registration symbols, the first registration symbol identifying a first orthogonal translation of the cell, the second registration symbol identifying a second orthogonal translation of the cell.
  • the first registration symbol identifies a first direction component of the orientation
  • the second registration symbol identifies a second direction component of the orientation, such that the first and second orthogonal registration symbols together identify the orientation via the first and second direction components.
  • the target elements are target dots and the data elements are macrodots, and each target dot has a diameter of at least twice that of each macrodot. This enables low-pass filtration of captured images to retain target elements but obscure macrodots.
  • a method of imaging a coding pattern disposed on a surface of a substrate comprising the steps of:
  • each tag comprising x-coordinate data and y-coordinate data
  • each tag a plurality of data elements contained in each tag, the x-coordinate data being represented by a respective set of data elements and the y-coordinate data being represented by a respective set of data elements,
  • the column and the row each have a width v
  • the imaged portion has a diameter of at least (l+v) ⁇ 2 and less than (2) ⁇ 2.
  • the position-coding pattern not only provides efficient use of tag space, but also allows the imaging field of view of the tag reader to be minimized.
  • each tag comprises a plurality of common codewords, each common codeword being comprised of a respective set of the Reed-Solomon symbols, wherein the plurality of common codewords are defined as codewords common to a plurality of contiguous tags, the method further comprising the step of:
  • one or more of the common codewords encode region identity data uniquely identifying a region of the surface, the method further comprising:
  • the region identity data uniquely identifies the substrate.
  • a system for imaging a coding pattern disposed on a surface of a substrate comprising:
  • each tag comprising x-coordinate data and y-coordinate data
  • each tag a plurality of data elements contained in each tag, the x-coordinate data being represented by a respective set of data elements and the y-coordinate data being represented by a respective set of data elements,
  • the column and the row each have a width v
  • an image sensor for capturing an image of a portion of the coding pattern, the image sensor having a field-of-view of at least (l+v) ⁇ 2 and less than (2l) ⁇ 2;
  • a processor configured for performing the steps of:
  • an optical reader for imaging a coding pattern disposed on a surface of a substrate, the coding pattern comprising:
  • each tag comprising x-coordinate data and y-coordinate data
  • each tag a plurality of data elements contained in each tag, the x-coordinate data being represented by a respective set of data elements and the y-coordinate data being represented by a respective set of data elements,
  • the column and the row each have a width v
  • the optical reader comprising:
  • an image sensor for capturing an image of a portion of the coding pattern, the image sensor having a field-of-view of at least (l+v) ⁇ 2 and less than (2) ⁇ 2;
  • a processor configured for performing the steps of:
  • optional embodiments of the fifth aspect may also be optional embodiments of sixth, seventh and eighth aspects.
  • FIG. 1 is a schematic of a relationship between a sample printed netpage and its online page description
  • FIG. 2 shows an embodiment of basic netpage architecture with various alternatives for the relay device
  • FIG. 3 shows the structure of a tag for a first position-coding pattern
  • FIG. 4 shows a group of twelve data symbols and four targets for the first position-coding pattern
  • FIG. 5 shows the layout of a 2-6PPM and 3-6PPM data symbol for the first position-coding pattern
  • FIG. 6 shows the spacing of macrodot positions in the first position-coding pattern
  • FIG. 7 shows the layout of a 2-6PPM registration symbol for the first position-coding pattern
  • FIG. 8 shows a semi-replicated x-coordinate codeword X for the first position-coding pattern
  • FIG. 9 shows a semi-replicated y-coordinate codeword Y for the first position-coding pattern
  • FIG. 10 shows common codewords A, B, C and D, with codeword A shown in bold outline for the first position-coding pattern
  • FIG. 11 shows an optional codeword E for the first position-coding pattern
  • FIG. 12 shows the layout of a complete tag for the first position-coding pattern
  • FIG. 13 shows the layout of a Reed-Solomon codeword for the first position-coding pattern
  • FIG. 14 shows the structure of a tag for a second position-coding pattern
  • FIG. 15 shows a group of eight data symbols and four targets for the second position-coding pattern
  • FIG. 16 shows the layout of a 2-9PPM data symbol for the second position-coding pattern
  • FIG. 17 shows an x-coordinate codeword X for the second position-coding pattern
  • FIG. 18 shows a y-coordinate codeword Y for the second position-coding pattern
  • FIG. 19 shows a common codeword A for the second position-coding pattern
  • FIG. 20 shows the layout of a complete tag for the second position-coding pattern
  • FIG. 21 shows the layout of a Reed-Solomon codeword for the second position-coding pattern
  • FIG. 22 is a flowchart of initial image processing by the Netpage pen
  • FIG. 23 is a flowchart of codeword decoding subsequent to the initial image processing
  • FIG. 24 shows a nib and elevation of the Netpage pen held by a user
  • FIG. 25 shows the pen held by a user at a typical incline to a writing surface
  • FIG. 26 is a lateral cross section through the pen
  • FIG. 27A is a bottom and nib end partial perspective of the pen
  • FIG. 27B is a bottom and nib end partial perspective with the fields of illumination and field of view of the sensor window shown in dotted outline;
  • FIG. 28 is a longitudinal cross section of the pen
  • FIG. 29A is a partial longitudinal cross section of the nib and barrel molding
  • FIG. 29B is a partial longitudinal cross section of the IR LED's and the barrel molding
  • FIG. 30 is a ray trace of the pen optics adjacent a sketch of the ink cartridge
  • FIG. 31 is a side elevation of the lens
  • FIG. 32 is a side elevation of the nib and the field of view of the optical sensor.
  • FIG. 33 is a block diagram of the pen electronics.
  • the invention is configured to work with the netpage networked computer system, an overview of which follows.
  • the preferred form of the netpage system employs a computer interface in the form of a mapped surface, that is, a physical surface which contains references to a map of the surface maintained in a computer system.
  • the map references can be queried by an appropriate sensing device.
  • the map references may be encoded visibly or invisibly, and defined in such a way that a local query on the mapped surface yields an unambiguous map reference both within the map and among different maps.
  • the computer system can contain information about features on the mapped surface, and such information can be retrieved based on map references supplied by a sensing device used with the mapped surface. The information thus retrieved can take the form of actions which are initiated by the computer system on behalf of the operator in response to the operator's interaction with the surface features.
  • the netpage system relies on the production of, and human interaction with, netpages. These are pages of text, graphics and images printed on ordinary paper, but which work like interactive webpages. Information is encoded on each page using ink which is substantially invisible to the unaided human eye.
  • the ink can be sensed by an optically imaging sensing device (or reader) and transmitted to the netpage system.
  • the sensing device may take the form of a clicker (for clicking on a specific position on a surface), a pointer having a stylus (for pointing or gesturing on a surface using pointer strokes), or a pen having a marking nib (for marking a surface with ink when pointing, gesturing or writing on the surface).
  • pen or “netpage pen” are provided by way of example only. It will, of course, be appreciated that the pen may take the form of any of the sensing devices or readers described herein.
  • active buttons and hyperlinks on each page can be clicked with the sensing device to request information from the network or to signal preferences to a network server.
  • text written by hand on a netpage is automatically recognized and converted to computer text in the netpage system, allowing forms to be filled in.
  • signatures recorded on a netpage are automatically verified, allowing e-commerce transactions to be securely authorized.
  • text on a netpage may be clicked or gestured to initiate a search based on keywords indicated by the user.
  • a printed netpage 1 can represent a interactive form which can be filled in by the user both physically, on the printed page, and “electronically”, via communication between the pen and the netpage system.
  • the example shows a “Request” form containing name and address fields and a submit button.
  • the netpage 1 consists of graphic data 2 , printed using visible ink, and a surface coding pattern 3 superimposed with the graphic data.
  • the surface coding pattern 3 comprises a collection of tags 4 .
  • a typical tag 4 is shown in the shaded region of FIG. 1 , although it will be appreciated that contiguous tags 4 , defined by the coding pattern 3 , are densely tiled over the whole netpage 1 .
  • the corresponding page description 5 stored on the netpage network, describes the individual elements of the netpage. In particular it describes the type and spatial extent (zone) of each interactive element (i.e. text field or button in the example), to allow the netpage system to correctly interpret input via the netpage.
  • the submit button 6 for example, has a zone 7 which corresponds to the spatial extent of the corresponding graphic 8 .
  • a netpage sensing device 400 such as the pen described in Section 5, works in conjunction with a netpage relay device 601 , which is an Internet-connected device for home, office or mobile use.
  • the pen 400 is wireless and communicates securely with the netpage relay device 601 via a short-range radio link 9 .
  • the netpage pen 400 utilises a wired connection, such as a USB or other serial connection, to the relay device 601 .
  • the relay device 601 performs the basic function of relaying interaction data to a page server 10 , which interprets the interaction data.
  • the relay device 601 may, for example, take the form of a personal computer 601 a , a netpage printer 601 b or some other relay 601 c (e.g. personal computer or mobile phone incorporating a web browser).
  • the netpage printer 601 b is able to deliver, periodically or on demand, personalized newspapers, magazines, catalogs, brochures and other publications, all printed at high quality as interactive netpages.
  • the netpage printer is an appliance which can be, for example, wall-mounted adjacent to an area where the morning news is first consumed, such as in a user's kitchen, near a breakfast table, or near the household's point of departure for the day. It also comes in tabletop, desktop, portable and miniature versions. Netpages printed on-demand at their point of consumption combine the ease-of-use of paper with the timeliness and interactivity of an interactive medium.
  • the netpage relay device 601 may be a portable device, such as a mobile phone or PDA, a laptop or desktop computer, or an information appliance connected to a shared display, such as a TV. If the relay device 601 is not a netpage printer 601 b which prints netpages digitally and on demand, the netpages may be printed by traditional analog printing presses, using such techniques as offset lithography, flexography, screen printing, relief printing and rotogravure, as well as by digital printing presses, using techniques such as drop-on-demand inkjet, continuous inkjet, dye transfer, and laser printing.
  • traditional analog printing presses using such techniques as offset lithography, flexography, screen printing, relief printing and rotogravure, as well as by digital printing presses, using techniques such as drop-on-demand inkjet, continuous inkjet, dye transfer, and laser printing.
  • the netpage sensing device 400 interacts with a portion of the tag pattern on a printed netpage 1 , or other printed substrate such as a label of a product item 251 , and communicates, via a short-range radio link 9 , the interaction to the relay device 601 .
  • the relay 601 sends corresponding interaction data to the relevant netpage page server 10 for interpretation.
  • Raw data received from the sensing device 400 may be relayed directly to the page server 10 as interaction data.
  • the interaction data may be encoded in the form of an interaction URI and transmitted to the page server 10 via a user's web browser 601 c .
  • the web browser 601 c may then receive a URI from the page server 10 and access a webpage via a webserver 201 .
  • the page server 10 may access application computer software running on a netpage application server 13 .
  • the netpage relay device 601 can be configured to support any number of sensing devices, and a sensing device can work with any number of netpage relays.
  • each netpage sensing device 400 has a unique identifier. This allows each user to maintain a distinct profile with respect to a netpage page server 10 or application server 13 .
  • Netpage publication servers 14 on the netpage network are configured to deliver print-quality publications to netpage printers. Periodical publications are delivered automatically to subscribing netpage printers via pointcasting and multicasting Internet protocols. Personalized publications are filtered and formatted according to individual user profiles.
  • a netpage pen may be registered with a netpage registration server 11 and linked to one or more payment card accounts. This allows e-commerce payments to be securely authorized using the netpage pen.
  • the netpage registration server compares the signature captured by the netpage pen with a previously registered signature, allowing it to authenticate the user's identity to an e-commerce server. Other biometrics can also be used to verify identity.
  • One version of the netpage pen includes fingerprint scanning, verified in a similar way by the netpage registration server.
  • Netpages are the foundation on which a netpage network is built. They provide a paper-based user interface to published information and interactive services.
  • a netpage consists of a printed page (or other surface region) invisibly tagged with references to an online description 5 of the page.
  • the online page description 5 is maintained persistently by the netpage page server 10 .
  • the page description describes the visible layout and content of the page, including text, graphics and images. It also describes the input elements on the page, including buttons, hyperlinks, and input fields.
  • a netpage allows markings made with a netpage pen on its surface to be simultaneously captured and processed by the netpage system.
  • each netpage may be assigned a unique page identifier.
  • This page ID (or, more generally, region ID) has sufficient precision to distinguish between a very large number of netpages.
  • Each reference to the page description 5 is repeatedly encoded in the netpage pattern.
  • Each tag (and/or a collection of contiguous tags) identifies the unique page on which it appears, and thereby indirectly identifies the page description 5 .
  • Each tag also identifies its own position on the page. Characteristics of the tags are described in more detail below.
  • Tags are typically printed in infrared-absorptive ink on any substrate which is infrared-reflective, such as ordinary paper, or in infrared fluorescing ink. Near-infrared wavelengths are invisible to the human eye but are easily sensed by a solid-state image sensor with an appropriate filter.
  • a tag is sensed by a 2D area image sensor in the netpage sensing device, and the tag data is transmitted to the netpage system via the nearest netpage relay device 601 .
  • the pen 400 is wireless and communicates with the netpage relay device 601 via a short-range radio link. It is important that the pen recognize the page ID and position on every interaction with the page, since the interaction is stateless. Tags are error-correctably encoded to make them partially tolerant to surface damage.
  • the netpage page server 10 maintains a unique page instance for each unique printed netpage, allowing it to maintain a distinct set of user-supplied values for input fields in the page description 5 for each printed netpage 1 .
  • Each tag 4 identifies an absolute location of that tag within a region of a substrate.
  • each interaction with a netpage should also provide a region identity together with the tag location.
  • the region to which a tag refers coincides with an entire page, and the region ID is therefore synonymous with the page ID of the page on which the tag appears.
  • the region to which a tag refers can be an arbitrary subregion of a page or other surface. For example, it can coincide with the zone of an interactive element, in which case the region ID can directly identify the interactive element.
  • the region identity may be encoded discretely in each tag 4 .
  • the region identity may be encoded by a plurality of contiguous tags in such a way that every interaction with the substrate still identifies the region identity, even if a whole tag is not in the field of view of the sensing device.
  • Each tag 4 should preferably identify an orientation of the tag relative to the substrate on which the tag is printed. Orientation data read from a tag enables the rotation (yaw) of the pen 400 relative to the substrate to be determined
  • a tag 4 may also encode one or more flags which relate to the region as a whole or to an individual tag.
  • One or more flag bits may, for example, signal a sensing device to provide feedback indicative of a function associated with the immediate area of the tag, without the sensing device having to refer to a description of the region.
  • a netpage pen may, for example, illuminate an “active area” LED when in the zone of a hyperlink.
  • a tag 4 may also encode a digital signature or a fragment thereof.
  • Tags encoding (partial) digital signatures are useful in applications where it is required to verify a product's authenticity. Such applications are described in, for example, US Publication No. 2007/0108285, the contents of which is herein incorporated by reference.
  • the digital signature may be encoded in such a way that it can be retrieved from every interaction with the substrate.
  • the digital signature may be encoded in such a way that it can be assembled from a random or partial scan of the substrate.
  • tag size may also be encoded into each tag or a plurality of tags, as will be explained in more detail below.
  • the Netpage tag pattern is advantageously designed to be printed using the Applicant's high-resolution (1600 dpi) pagewidth inkjet printers.
  • the Netpage system complements the Applicant's inkjet printers, which are able to print Netpages having a high degree of functionality and position resolution via the printed tags 4 .
  • Netpages are printed using ‘Netpage-aware’ printers, which are specifically tailored for printing Netpages.
  • Netpage system is a generic page-based system that need not be inextricably tied to such printers.
  • Netpages should be printable using other types of printers, including existing lower resolution (e.g. 300 dpi) print-on-demand printers, such as laser printers and other inkjet printers.
  • Netpages should also be printable using traditional analogue printing presses, which use, for example, established offset, rotogravure or photogravure printing techniques.
  • position-coding patterns designed to be printed with high-resolution printers may not be printable using lower resolution printing technologies. If a dot spacing in the coding pattern is too small, then individual dots may not be resolvable by a relatively low resolution printing technology. Moreover, the resultant coding pattern, printed by a low-resolution printer, would not be readable by the Netpage pen 400 if adjacent dots are merged together.
  • the present invention therefore provides two variants of the Netpage position-coding pattern, both of which are readable by the same Netpage pen 400 .
  • a first position-coding pattern (dubbed “Yarrow” by the present Applicant) is suitable for printing by the Applicant's high-resolution (1600 dpi) pagewidth inkjet printers and has a high degree of functionality and resolution.
  • a second position-coding pattern (dubbed “Saffron” by the present Applicant) is suitable for printing by relatively low resolution (e.g. 300 dpi) printers and has a lower degree of functionality and resolution.
  • both the first and second position-coding patterns are readable by the Netpage pen 400 by virtue of features common to each pattern.
  • the Netpage pen 400 is able to determine whether it is reading the first or second position-coding pattern by decoding a registration symbol in each tag 4 , as will be explained in more detail below. Once the pen 400 has recognized the coding pattern it is reading, decoding of tag data can proceed in accordance with that particular coding pattern.
  • the netpage surface coding generally consists of a dense planar tiling of tags.
  • each tag 4 is represented by two kinds of elements.
  • the first kind of element is a target element.
  • Target elements in the form of target dots 301 allow a tag 4 to be located in an image of a coded surface, and allow the perspective distortion of the tag to be inferred.
  • the second kind of element is a data element in the form of a macrodot 302 (see FIG. 6 ).
  • the macrodots 302 encode data values.
  • the presence or absence of a macrodot was be used to represent a binary bit.
  • the tag structure of the first position-coding pattern encodes a data value using multi-pulse position modulation, which is described in more detail in Section 3.3.
  • the coding pattern 3 is represented on the surface in such a way as to allow it to be acquired by an optical imaging system, and in particular by an optical system with a narrowband response in the near-infrared.
  • the pattern 3 is typically printed onto the surface using a narrowband near-infrared ink.
  • FIG. 3 shows the structure of a complete tag 4 A from the first position-coding pattern, with target elements 301 shown.
  • the tag 4 A is square and contains sixteen target elements. Those target elements 301 located at the edges and corners of the tag (twelve in total) are shared by adjacent tags and define the perimeter of the tag.
  • the high number of target elements 301 advantageously facilitates accurate determination of a perspective distortion of the tag 4 when it is imaged by the sensing device 400 . This improves the accuracy of tag sensing and, ultimately, position determination.
  • the tag 4 A consists of a square array of nine symbol groups 303 .
  • Symbol groups 303 are demarcated by the target elements 301 so that each symbol group is contained within a square defined by four target elements. Adjacent symbol groups 303 are contiguous and share targets.
  • tags 4 A themselves are indistinguishable by viewing only the target elements. Hence, tags 4 A must be aligned with the target grid as part of tag decoding.
  • the tag 4 A is designed to allow all tag data, with the exception of an embedded data object (see Section 3.9.3), to be recovered from an imaging field of view substantially the size of the tag.
  • each of the nine symbol groups 303 comprises twelve data symbols 304 A, each data symbol being part of a codeword.
  • each symbol group 303 comprises a pair of registration symbols—a vertical registration symbol (‘VRS’) and a horizontal registration symbol (‘HRS’). These allow the orientation and/or translation of the tag 4 A in the field of view to be determined. Translation refers to the translation of tag(s) relative to the symbol groups 303 in the field of view. In other words, the registration symbols enable alignment of the ‘invisible’ tags with the target grid.
  • Each data symbol 304 A is a multi-pulse position modulated (PPM) data symbol.
  • PPM data symbol 304 A encodes a single 4-bit Reed-Solomon symbol using 3 macrodots in any of 6 positions ⁇ p 0 , p 1 , p 2 , p 3 , p 4 , p 5 ⁇ , i.e. using 3-6 pulse-position modulation (PPM).
  • PPM pulse-position modulation
  • PPM has a range of 20 codes, or 4.3 bits, and is used for Reed-Solomon data symbols and Reed-Solomon redundancy symbols.
  • Each symbol group also contains a 2-6 PPM vertical registration symbol (VRS) and a 2-6 PPM horizontal registration symbol (HRS). These allow the orientation and translation of the tag in the field of view to be determined. This is described in more detail in Section 3.6.1.
  • VRS vertical registration symbol
  • HRS horizontal registration symbol
  • FIG. 5 shows the layout for a 2-6 PPM or 3-6 PPM data symbol 304 .
  • Table 1 defines the mapping from 3-6 PPM symbol values to Reed-Solomon symbol values. Unused symbol values can be treated as erasures.
  • the spacing of macrodots 302 in both dimensions, as shown in FIG. 6 is specified by the parameter s. It has a nominal value of 127 ⁇ m, based on 8 dots printed at a pitch of 1600 dots per inch.
  • a macrodot 302 is nominally square with a nominal size of (4/8)s. However, it is allowed to vary in size by ⁇ 10% according to the capabilities of the device used to produce the pattern.
  • a target 301 is nominally circular with a nominal diameter of (12/8)s. However, it is allowed to vary in size by 110% according to the capabilities of the device used to produce the pattern.
  • Each symbol group 303 has a width of 10s. Therefore, each tag 4 A has a width of 30s and a length of 30s. However, it should be noted from FIG. 3 that the tag 4 A is configured so that some data symbols 304 A extend beyond the perimeter edge of the tag 4 A by one macrodot unit (is), and interlock with complementary data symbols from adjacent tags. This arrangement provides a tessellated pattern of data symbols 304 A within the target grid. From a data acquisition standpoint, tessellation of data symbols in this way increases the effective length of each tag 4 A by one macrodot unit.
  • the macrodot spacing, and therefore the overall scale of the tag pattern is allowed to vary between 127 ⁇ m and 120 ⁇ m according to the capabilities of the device used to produce the pattern. Any deviation from the nominal scale is recorded in each tag (via a macrodot size ID field) to allow accurate generation of position samples.
  • the tag 4 A is designed to allow all tag data to be recovered from an imaging field of view roughly the size of the tag. Any data common to a set of contiguous tags only needs to appear once within each tag, since fragments of the common data can be recovered from adjacent tags. Any data common only to a column or row of tags may appear twice within the tag—i.e. once in each horizontal half or vertical half of the tag respectively. However, special symbol arrangements may be used to ameliorate this requirement, as described in more detail in Section 3.6.3. Finally, any data unique to the tag must appear four times within the tag—i.e. once in each quadrant.
  • pulse-position modulated values are best decoded from spatially-coherent samples (i.e. from a whole symbol as opposed to partial symbols at opposite sides of the field of view), since this allows raw sample values to be compared without first being normalised. This implies that the field of view must be large enough to contain two complete copies of each such pulse-position modulated value.
  • the tag is designed so that the maximum extent of a pulse-position modulated value is three macrodots (see FIG. 3 ). Making the field of view at least as large as the tag plus three macrodot units guarantees that pulse-position modulated values can be coherently sampled.
  • each symbol in FIGS. 8 to 12 is shown with a unique label.
  • the label consists of an alphabetic prefix which identifies which codeword the symbol is part of, and a numeric suffix which indicates the index of the symbol within the codeword. For simplicity only data symbols 304 A are shown, not registration symbols.
  • Each registration symbol is encoded using 2-6 PPM.
  • FIG. 7 shows the layout of the registration symbol.
  • the horizontal and vertical registration symbols each appear once within a symbol group 303 .
  • the registration symbols of an entire tag typically indicate the vertical and horizontal translation of the tag by coding two orthogonal translation codes, and the orientation of the tag by coding two orthogonal direction codes.
  • Each registration symbol may also encode a one-bit symbol of a flag code (see Section 3.6.2).
  • Table 2 defines the mapping from 2-6 PPM registration symbol values to flag code, direction code and translation code symbol values.
  • the first position-coding pattern (“Yarrow”) uses the first eight registration symbol values in Table 2 i.e. those registration symbol values mapping to a translation code symbol value of 0, 1 or 2. In other words, if the registration symbol value maps to a translation code symbol value of 0, 1 or 2, then the position-coding pattern is identified as the first position-coding pattern having 9 symbol groups 303 contained in one tag 4 A.
  • the additional translation code symbol values (i.e. 3 and 4) shown in Table 2 are reserved for the second position-coding pattern (“Saffron”) described in Section 4.6.1.
  • the registration symbol value maps to a translation code symbol value of 3 or 4
  • the position-coding pattern is identified as the second position-coding pattern having 4 symbol groups 303 contained in one tag 4 B.
  • the registration symbol provides a means of distinguishing the first position-coding pattern from the second position-coding pattern.
  • Subsequent decoding of PPM data symbols proceeds in accordance with the position-coding pattern identified from decoding the registration symbol(s).
  • each row of symbol groups and each column of symbol groups encodes a three-symbol 3-ary cyclic position code.
  • the code consists of the codeword (0, 1, 2) and its cyclic shifts.
  • the code has a minimum distance of 3, allowing a single symbol error to be corrected.
  • the three translation codes of an entire tag form a code with a minimum distance of 9, allowing 4 symbol errors to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy.
  • the translation code symbol in the middle of the codeword (i.e. 1) is mapped to a set of 2-6 PPM symbol values that are each other's reverse, while the two translation code symbols at the ends of the codeword (i.e. 0 and 2) are each mapped to a set of 2-6 PPM symbol values that are the reverses of the 2-6 PPM symbol values in the other set.
  • a 0 read upside-down i.e. rotated 180 degrees
  • a 1 read upside-down remains a 1. This allows translation to be determined independently of rotation.
  • each 2-6 PPM symbol value and its reverse map to opposite direction code symbol values (Table 2).
  • Table 2 The vertical registration symbols of an entire tag encode 9 symbols of a vertical direction code. This has a minimum distance of 9, allowing 4 symbol errors to be corrected.
  • the horizontal registration symbols of an entire tag encode 9 symbols of a horizontal direction code This has a minimum distance of 9, allowing 4 symbol errors to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy. Any erasures detected during decoding of a translation code can also be used during decoding of a direction code, and vice versa. Together the orthogonal direction codes allow the orientation of the tag to be determined.
  • the top left corner of an un-rotated tag is identified by a symbol group whose translation symbols are both zero and whose direction symbols are both zero.
  • the flag symbol consists of one bit of data, and is encoded in some of the vertical and horizontal registration symbols, as shown in Table 2.
  • the flag symbol is unique to a tag and is therefore coded redundantly in each quadrant of the tag. Since the flag symbol is encoded in each registration code symbol, it appears four times within each quadrant (assuming the central registration code symbols participate in each quadrant, as usually supported by the minimum field of view). Four symbols form a code with a minimum distance of 4, allowing 1 error to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy. Any errors detected during decoding of translation and/or direction codes can also be used to flag erasures during decoding of the flag code. Since the flag code encodes the active area flag, it can meaningfully be interpreted as set even if ambiguous.
  • the tag 4 A contains an x-coordinate codeword and a y-coordinate codeword used to encode the x and y coordinates of the tag respectively.
  • the codewords are of a shortened 2 4 -ary (11, 3) or (11, 5) Reed-Solomon code.
  • the tag therefore encodes either 12-bit or 20-bit coordinates.
  • An (11, 5) code is used if the ⁇ region has long coordinates> flag in the region flags is set (see Table 5).
  • An (11, 3) code is used otherwise.
  • Each x coordinate codeword is replicated twice within the tag—in each horizontal half (“north” and “south”), and is constant within the column of tags containing the tag.
  • each y coordinate codeword is replicated twice within the tag—in each vertical half (“east” and “west”), and is constant within the row of tags containing the tag. This guarantees that an image of the tag pattern large enough to contain a complete tag is guaranteed to contain a complete instance of each coordinate codeword, irrespective of the alignment of the image with the tag pattern.
  • the instance of either coordinate codeword may consist of fragments from different tags.
  • the layout of the x-coordinate codeword is shown in FIG. 8 .
  • the layout of the y-coordinate codeword is shown in FIG. 9 . It can be seen that x-coordinate symbols X 4 , X 5 , X 6 , X 7 , X 8 and X 9 are placed in a central column 310 of the tag 4 A, which divides the eastern half of the tag from the western half. Likewise, the y-coordinate symbols Y 4 , Y 5 , Y 6 , Y 7 , Y 8 and Y 9 are placed in a central row 312 of the tag 4 A, which divides the northern half of the tag from the southern half.
  • the central column 310 and central row 312 each have a width q, which corresponds to a width of 2s, where s is the macrodot spacing.
  • the tag 4 A contains four codewords A, B, C and D which encode information common to a set of contiguous tags in a surface region.
  • the A codeword is of a 2 4 -ary (15, 5) Reed-Solomon code.
  • the B, C and D codewords are of a 2 4 -ary (15, 7) or (15, 9) Reed-Solomon code.
  • the tag therefore encodes either 112 or 136 bits of information common to a set of contiguous tags.
  • a (15, 9) code is used for the B, C and D codewords if the ⁇ region has a long region ID> flag in the region flags is set (see Table 6).
  • a (15, 7) code is used otherwise.
  • the common codewords are replicated throughout a tagged region. This guarantees that an image of the tag pattern large enough to contain a complete tag is guaranteed to contain a complete instance of each common codeword, irrespective of the alignment of the image with the tag pattern.
  • the instance of each common codeword may consist of fragments from different tags.
  • the layout of the common codewords is shown in FIG. 10 .
  • the codewords have the same layout, rotated 90 degree relative to each other.
  • the tag optionally contains a codeword E.
  • This codeword may be used to encode a secret-key signature or a fragment of an embedded data object. These are discussed further in Sections 3.6.6 and Section 3.9.3 respectively.
  • the codeword is of a 2 4 -ary (15, 9) Reed-Solomon code.
  • the layout of the optional codeword is shown in FIG. 11 .
  • the tag optionally contains an entire secret-key digital signature common to a set of contiguous tags in a surface region.
  • the signature consists of sixteen 2 4 -ary symbols (i.e. symbol E 15 is also used).
  • the tag therefore optionally encodes up to 64 bits of secret-key signature data.
  • the signature is replicated throughout a tagged region. This guarantees that an image of the tag pattern large enough to contain a complete tag is guaranteed to contain a complete instance of the signature, irrespective of the alignment of the image with the tag pattern.
  • the instance of the signature may consist of fragments from different tags.
  • the signature if present, is encoded in the E codeword described in Section 3.6.5.
  • FIG. 12 shows the layout of the data of a complete tag, with each symbol group comprising ten data symbols. The vertical and horizontal registration symbols are not shown in FIG. 12 .
  • All data is encoded using a Reed-Solomon code defined over GF(2 4 ).
  • the code has a natural length n of 15.
  • the dimension k of the code is chosen to balance the error correcting capacity and data capacity of the code, which are (n ⁇ k)/2 and k symbols respectively.
  • the code may be punctured, by removing high-order redundancy symbols, to obtain a code with reduced length and reduced error correcting capacity.
  • the code may also be shortened, by replacing high-order data symbols with zeros, to obtain a code with reduced length and reduced data capacity. Both puncturing and shortening can be used to obtain a code with particular parameters. Shortening is preferred, where possible, since this avoids the need for erasure decoding.
  • the code has the following primitive polynomial:
  • the code has the following generator polynomial:
  • Reed-Solomon codes For a detailed description of Reed-Solomon codes, refer to Wicker, S. B. and V. K. Bhargava, eds., Reed-Solomon Codes and Their Applications, IEEE Press, 1994.
  • redundancy coordinates r i and data coordinates di of the code are indexed from left to right according to the power of their corresponding polynomial terms.
  • the symbols X i of a complete codeword are indexed from right to left to match the bit order of the data.
  • the bit order within each symbol is the same as the overall bit order.
  • Table 3 defines the parameters of the different codes used in the tag.
  • the region ID is protected by a 16-bit cyclic redundancy check (CRC).
  • CRC cyclic redundancy check
  • the CRC has the following generator polynomial:
  • the CRC is initialised to 0xFFFF.
  • the most significant bit of the region ID is treated as the most significant coefficient of the data polynomial.
  • the tag coordinate space has two orthogonal axes labelled x and y respectively. When the positive x axis points to the right then the positive y axis points down.
  • the surface coding does not specify the location of the tag coordinate space origin on a particular tagged surface, nor the orientation of the tag coordinate space with respect to the surface.
  • This information is application-specific. For example, if the tagged surface is a sheet of paper, then the application which prints the tags onto the paper may record the actual offset and orientation, and these can be used to normalise any digital ink subsequently captured in conjunction with the surface.
  • the position encoded in a tag is defined in units of tags and is defined to be the centre of the top left target.
  • the origin of a particular tag pattern is therefore the centre of the top left target of the tag that encodes coordinate pair (0, 0).
  • the surface coding is optionally displaced from its nominal position relative to the surface by an amount derived from the region ID. This ensures that the utilisation of a pagewidth digital printhead used to print the surface coding is uniform.
  • the displacement of the surface coding is negative, hence the displacement of the region described by the surface coding is positive relative to the surface coding.
  • the magnitude of the displacement is the region ID modulo the width of the tag in 1600 dpi dots (i.e. 240). To accommodate non-1600 dpi printers the actual magnitude of the displacement may vary from its nominal value by up to half the dot pitch of the printer.
  • Table 4 defines the information fields embedded in the first position-coding pattern.
  • width field (bits) description unique to tag active area flag 1 A flag indicating whether the area a immediately surrounding a tag intersects an active area.
  • Other values are reserved region flags 10 Flags controlling the interpretation of region data (see Table 5).
  • coordinate 2 A value (p) indicating the precision of x and y precision coordinates according to the formula 8 + 4p.
  • macrodot size 4 The ID of the macrodot size. ID region ID 72 or The ID of the region containing the tags.
  • secret-key 64 An optional secret-key signature of the region. signature a the diameter of the area, centered on the tag, is nominally 2.5 times the diagonal size of the tag; this is to accommodate the worst-case distance between the nib position and the imaged tag b allows a coordinate value ranges of 14.8 m and 3.8 km for the minimum tag size of 3.6 mm (based on the minimum macrodot size of 120 microns and 30 macrodots per tag)
  • An active area is an area within which any captured input should be immediately forwarded to the corresponding Netpage server 10 for interpretation. This also allows the Netpage server 10 to signal to the user that the input has had an immediate effect. Since the server has access to precise region definitions, any active area indication in the surface coding can be imprecise so long as it is inclusive.
  • Table 6 Table 7 and Table 8 define how the information fields map to codewords in the first position-coding pattern.
  • codeword E either contains a data fragment or a secret-key signature. These are described in Section 3.9.3 and Section 3.9.4 respectively.
  • the secret-key signature is present in a particular tag if the ⁇ region has secret-key signature> flag in the region flags is set, and the tag's active area flag is set.
  • the data fragment is present in a particular tag if the ⁇ region contains embedded data> flag in the region flags is set and the tag does not already contain a secret-key signature.
  • the region flags indicate that a particular codeword is absent then the codeword is not coded in the tag pattern, i.e. there are no macrodots representing the codeword.
  • the E codeword is present if a secret-key signature or data fragment is present.
  • the surface coding contains embedded data.
  • the embedded data is encoded in multiple contiguous tags' data fragments, and is replicated in the surface coding as many times as it will fit.
  • the embedded data is encoded in such a way that a random and partial scan of the surface coding containing the embedded data can be sufficient to retrieve the entire data.
  • the scanning system reassembles the data from retrieved fragments, and reports to the user when sufficient fragments have been retrieved without error.
  • each block has a data capacity of 176-bits.
  • the block data is encoded in the data fragments of a contiguous group of six tags arranged in a 3 ⁇ 2 rectangle.
  • the block parameters are as defined in Table 9.
  • the E codeword of each tag may encode a fragment of the embedded data.
  • Block parameters parameter value description w 3 The width of the block, in tags h 2 The height of the block, in tags. b 176 The data capacity of the block, in bits
  • the pen 400 can discover this implicitly by the failure of the codeword to decode, or explicitly from the tag's active area flag.
  • Data of arbitrary size may be encoded into a superblock consisting of a contiguous set of blocks, typically arranged in a rectangle.
  • the size of the superblock may be encoded in each block.
  • the superblock is replicated in the surface coding as many times as it will fit, including partially along the edges of the surface coding.
  • the data encoded in the superblock may include, for example, more precise type information, more precise size information, and more extensive error detection and/or correction data.
  • a region may contain a digital signature.
  • the region has a secret-key digital signature.
  • the secret-key signature can be verified, in conjunction with the region ID, by querying a server with knowledge of the secret-key signature or the corresponding secret key.
  • the surface coding contains an embedded public-key digital signature of the region ID.
  • any number of signature fragments can be used, in conjunction with the region ID and optionally the secret-key signature, to validate the public-key signature by querying a server with knowledge of the full public-key signature or the corresponding private key.
  • the entire public-key signature can be recovered by reading multiple tags, and can then be verified using the corresponding public signature key.
  • the actual length and type of the signature are determined from the region ID during signature validation i.e. typically from a previously-retrieved digital signature associated with a sequence of region IDs.
  • the minimum imaging field of view required to guarantee acquisition of data from an entire tag 4 A has a diameter of 46.7s (i.e. ((3 ⁇ 10)+3) ⁇ 2s), allowing for arbitrary rotation and translation of the surface coding in the field of view.
  • the imaging field of view does not have to be large enough to guarantee capture of an entire tag—the arrangement of the data symbols within each tag ensures that a any square portion of length (l+3s) captures the requisite information in full, irrespective of whether a whole tag is actually visible in the field-of-view.
  • l is defined as the length of a tag.
  • the imaging field-of-view is typically a circle. Accordingly, the imaging field-of-view should preferably have diameter of at least (l+3s) ⁇ 2 and less than two tag diameters. Importantly, the field-of-view is not required to be at least two tag diameters, in contrast with prior art tag designs, because it is not essential to capture an entire tag 4 A in the field of view.
  • the extra three macrodot units ensure that pulse-position modulated values can be decoded from spatially coherent samples. Furthermore, the extra three macrodot units ensure that all requisite data symbols 304 A can be read with each interaction. These include the coordinate symbols from a central column or row of a tag (see Section 3.6.3) having a width of 2s.
  • a “tag diameter” is given to mean the length of a tag diagonal.
  • the second position-coding pattern bears many similarities with the first position coding pattern. The most notable difference is that each tag comprises 4 rather than 9 symbol groups 303 . Furthermore, the registration symbols in the second position-coding pattern map to translation code symbol values (3, 4) specifically identifying the second position-coding pattern, as described earlier in Section 3.6.1.
  • each tag 4 B of the second position-coding pattern is represented by two kinds of elements.
  • the first kind of element is a target element.
  • Target elements in the form of target dots 301 allow the tag 4 B to be located in an image of a coded surface, and allow the perspective distortion of the tag to be inferred.
  • the second kind of element is a data element in the form of a macrodot 302 (see FIG. 6 ).
  • the macrodots 302 encode data values.
  • FIG. 14 shows the structure of a complete tag 4 B from the second position-coding pattern, with target elements 301 shown.
  • the tag 4 B is square and contains nine target elements. Those target elements 301 located at the edges and corners of the tag (eight in total) are shared by adjacent tags and define the perimeter of the tag 4 B.
  • the tag 4 B consists of a square array of four symbol groups 303 .
  • Symbol groups 303 are demarcated by the target elements 301 so that each symbol group is contained within a square defined by four target elements. Adjacent symbol groups 303 are contiguous and share targets.
  • the target elements 301 are all identical, they do not demarcate one tag from its adjacent tags. Viewed purely at the level of target elements, only symbol groups 303 , which define cells of a target grid, can be distinguished—the tags 4 B themselves are indistinguishable by viewing only the target elements. Hence, tags 4 B must be aligned with the target grid as part of tag decoding.
  • the tag 4 B is designed to allow all tag data to be recovered from an imaging field of view substantially the size of the tag.
  • each of the nine symbol groups 303 comprises eight data symbols 304 B, each data symbol being part of a codeword.
  • each symbol group 303 comprises a pair of registration symbols—a vertical registration symbol (‘VRS’) and a horizontal registration symbol (‘HRS’). These allow the orientation and/or translation of the tag 4 B in the field of view to be determined.
  • VRS vertical registration symbol
  • HRS horizontal registration symbol
  • Each data symbol 304 B is a multi-pulse position modulated (PPM) data symbol.
  • PPM data symbol 304 B encodes 5-bits using 2-9 PPM encoding. i.e. 2 macrodots in any of 9 positions ⁇ p 0 , p 2 , p 3 , p 4 , p 5 , p 6 , p 7 , p 8 ⁇
  • FIG. 16 shows the layout for a 2-9 PPM data symbol 304 B.
  • Each symbol group also contains a 2-6 PPM vertical registration symbol (VRS) and a 2-6 PPM horizontal registration symbol (HRS), as described in Sections 3.3 and 3.6.1 above.
  • VRS vertical registration symbol
  • HRS 2-6 PPM horizontal registration symbol
  • Table 10 defines the mapping from 2-6 PPM symbol values to data symbol values. Unused symbol values can be treated as erasures.
  • the spacing of macrodots 302 in both dimensions, as shown in FIG. 6 , is specified by the parameter s.
  • the second position-coding pattern it has a nominal value of 159 ⁇ m, based on 10 dots printed at a pitch of 1600 dots per inch.
  • a macrodot 302 is nominally square with a nominal size of (5/10)s. However, it is allowed to vary in size by 110% according to the capabilities of the device used to produce the pattern.
  • a target 301 is nominally circular with a nominal diameter of (15/10)s. However, it is allowed to vary in size by 110% according to the capabilities of the device used to produce the pattern.
  • Each symbol group 303 has a width of 10s. Therefore, each tag 4 B has a width of 20s and a length of 20s. However, it should be noted from FIG. 15 that the tag 4 B is configured so that some data symbols 304 extend beyond the perimeter edge of the tag 4 B by one macrodot unit (1s), and interlock with complementary data symbols from adjacent tags. This arrangement provides a tessellated pattern of data symbols 304 A within the target grid. From a data acquisition standpoint, tessellation of data symbols in this way increases the effective length of each tag 4 B by one macrodot unit.
  • the macrodot spacing, and therefore the overall scale of the tag pattern is allowed to vary between 152 ⁇ m and 169 ⁇ m according to the capabilities of the device used to produce the pattern. Any deviation from the nominal scale is recorded in each tag (via a macrodot size ID field) to allow accurate generation of position samples.
  • the tag 4 B is designed to allow all tag data to be recovered from an imaging field of view roughly the size of the tag.
  • pulse-position modulated values are best decoded from spatially-coherent samples (i.e. from a whole symbol as opposed to partial symbols at opposite sides of the field of view), since this allows raw sample values to be compared without first being normalised. This implies that the field of view must be large enough to contain two complete copies of each such pulse-position modulated value.
  • the tag is designed so that the maximum extent of a pulse-position modulated value is four macrodots. Making the field of view at least as large as the tag plus four macrodot units guarantees that pulse-position modulated values can be coherently sampled.
  • each symbol in FIGS. 17 to 20 is shown with a unique label.
  • the label consists of an alphabetic prefix which identifies which codeword the symbol is part of, and a numeric suffix which indicates the index of the symbol within the codeword.
  • data symbols 304 B are shown in FIGS. 17 to 20 , not registration symbols.
  • Each registration symbol of the second position-coding pattern is encoded using 2-6 PPM, as described above in Section 3.6.1 and FIG. 7 . Furthermore, each registration symbol of the second position-coding pattern is positioned and configured in the same way as each registration symbol of the first position-coding pattern. However, the second position-coding pattern utilizes only those registration symbol values mapping to the translation code symbol values (3, 4). This enables the registration symbol to identify the second position-coding pattern, and distinguish it from the first position-coding pattern.
  • the position-coding pattern is identified as the second position-coding pattern having 4 symbol groups 304 B contained in one tag 4 B.
  • each row of symbol groups and each column of symbol groups encodes a two-symbol 2-ary cyclic position code.
  • the Applicant's cyclic position codes are described in U.S. Pat. No. 7,082,562, the contents of which is herein incorporated by reference).
  • the code consists of the codeword (3, 4) and its cyclic shifts.
  • the two translation codes of an entire tag form a code with a minimum distance of 4, allowing 1 symbol error to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy.
  • the two translation code symbols (3 and 4) are each mapped to a set of 2-6 PPM symbol values that are the reverses of the 2-6 PPM symbol values in the other set.
  • a 3 read upside-down i.e. rotated 180 degrees
  • a 4 read upside-down becomes a 4, and vice versa. This allows translation to be determined independently of rotation.
  • each 2-6 PPM symbol value and its reverse map to opposite direction code symbol values (Table 2).
  • Table 2 The vertical registration symbols of an entire tag encode 4 symbols of a vertical direction code. This has a minimum distance of 4, allowing 1 symbol error to be corrected.
  • the horizontal registration symbols of an entire tag encode 4 symbols of a horizontal direction code This has a minimum distance of 4, allowing 1 symbol error to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy. Any erasures detected during decoding of a translation code can also be used during decoding of a direction code, and vice versa. Together the orthogonal direction codes allow the orientation of the tag to be determined.
  • the top left corner of an un-rotated tag is identified by a symbol group whose translation symbols are both zero and whose direction symbols are both zero.
  • the 2-6 PPM registration symbol does not allow flag codes for the second position-coding pattern
  • a 3-6 PPM registration symbol mapping to 20 available symbol values would allow the second position-coding pattern to contain flag codes, if desired.
  • 12 registration symbol values (3 ⁇ 2 ⁇ 2) would be used for the first position-coding pattern and 8 registration symbols value (2 ⁇ 2 ⁇ 2) would be used for the second position-coding pattern.
  • the tag 4 B contains an x-coordinate codeword and a y-coordinate codeword used to encode the x and y coordinates of the tag respectively.
  • the codewords are of a shortened 2 5 -ary (4, 2) Reed-Solomon code.
  • the tag therefore encodes 10-bit coordinates.
  • Each x coordinate codeword is constant within the column of tags containing the tag.
  • each y coordinate codeword is constant within the row of tags containing the tag.
  • FIG. 17 shows the layout of an x-coordinate codeword X.
  • the outline of the codeword X is shown in bold.
  • the entire x-coordinate codeword is encoded by data symbols X 0 , X 1 , X 2 and X 3 contained in a single column 313 of width v.
  • the entire y-coordinate codeword is encoded by data symbols Y 0 , Y 1 , Y 2 and Y 3 contained in a single row 315 of width v.
  • the column of x-coordinate symbols and the row of y-coordinate symbols each have a width v, which corresponds to a width of 3s, where s is the macrodot spacing.
  • the tag 4 B contains one codeword A which encodes information common to a set of contiguous tags in a surface region.
  • the A codeword is of a shortened 2 5 -ary (24, 16) Reed-Solomon code.
  • the tag 4 B therefore encodes 80 bits of information common to a set of contiguous tags.
  • the common codeword is replicated throughout a tagged region. This guarantees that an image of the tag pattern large enough to contain a complete tag is guaranteed to contain a complete instance of the common codeword, irrespective of the alignment of the image with the tag pattern.
  • the instance of the common codeword may consist of fragments from different tags.
  • the layout of the common codeword is shown in FIG. 19 .
  • FIG. 20 shows the layout of the data of a complete tag 4 B, with each symbol group comprising eight data symbols. The vertical and horizontal registration symbols are not shown in FIG. 20 .
  • All data of the second position-coding pattern is encoded using a Reed-Solomon code defined over GF(2 5 ).
  • the code has a natural length n of 31.
  • the dimension k of the code is chosen to balance the error correcting capacity and data capacity of the code, which are (n ⁇ k)/2 and k symbols respectively.
  • the code may be punctured, by removing high-order redundancy symbols, to obtain a code with reduced length and reduced error correcting capacity.
  • the code may also be shortened, by replacing high-order data symbols with zeros, to obtain a code with reduced length and reduced data capacity. Both puncturing and shortening can be used to obtain a code with particular parameters. Shortening is preferred, where possible, since this avoids the need for erasure decoding.
  • the code has the following primitive polynomial:
  • the code has the following generator polynomial:
  • Reed-Solomon codes For a detailed description of Reed-Solomon codes, refer to Wicker, S. B. and V. K. Bhargava, eds., Reed-Solomon Codes and Their Applications, IEEE Press, 1994.
  • redundancy coordinates r i and data coordinates di of the code are indexed from left to right according to the power of their corresponding polynomial terms.
  • the symbols X i of a complete codeword are indexed from right to left to match the bit order of the data.
  • the bit order within each symbol is the same as the overall bit order.
  • Table 11 defines the parameters of the different codes used in the tag 4 B.
  • the region ID is protected by a 16-bit cyclic redundancy check (CRC).
  • CRC cyclic redundancy check
  • the CRC has the following generator polynomial:
  • the CRC is initialised to 0xFFFF.
  • the most significant bit of the region ID is treated as the most significant coefficient of the data polynomial.
  • the tags 4 B of the second position-coding pattern use a coordinate space corresponding to the first position-coding pattern having two orthogonal axes labelled x and y respectively.
  • Table 12 defines the information fields embedded in the second position-coding pattern.
  • CRC 16 A CRC of the region ID (see Section 4.7.4) a allows a coordinate value ranges of 3.1 m for the minimum tag size of 3.04 mm (based on the minimum macrodot size of 152 microns and 20 macrodots per tag)
  • Tables 14 and 15 define how the information fields map to codewords in the second position-coding pattern.
  • the region flags indicate that a particular codeword is absent then the codeword is not coded in the tag pattern, i.e. there are no macrodots representing the codeword. This applies to the X and Y i.e. the X and Y codewords are present if the ⁇ region is interactive> flag in the region flags is set.
  • the minimum imaging field of view required to guarantee acquisition of data from an entire tag 4 B has a diameter of 33.9s (i.e. ((2 ⁇ 10)+4) ⁇ 2s), allowing for arbitrary rotation and translation of the surface coding in the field of view.
  • the imaging field of view does not have to be large enough to guarantee capture of an entire tag—the arrangement of the data symbols within each tag ensures that a any square portion of length (l+4s) captures the requisite information in full, irrespective of whether a whole tag is actually visible in the field-of-view.
  • l is defined as the length of a tag.
  • the imaging field-of-view is typically a circle. Accordingly, the imaging field-of-view should preferably have diameter of at least (l+4s) ⁇ 2 and less than two tag diameters. Importantly, the field-of-view is not required to be at least two tag diameters, in contrast with prior art tag designs, because it is not essential to capture an entire tag 4 B in the field of view.
  • the extra four macrodot units ensure that pulse-position modulated values can be decoded from spatially coherent samples. Furthermore, the extra four macrodot units ensure that all requisite data symbols 304 B can be read with each interaction. These include the coordinate symbols from a column or row of a tag (see Section 4.6.2) having a width of 3s.
  • a “tag diameter” is given to mean the length of a tag diagonal.
  • a field of view of at least 5.93 mm is sufficient to capture data from an entire tag 4 A from the first position-coding pattern or an entire tag 4 B from the second position-coding pattern.
  • the requisite field of view for capturing either tag 4 A or tag 4 B will vary depending on the macrodot spacing in either the first or second position coding patterns. This, in turn, depends on the print resolution of a printer used to print the respective position-coding pattern.
  • FIG. 22 shows a tag image processing and decoding process flow up to the stage of sampling registration symbols and decoding the translation codewords.
  • a raw image 802 of the tag pattern is acquired (at 800 ), for example via an image sensor such as a CCD image sensor, CMOS image sensor, or a scanning laser and photodiode image sensor.
  • the raw image 802 is then typically enhanced (at 804 ) to produce an enhanced image 806 with improved contrast and more uniform pixel intensities.
  • Image enhancement may include global or local range expansion, equalization, and the like.
  • the enhanced image 806 is then typically filtered (at 808 ) to produce a filtered image 810 .
  • Image filtering may consist of low-pass filtering, with the low-pass filter kernel size tuned to obscure macrodots 302 but to preserve targets 301 .
  • the filtering step 808 may include additional filtering (such as edge detection) to enhance target features 301 .
  • Encoding of data symbols 304 using pulse position modulation (PPM) provides a more uniform coding pattern 3 than simple binary dot encoding (as described in, for example, U.S. Pat. No. 6,832,717).
  • PPM pulse position modulation
  • the filtered image 810 is then processed (at 812 ) to locate the targets 301 .
  • This may consist of a search for target features whose spatial inter-relationship is consistent with the known geometry of the tag pattern (i.e. targets positioned at the corners of square cells).
  • Candidate targets may be identified directly from maxima in the filtered image 810 , or may be the subject of further characterization and matching, such as via their (binary or grayscale) shape moments (typically computed from pixels in the enhanced image 806 based on local maxima in the filtered image 810 ), as described in U.S. Pat. No. 7,055,739, the contents of which is herein incorporated by reference.
  • the identified targets 301 are then assigned (at 816 ) to a target grid 818 .
  • Each cell of the grid 818 contains a symbol group 303 , and several symbol groups will of course be visible in the image.
  • individual tags 4 will not be identifiable in the target grid 818 , since the targets 301 do not themselves demarcate one tag from another.
  • the perspective transform of the captured image must be inferred.
  • Four of the targets 301 are taken to be the perspective-distorted corners of a square of known size in tag space, and the eight-degree-of-freedom perspective transform 822 is inferred (at 820 ), based on solving the well-understood equations relating the four tag-space and image-space point pairs.
  • Calculation of the 2D perspective transform is described in detail in, for example, Applicant's U.S. Pat. No. 6,832,717, the contents of which is herein incorporated by reference.
  • each image of either the first or second position-coding pattern will typically contain at least 9 targets arranged in a square grid, the accuracy of calculating the 2D perspective transform is improved compared to the Applicant's previous tag designs described in, for example, U.S. Pat. No. 6,832,717. Hence, more accurate position calculation can be achieved with the tag design of the present invention.
  • the inferred tag-space to image-space perspective transform 822 is used to project each known macrodot position in tag space into image space. Since all bits in the tags are represented by PPM-encoding, the presence or absence of each macrodot 302 can be determined using a local intensity reference, rather than a separate intensity reference. Thus, PPM-encoding provides improved data sampling compared with pure binary encoding.
  • the next stage determines a type of position-coding pattern being imaged by the pen 400 from a translation codeword. In other words, this stage distinguishes the first position-coding pattern from the second position-coding pattern for subsequent sampling and decoding.
  • Two or more orthogonal registration symbols (‘VRS’ and ‘HRS’) are sampled (at 824 ), to allow decoding of the orthogonal translation codewords and the orthogonal direction codewords.
  • a flag symbol value may also be decoded subsequently from the decoded registration symbols.
  • Decoding of the orthogonal translation codewords yields either a (0, 1, 2) translation codeword or a (3, 4) translation codeword (at 830 ).
  • the (0, 1, 2) translation codeword indicates nine symbol groups per tag, thereby identifying (at 832 A) the imaged position-coding pattern as being the first position-coding pattern (“Yarrow”) containing tags 4 A.
  • the (3, 4) translation codeword indicates four symbol groups per tag, thereby identifying (at 832 B) the imaged position-coding pattern as being the second position-coding pattern (“Saffron”) containing tags 4 B.
  • the decoded orthogonal translation codewords are used to determine the translation of tags(s) in the field of view relative to the target grid 818 .
  • This enables alignment of the tags 4 A or 4 B with the target grid 818 , thereby allowing individual tag(s), or portions thereof, to be distinguished in the coding pattern 3 in the field of view.
  • the tags 4 A each containing nine symbol groups
  • the tags 4 B are aligned (at 834 B) with the target grid 818 .
  • each symbol group 303 contains orthogonal registration symbols, multiple translation codes can be decoded to provide robust translation determination.
  • the translation code is a cyclic position code. Since each row and each column of a tag contains M symbol groups, the code has minimum distance M ⁇ M. This allows robust determination of the alignment of tags 4 A or 4 B with the target grid 818 . The alignment needs to be both robust and accurate since there are many possible alignments when each tag contains multiple symbol groups 303 .
  • At 836 A or 836 B At least two orthogonal direction codes are decoded (at 836 A or 836 B) to provide the orientation 838 A or 838 B.
  • N vertical registration symbols in a tag form a vertical direction code with minimum distance N
  • the vertical direction code is capable of correcting (N ⁇ 1)/2 errors.
  • the horizontal direction code is similarly capable of correcting (N ⁇ 1)/2 errors using N horizontal registration symbols.
  • orientation determination is very robust and capable of correcting errors, depending on the number of registration symbols sampled.
  • the data codewords can then be sampled and decoded (at 840 A or 840 B) to yield the requisite decoded codewords 842 A or 842 B.
  • Decoding of data codewords in the first position-coding pattern (“Yarrow”) typically proceeds as follows:
  • Decoding of data codewords in the second position-coding pattern (“Saffron”) typically proceeds as follows:
  • Region ID decoding need not occur at the same rate as position decoding.
  • the interaction data sent from the pen 400 to the netpage system may include other data e.g. digital signature (see Section 3.9.4), pen mode (see US 2007/125860 incorporated herein by reference), orientation data, force data, pen ID, nib ID etc.
  • the active sensing device (or “reader”) of the netpage system may take the form of a clicker (for clicking on a specific position on a surface), a pointer having a stylus (for pointing or gesturing on a surface using pointer strokes), or a pen having a marking nib (for marking a surface with ink when pointing, gesturing or writing on the surface).
  • a clicker for clicking on a specific position on a surface
  • a pointer having a stylus for pointing or gesturing on a surface using pointer strokes
  • a pen having a marking nib for marking a surface with ink when pointing, gesturing or writing on the surface.
  • the present invention may utilize any suitable optical reader.
  • the Netpage pen 400 will be described herein as one such example.
  • either the first position-coding pattern (as described in Section 3) or the second position-coding pattern (as described in Section 4) may be read using the same Netpage pen 400 using the image processing and decoding steps described in Section 4.11.
  • the Netpage pen 400 is a motion-sensing writing instrument which works in conjunction with a tagged Netpage surface containing either the first or second position-coding patterns.
  • the pen 400 incorporates a conventional ballpoint pen cartridge for marking the surface, an image sensor and processor for simultaneously capturing the absolute path of the pen on the surface and identifying the surface, a force sensor for simultaneously measuring the force exerted on the nib, and a real-time clock for simultaneously measuring the passage of time.
  • the pen While in contact with a tagged surface, as indicated by the force sensor, the pen continuously images the surface region adjacent to the nib, and decodes the nearest tag in its field of view to determine both the identity of the surface, its own instantaneous position on the surface and the pose of the pen. The pen thus generates a stream of timestamped position samples relative to a particular surface, and transmits this stream to the Netpage server 10 .
  • the sample stream describes a series of strokes, and is conventionally referred to as digital ink (DInk). Each stroke is delimited by a pen down and a pen up event, as detected by the force sensor. More generally, any data resulting from an interaction with a Netpage, and transmitted to the Netpage server 10 , is referred to herein as “interaction data”.
  • the pen samples its position at a sufficiently high rate (nominally 100 Hz) to allow a Netpage server to accurately reproduce hand-drawn strokes, recognise handwritten text, and verify hand-written signatures.
  • a sufficiently high rate nominally 100 Hz
  • the Netpage pen also supports hover mode in interactive applications.
  • hover mode the pen is not in contact with the paper and may be some small distance above the surface of the paper (or other substrate). This allows the position of the pen, including its height and pose to be reported.
  • hover mode behaviour can be used to move a cursor without marking the paper, or the distance of the nib from the coded surface could be used for tool behaviour control, for example an air brush function.
  • the pen includes a Bluetooth radio transceiver for transmitting digital ink via a relay device to a Netpage server.
  • a Bluetooth radio transceiver for transmitting digital ink via a relay device to a Netpage server.
  • the pen buffers captured digital ink in non-volatile memory.
  • the pen transmits digital ink in real time.
  • the pen is supplied with a docking cradle or “pod”.
  • the pod contains a Bluetooth to USB relay.
  • the pod is connected via a USB cable to a computer which provides communications support for local applications and access to Netpage services.
  • the pen is powered by a rechargeable battery.
  • the battery is not accessible to or replaceable by the user. Power to charge the pen can be taken from the USB connection or from an external power adapter through the pod.
  • the pen also has a power and USB-compatible data socket to allow it to be externally connected and powered while in use.
  • the pen cap serves the dual purpose of protecting the nib and the imaging optics when the cap is fitted and signalling the pen to leave a power-preserving state when uncapped.
  • FIG. 24 shows a rounded triangular profile giving the pen 400 an ergonomically comfortable shape to grip and use the pen in the correct functional orientation. It is also a practical shape for accommodating the internal components. A normal pen-like grip naturally conforms to a triangular shape between thumb 402 , index finger 404 and middle finger 406 .
  • a typical user writes with the pen 400 at a nominal pitch of about 30 degrees from the normal toward the hand 408 when held (positive angle) but seldom operates a pen at more than about 10 degrees of negative pitch (away from the hand).
  • the range of pitch angles over which the pen 400 is able to image the pattern on the paper has been optimised for this asymmetric usage.
  • the shape of the pen 400 helps to orient the pen correctly in the user's hand 408 and to discourage the user from using the pen “upside-down”.
  • the pen functions “upside-down” but the allowable tilt angle range is reduced.
  • the cap 410 is designed to fit over the top end of the pen 400 , allowing it to be securely stowed while the pen is in use.
  • Multi colour LEDs illuminate a status window 412 in the top edge (as in the apex of the rounded triangular cross section) of the pen 400 near its top end.
  • the status window 412 remains un-obscured when the cap is stowed.
  • a vibration motor is also included in the pen as a haptic feedback system (described in detail below).
  • the grip portion of the pen has a hollow chassis molding 416 enclosed by a base molding 528 to house the other components.
  • the ink cartridge 414 for the ball point nib fits naturally into the apex 420 of the triangular cross section, placing it consistently with the user's grip. This in turn provides space for the main PCB 422 in the centre of the pen and for the battery 424 in the base of the pen.
  • FIG. 27A it can be seen that this also naturally places the tag-sensing optics 426 unobtrusively below the nib 418 (with respect to nominal pitch).
  • the nib molding 428 of the pen 400 is swept back below the ink cartridge 414 to prevent contact between the nib molding 428 and the paper surface when the pen is operated at maximum pitch.
  • the imaging field of view 430 emerges through a centrally positioned IR filter/window 432 below the nib 418 , and two near-infrared illumination LEDs 434 , 436 emerge from the two bottom corners of the nib molding 428 .
  • Each LED 434 , 436 has a corresponding illumination field 438 , 440 .
  • the pen As the pen is hand-held, it may be held at an angle that causes reflections from one of the LED's that are detrimental to the image sensor. By providing more than one LED, the LED causing the offending reflections can be extinguished.
  • FIG. 28 is a longitudinal cross section through the centre-line if the pen 400 (with the cap 410 stowed on the end of the pen).
  • the pen incorporates red and green LEDs 444 to indicate several states, using colours and intensity modulation.
  • a light pipe 448 on the LEDs 444 transmit the signal to the status indicator window 412 in the tube molding 416 .
  • These signal status information to the user including power-on, battery level, untransmitted digital ink, network connection on-line, fault or error with an action, detection of an “active area” flag, detection of an “embedded data” flag, further data sampling to required to acquire embedded data, acquisition of embedded data completed etc.
  • a vibration motor 446 is used to haptically convey information to the user for important verification functions during transactions. This system is used for important interactive indications that might be missed due to inattention to the LED indicators 444 or high levels of ambient light.
  • the haptic system indicates to the user when:
  • the pen incorporates a fixed-focus narrowband infrared imaging system. It utilizes a camera with a short exposure time, small aperture, and bright synchronised illumination to capture sharp images unaffected by defocus blur or motion blur.
  • FIGS. 29A and 29B Cross sections showing the pen optics are provided in FIGS. 29A and 29B .
  • An image of the Netpage tags printed on a surface 548 adjacent to the nib 418 is focused by a lens 488 onto the active region of an image sensor 490 .
  • a small aperture 494 ensures the available depth of field accommodates the required pitch and roll ranges of the pen 400 .
  • First and second LEDs 434 and 436 brightly illuminate the surface 549 within the field of view 430 .
  • the spectral emission peak of the LEDs is matched to the spectral absorption peak of the infrared ink used to print Netpage tags to maximise contrast in captured images of tags.
  • the brightness of the LEDs is matched to the small aperture size and short exposure time required to minimise defocus and motion blur.
  • a longpass IR filter 432 suppresses the response of the image sensor 490 to any coloured graphics or text spatially coincident with imaged tags and any ambient illumination below the cut-off wavelength of the filter 432 .
  • the transmission of the filter 432 is matched to the spectral absorption peak of the infrared ink to maximise contrast in captured images of tags.
  • the filter also acts as a robust physical window, preventing contaminants from entering the optical assembly 470 .
  • the image sensor 490 is a CMOS image sensor with an active region of 140 pixels squared. Each pixel is 10 ⁇ m squared, with a fill factor of 93%.
  • FIG. 31 the lens 488 is shown in detail. The dimensions are:
  • the lens 488 is biconvex, with the most curved surface facing the image sensor.
  • the minimum imaging field of view 430 required to guarantee acquisition of sufficient tag data with each interaction is dependent on the specific coding pattern. The required field of view for the coding patterns of the present invention is described in Section 4.10.
  • the required paraxial magnification of the optical system is defined by the minimum spatial sampling frequency of 2.25 pixels per macrodot for the fully specified tilt range of the pen 400 , for the image sensor 490 of 10 ⁇ m pixels.
  • the imaging system employs a paraxial magnification of 0.225, the ratio of the diameter of the inverted image at the image sensor to the diameter of the field of view at the object plane, on an image sensor 490 of minimum 128 ⁇ 128 pixels.
  • the image sensor 490 however is 140 ⁇ 140 pixels, in order to accommodate manufacturing tolerances. This allows up to +/ ⁇ 120 ⁇ m (12 pixels in each direction in the plane of the image sensor) of misalignment between the optical axis and the image sensor axis without losing any of the information in the field of view.
  • the lens 488 is made from Poly-methyl-methacrylate (PMMA), typically used for injection moulded optical components.
  • PMMA is scratch resistant, and has a refractive index of 1.49, with 90% transmission at 810 nm.
  • the lens is biconvex to assist moulding precision and features a mounting surface to precisely mate the lens with the optical barrel molding 492 .
  • a 0.8 mm diameter aperture 494 is used to provide the depth of field requirements of the design.
  • the specified tilt range of the pen is 15.0 to 45.0 degree pitch, with a roll range of 30.0 to 30.0 degrees. Tilting the pen through its specified range moves the tilted object plane up to 6.3 mm away from the focal plane.
  • the specified aperture thus provides a corresponding depth of field of 6.5 mm, with an acceptable blur radius at the image sensor of 16 ⁇ m.
  • the pen operates correctly over a pitch range of 33.0 to 45.0 degrees.
  • the optical axis 550 is pitched 0.8 degrees away from the nib axis 552 .
  • the optical axis and the nib axis converge toward the paper surface 548 .
  • the distance A between the edge of the field of view 430 closest to the nib axis and the nib axis itself is 1.2 mm.
  • the longpass IR filter 432 is made of CR-39, a lightweight thermoset plastic heavily resistant to abrasion and chemicals such as acetone. Because of these properties, the filter also serves as a window.
  • the filter is 1.5 mm thick, with a refractive index of 1.50. Each filter may be easily cut from a large sheet using a CO 2 laser cutter.
  • FIG. 33 is a block diagram of the pen electronics.
  • the electronics design for the pen is based around five main sections. These are:
  • the pen uses an Atmel AT91FR40162 microprocessor (see Atmel, AT 91 ARM Thumb Microcontrollers—A T 91 FR 40162 Preliminary, http://www.keil.com/dd/docs/datashts/atmel/at 91fr40162.pdf) running at 80 MHz.
  • the AT91FR40162 incorporates an ARM7 microprocessor, 256 kBytes of on-chip single wait state SRAM and 2 MBytes of external flash memory in a stack chip package.
  • This microprocessor 574 forms the core of the pen 400 . Its duties include:
  • the ARM7 microprocessor 574 runs from an 80 MHz oscillator. It communicates with the Jupiter image sensor 576 using a Universal Synchronous Receiver Transmitter (USRT) 586 with a 40 MHz clock. The ARM7 574 communicates with the Bluetooth module 578 using a Universal Asynchronous Receiver Transmitter (UART) 588 running at 115.2 kbaud. Communications to the PMU 580 and the Force Sensor microprocessor (FSP) 582 are performed using a Low Speed Serial bus (LSS) 590 .
  • the LSS is implemented in software and uses two of the microprocessor's general purpose IOs.
  • the ARM7 microprocessor 574 is programmed via its JTAG port.
  • the ‘Jupiter’ Image Sensor 584 contains a monochrome sensor array, an analogue to digital converter (ADC), a frame store buffer, a simple image processor and a phase lock loop (PLL).
  • ADC analogue to digital converter
  • PLL phase lock loop
  • Jupiter uses the USRT's clock line and its internal PLL to generate all its clocking requirements. Images captured by the sensor array are stored in the frame store buffer. These images are decoded by the ARM7 microprocessor 574 with help from the ‘Callisto’ image processor contained in Jupiter.
  • the Callisto image processor performs, inter alia, low-pass filtering of captured images (see Section 4.11 and US Publication No. 2005/0024510) before macrodot sampling and decoding by the microprocessor 574 .
  • Jupiter controls the strobing of two infrared LEDs 434 and 436 at the same time as its image array is exposed.
  • One or other of these two infrared LEDs may be turned off while the image array is exposed to prevent specular reflection off the paper that can occur at certain angles.
  • the pen uses a CSR BlueCore4-External device (see CSR, BlueCore 4- External Data Sheet rev c, 6 Sep. 2004) as the Bluetooth controller 578 . It requires an external 8 Mbit flash memory device 594 to hold its program code.
  • the BlueCore4 meets the Bluetooth v1.2 specification and is compliant to v0.9 of the Enhanced Data Rate (EDR) specification which allows communication at up to 3 Mbps.
  • EDR Enhanced Data Rate
  • a 2.45 GHz chip antenna 486 is used on the pen for the Bluetooth communications.
  • the BlueCore4 is capable of forming a UART to USB bridge. This is used to allow USB communications via data/power socket 458 at the top of the pen 456 .
  • Bluetooth includes wireless LAN and PAN standards such as IEEE 802.11 (Wi-Fi) (see IEEE, 802.11 Wireless Local Area Networks, http://grouper.ieee.org/groups/802/11/index.html), IEEE 802.15 (see IEEE, 802.15 Working Groupfor WPAN, http://grouper.ieee.org/groups/802/15/index.html), ZigBee (see ZigBee Alliance, http://www.zigbee.org), and WirelessUSB Cypress (see WirelessUSB LR 2.4-GHz DSSS Radio SoC, http://www.cypress.com/cfuploads/img/products/cywusb6935.pdf), as well as mobile standards such as GSM (see GSM Association, http://www.gsmworld.com/index.shtml), GPRS/EDGE, GPRSPlatform, http://www.gsmworld.com/technology/gprs/index.shtml), CDMA (see CDMA Development Group, http://www.
  • the pen uses an Austria Microsystems AS3603 PMU 580 (see Austria Microsystems, AS3603 Multi-Standard Power Management Unit Data Sheet v2.0).
  • the PMU is used for battery management, voltage generation, power up reset generation and driving indicator LEDs and the vibrator motor.
  • the PMU 580 communicates with the ARM7 microprocessor 574 via the LSS bus 590 .
  • the force sensor subsystem comprises a custom Hokuriku force sensor 500 (based on Hokuriku, HFD-500 Force Sensor, http://www.hdk.cojp/pdf/eng/e1381AA.pdf), an amplifier and low pass filter 600 implemented using op-amps and a force sensor microprocessor 582 .
  • the pen uses a Silicon Laboratories C8051F330 as the force sensor microprocessor 582 (see Silicon Laboratories, C8051F330/1 MCUData Sheet, rev 1.1).
  • the C8051F330 is an 8051 microprocessor with on chip flash memory, 10 bit ADC and 10 bit DAC. It contains an internal 24.5 MHz oscillator and also uses an external 32.768 kHz tuning fork.
  • the Hokuriku force sensor 500 is a silicon piezoresistive bridge sensor.
  • An op-amp stage 600 amplifies and low pass (anti-alias) filters the force sensor output. This signal is then sampled by the force sensor microprocessor 582 at 5 kHz.
  • piezoresistive force sensing include capacitive and inductive force sensing (see Wacom, “Variable capacity condenser and pointer”, US Patent Application 20010038384, filed 8 Nov. 2001, and Wacom, Technology, http://www.wacom-components.com/english/tech.asp).
  • the force sensor microprocessor 582 performs further (digital) filtering of the force signal and produces the force sensor values for the digital ink stream.
  • a frame sync signal from the Jupiter image sensor 576 is used to trigger the generation of each force sample for the digital ink stream.
  • the temperature is measured via the force sensor microprocessor's 582 on chip temperature sensor and this is used to compensate for the temperature dependence of the force sensor and amplifier.
  • the offset of the force signal is dynamically controlled by input of the microprocessor's DAC output into the amplifier stage 600 .
  • the force sensor microprocessor 582 communicates with the ARM7 microprocessor 574 via the LSS bus 590 . There are two separate interrupt lines from the force sensor microprocessor 582 to the ARM7 microprocessor 574 . One is used to indicate that a force sensor sample is ready for reading and the other to indicate that a pen down/up event has occurred.
  • the force sensor microprocessor flash memory is programmed in-circuit by the ARM7 microprocessor 574 .
  • the force sensor microprocessor 582 also provides the real time clock functionality for the pen 400 .
  • the RTC function is performed in one of the microprocessor's counter timers and runs from the external 32.768 kHz tuning fork.
  • the force sensor microprocessor needs to remain on when the cap 472 is on and the ARM7 574 is powered down.
  • the force sensor microprocessor 582 uses a low power LDO separate from the PMU 580 as its power source.
  • the real time clock functionality includes an interrupt which can be programmed to power up the ARM7 574 .
  • the cap switch 602 is monitored by the force sensor microprocessor 582 .
  • the force sensor microprocessor 582 starts up the ARM7 572 by initiating a power on and reset cycle in the PMU 580 .
  • the Netpage pen software comprises that software running on microprocessors in the Netpage pen 400 and Netpage pod.
  • the pen contains a number of microprocessors, as detailed in Section 5.6.
  • the Netpage pen software includes software running on the Atmel ARM7 CPU 574 (hereafter CPU), the Force Sensor microprocessor 582 , and also software running in the VM on the CSR BlueCore Bluetooth module 578 (hereafter pen BlueCore). Each of these processors has an associated flash memory which stores the processor specific software, together with settings and other persistent data.
  • the pen BlueCore 578 also runs firmware supplied by the module manufacturer, and this firmware is not considered a part of the Netpage pen software.
  • the pod contains a CSR BlueCore Bluetooth module (hereafter pod BlueCore).
  • the Netpage pen software also includes software running in the VM on the pod BlueCore.
  • DInk may include samples with zero force (so called “Hover DInk”) produced when the Netpage pen is in proximity to, but not marking, a Netpage tagged surface.
  • the CPU component of the Netpage pen software is responsible for DInk capture, tag image processing and decoding (in conjunction with the Jupiter image sensor 576 ), storage and offload management, host communications, user feedback and software upgrade. It includes an operating system (RTOS) and relevant hardware drivers. In addition, it provides a manufacturing and maintenance mode for calibration, configuration or detailed (non-field) fault diagnosis.
  • the Force Sensor microprocessor 582 component of the Netpage pen software is responsible for filtering and preparing force samples for the main CPU.
  • the pen BlueCore VM software is responsible for bridging the CPU UART 588 interface to USB when the pen is operating in tethered mode. The pen BlueCore VM software is not used when the pen is operating in Bluetooth mode.
  • the pod BlueCore VM software is responsible for sensing when the pod is charging a pen 400 , controlling the pod LEDs appropriately, and communicating with the host PC via USB.

Abstract

A method of imaging a coding pattern disposed on a surface of a substrate. The method comprises the steps of: (a) operatively positioning an optical reader relative to the surface and capturing an image of a portion of the coding pattern, said coding pattern comprising: (b) sampling and decoding x-coordinate data and y-coordinate data within the imaged portion; and (c) determining a position of the reader. All the x-coordinate data is represented in a column of an imaged tag and all the y-coordinate data is represented in a row of the imaged tag. The column and the row each have a width v. The imaged portion has a diameter of at least (l+v)√2 and less than (2l)√2.

Description

    FIELD OF INVENTION
  • The present invention relates to a position-coding pattern on a surface.
  • COPENDING APPLICATIONS
  • The following applications have been filed by the Applicant simultaneously with the present application:
      • NPT100US NPT101US NPT102US
  • The disclosures of these co-pending applications are incorporated herein by reference.
  • The above applications have been identified by their filing docket number, which will be substituted with the corresponding application number, once assigned.
  • CROSS REFERENCES
  • The following patents or patent applications filed by the applicant or assignee of the present invention are hereby incorporated by cross-reference.
  • 10/815,621 10/815,635 10/815,647 11/488,162 10/815,636
    11/041,652 11/041,609 11/041,556 10/815,609 7,204,941
    7,278,727 10/913,380 7,122,076 7,156,289 09/575,197
    6,720,985 7,295,839 09/722,174 7,068,382 7,094,910
    7,062,651 6,644,642 6,549,935 6,987,573 6,727,996
    6,760,119 7,064,851 6,290,349 6,428,155 6,785,016
    6,831,682 6,741,871 6,965,439 10/932,044 6,870,966
    6,474,888 6,724,374 6,788,982 7,263,270 6,788,293
    6,737,591 09/693,514 10/778,056 10/778,061 11/193,482
    7,055,739 6,830,196 7,182,247 7,082,562 10/409,864
    7,108,192 10/492,169 10/492,152 10/492,168 10/492,161
    7,308,148 6,957,768 7,170,499 11/856,061 11/672,522
    11/672,950 11/754,310 12/015,507 7,148,345 12/025,746
    12/025,762 12/025,765 10/407,212 6,902,255 6,755,509
    12/178,611 12/178,619
  • BACKGROUND
  • The Applicant has previously described a method of enabling users to access information from a computer system via a printed substrate e.g. paper. The substrate has a coding pattern printed thereon, which is read by an optical sensing device when the user interacts with the substrate using the sensing device. A computer receives interaction data from the sensing device and uses this data to determine what action is being requested by the user. For example, a user may make handwritten input onto a form or make a selection gesture around a printed item. This input is interpreted by the computer system with reference to a page description corresponding to the printed substrate.
  • It would desirable to improve the coding pattern printed on the substrate so as to maximize usage of images captured by the sensing device. It would be further desirable to provide variants of a position coding pattern, suitable for printing by different types of printer, where each variant is readable by the same optical reader.
  • SUMMARY OF INVENTION
  • In a first aspect, the present invention provides a substrate having a first coding pattern disposed on a surface thereof, the first coding pattern comprising:
      • a plurality of target elements defining a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements;
      • a plurality of data elements contained in each cell; and
      • a plurality of tags, each tag being defined by a first set of contiguous cells, each tag comprising respective tag data encoded by a respective set of the data elements, wherein each cell comprises one or more registration symbols encoded by a respective set of the data elements, each of the one or more registration symbols identifying the cell as being contained in the first set and thereby contained in the first coding pattern.
  • The registration symbols advantageously provide a means by which the first coding pattern can be distinguished from other coding pattern(s) of the same general type.
  • Optionally, a number of cells contained in the first set identifies the first set and thereby the first coding pattern. Optionally, each of the registration symbols identifies the number of cells contained in the first set. Optionally, each registration symbol distinguishes the first coding pattern from a second coding pattern. Advantageously, the registration symbols identify the first coding pattern by identifying the number of cells contained in each tag. For example, a first coding pattern have contain nine cells per tag, whilst a second coding pattern may have four cells per tag.
  • Optionally, the first coding pattern and the second coding pattern are both readable and decodable by a same optical reader. Hence, the Netpage pen can read and decode different Netpage position-coding patterns, irrespective of the actual number of cells per tag. This enables different position-coding patterns to be used and printed, depending on the print capabilities of a printer
  • Optionally, the second coding pattern comprises:
      • a plurality of target elements defining a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements;
      • a plurality of data elements contained in each cell; and
      • a plurality of tags, each tag being defined by a second set of contiguous cells, each tag comprising respective tag data encoded by a respective set of the data elements, wherein the second set contains a different number of cells than the first set.
  • Hence, the second-position coding pattern is typically of the same general type as the first position-coding pattern.
  • Optionally, each cell of the first coding pattern and the second coding pattern comprises one or more registration symbols. A large number of registration symbols in each tag provides a high degree of redundancy, meaning that the pen can robustly recognize a particular coding pattern.
  • Optionally, the registration symbols in the first and second coding patterns are configured and positioned identically relative to target elements contained by each cell. The relative positioning of the registration symbols in both the first and second coding patterns is the same, so that the pen can find the registrations symbols before it identifies which coding pattern it is reading.
  • Optionally, the second coding pattern is adapted to be printed at a lower print resolution than the first coding pattern. Optionally, the second set contains a fewer number of cells than the first set.
  • Optionally, each registration symbol identifies a translation of the cell relative to a tag containing the cell. This enables alignment of the tag(s) with the target grid. Typically, a first translation codeword (e.g. 0, 1, 2) is reserved for the first coding pattern, whilst a second translation codeword (e.g. 3, 4) is reserved for the second coding pattern.
  • Optionally, each cell comprises a pair of orthogonal registration symbols, each orthogonal registration symbol identifying a respective orthogonal translation of the cell relative to a tag containing the cell. Hence, each registration symbol is identifies either an x-translation or a y-translation of a cell relative to a tag containing that cell.
  • Optionally, each tag is square and comprises M2 contiguous square cells, wherein M is an integer having a value of at least 2. Typical tag sizes are M=2, 3 or 4. Preferably, M=2 or 3.
  • Optionally, M registration symbols in a row of M cells define a cyclic position code having minimum distance M, the code being defined by a first translation codeword.
  • Optionally, M registration symbols in a column of M cells define a cyclic position code having minimum distance M, the code being defined by a second translation codeword.
  • Optionally, each tag comprises N cells, and at least N registration symbols form a third translation codeword with minimum distance N, wherein N is an integer having a value of at least 4.
  • Advantageously, the first, second and/or third translation codewords enable robust alignment of the tag(s) with the target. For example, in a tag containing nine cells, four symbol errors in the third translation codeword may be corrected.
  • Optionally, each registration symbol further identifies an orientation of a layout of the tag data with respect to the target grid. The encoded orientation enables the Netpage pen to determine its orientation (yaw) relative to the tag data, and hence relative to the substrate.
  • Typically, the data elements are macrodots (i.e. readable marks in the form of dots). Typically, a portion of data is represented by m macrodots, each of the macrodots occupying a respective position from a plurality of predetermined possible positions p within the cell, the respective positions of the macrodots representing one of a plurality of possible data values, wherein m is an integer of 1 or more (usually 2 or more), and p>m (typically p≧2m). Encoding by multi-PPM in this way ensures uniform coverage of the substrate with macrodots, which helps to reduce visibility. Moreover, PPM encoding provides an internal luminescence reference for reading macrodots. For example, the darkest m macrodots in the p positions are taken to be the PPM data, without the need to refer to any external luminescence threshold value.
  • Optionally, each cell defines a symbol group, each symbol group comprising a plurality of Reed-Solomon symbols encoded by a plurality of the data elements.
  • Optionally, at least some of said tag data is encoded as a local codeword comprised of a set of the Reed-Solomon symbols. The local tag data typically identifies a location of the tag.
  • In a second aspect, there is provided a method of imaging either a first coding pattern or a second coding pattern disposed on a surface, the method comprising the steps of:
  • (a) operatively positioning an optical reader relative to the surface having either the first or second coding pattern disposed thereon;
  • (b) capturing an image of a portion of the first or second coding pattern, the first and second coding patterns each comprising:
      • a plurality of target elements defining a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements;
      • a plurality of data elements contained in each cell; and
      • a plurality of tags, each tag being defined by a set of contiguous cells, each tag comprising respective tag data encoded by a respective set of the data elements,
        wherein each cell comprises one or more registration symbols encoded by a respective set of the data elements;
  • (c) sampling and decoding at least one registration symbol contained in the imaged portion;
  • (d) determining, from the decoded registration symbol, an identifier of the first or second coding pattern, the identifier indicating a number of cells contained in each tag;
  • (e) determining, from the identifier, whether the optical reader is positioned relative to the first coding pattern or the second coding pattern; and
  • (f) using the indicated number of cells to sample and decode the tag data, wherein a number of cells contained in each tag of the first coding pattern is different from a number of cells contained in each tag of the second coding pattern.
  • Optionally, each registration symbol identifies a translation of the cell relative to a tag containing the cell, the method further comprising the step of:
  • using the translation to sample and decode the tag data.
  • Optionally, each registration symbol identifies an orientation of a layout of the tag data with respect to the target grid, the method further comprising the step of:
  • using the orientation to sample and decode the tag data.
  • In a third aspect, there is provided a system for imaging either a first coding pattern or a second coding pattern, the system comprising:
  • (A) a substrate having either the first coding pattern or the second coding pattern disposed on a surface thereof, wherein the first and second coding patterns each comprises:
  • a plurality of target elements defining a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements;
  • a plurality of data elements contained in each cell; and
  • a plurality of tags, each tag being defined by a set of contiguous cells, each tag comprising respective tag data encoded by a respective set of the data elements, wherein each cell comprises one or more registration symbols encoded by a respective set of the data elements;
  • (B) an optical reader comprising:
  • an image sensor for capturing an image of a portion of the first or second coding pattern; and
  • a processor configured for performing the steps of:
      • (i) sampling and decoding at least one registration symbol contained in the imaged portion;
      • (ii) determining, from the decoded registration symbol, an identifier of the first or second coding pattern, the identifier indicating a number of cells contained in each tag;
      • (iii) determining, from the identifier, whether the optical reader is positioned relative to the first coding pattern or the second coding pattern; and
      • (iv) using the indicated number of cells to sample and decode the tag data,
        wherein a number of cells contained in each tag of the first coding pattern is different from a number of cells contained in each tag of the second coding pattern.
  • Optionally, each registration symbol identifies a translation of the cell relative to a tag containing the cell, the processor being configured to perform the further step of:
  • using the translation to sample and decode the tag data.
  • Optionally, each registration symbol identifies an orientation of a layout of the tag data with respect to the target grid, the processor being configure to perform the further step of:
  • using the orientation to sample and decode the tag data.
  • In a fourth aspect, there is provided an optical reader for imaging either a first coding pattern or a second coding pattern, the first and second coding patterns each comprising:
  • a plurality of target elements defining a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements;
  • a plurality of data elements contained in each cell; and
  • a plurality of tags, each tag being defined by a set of contiguous cells, each tag comprising respective tag data encoded by a respective set of the data elements, wherein each cell comprises one or more registration symbols encoded by a respective set of the data elements; the optical reader comprising:
  • an image sensor for capturing an image of a portion of either first or second coding pattern; and
  • a processor configured for performing the steps of:
      • (i) sampling and decoding at least one registration symbol contained in the imaged portion;
      • (ii) determining, from the decoded registration symbol, an identifier of the first or second coding pattern, the identifier indicating a number of cells contained in each tag;
      • (iii) determining, from the identifier, whether the optical reader is positioned relative to the first coding pattern or the second coding pattern; and
      • (iv) using the indicated number of cells to sample and decode the tag data, wherein a number of cells contained in each tag of the first coding pattern is different from a number of cells contained in each tag of the second coding pattern.
  • It will be appreciated that optional embodiments of the first aspect may also be optional embodiments of the second, third or fourth aspects.
  • In a fifth aspect, there is provided a substrate having a coding pattern disposed on a surface thereof, the coding pattern comprising:
  • a plurality of contiguous square tags of length l, each tag comprising x-coordinate data and y-coordinate data; and
  • a plurality of data elements contained in each tag, the x-coordinate data being represented by a respective set of data elements and the y-coordinate data being represented by a respective set of data elements,
  • wherein:
  • all the x-coordinate data is represented in a column of the tag parallel with a y-axis;
  • all the y-coordinate data is represented in a row of the tag parallel with an x-axis; and the column and the row each have a width v, such that any square portion of the coding pattern having a length (I+v) is guaranteed to contain the x-coordinate data and the y-coordinate data for a tag irrespective of whether a whole tag is contained in the portion.
  • The fifth aspect of the invention advantageously enables non-replication of coordinate data in each tag, which saves on tag space. Typically, x-coordinate data should be replicated in each vertical half of tag, and y-coordinate data should be replicated in each horizontal half of a tag. However, by encoding all x-coordinate data in one column, and all y-coordinate data in one row, the requirement for replication is obviated. If the column or row has a width v, then any square portion of length (l+v) is guaranteed to contain the relevant coordinate data. Moreover, if the width v corresponds to a width or length of a coordinate data symbol (depending on the shape and orientation of coordinate data symbols in the column or row), then it is ensured that any square portion of length (l+v) is guaranteed to contain the relevant coordinate data from spatially coherent samples i.e. from the same symbol, as opposed to partial symbols at opposite sides of a field of view.
  • Optionally, a plurality of target elements define a target grid, the target grid comprising a plurality of cells, wherein neighboring cells share target elements and wherein each tag is defined by a plurality of contiguous cells.
  • Optionally, each tag comprises M2 contiguous square cells, wherein M is an integer having a value of at least 1. Typical tag sizes are M=2, 3 or 4. Preferably, M=2 or 3
  • Optionally, the data elements are macrodots, which are readable dot-like marks formed by a plurality of contiguous printed dots.
  • Optionally, v=ts, wherein: s is defined as a spacing between adjacent macrodots; and t is an integer value of 2 or more.
  • Optionally, the macrodots encode data values by pulse position modulation (PPM).
  • Optionally, a portion of data is represented by m macrodots, each of the macrodots occupying a respective position from a plurality of predetermined possible positions p within the cell, the respective positions of the macrodots representing one of a plurality of possible data values.
  • Optionally, the x-coordinate data is encoded as an x-coordinate codeword comprised of a respective set of the X-Reed-Solomon symbols, and the y-coordinate data is encoded as a y-coordinate codeword comprised of a respective set of the Y-Reed-Solomon symbols.
  • Optionally, the X-Reed-Solomon symbols are configured and oriented in the column so as to have the width v, and wherein the Y-Reed-Solomon symbols are configured and oriented in the row so as to have the width v.
  • Optionally, each tag comprises a plurality of common codewords, each common codeword being comprised of a respective set of the Reed-Solomon symbols, wherein the plurality of common codewords are defined as codewords common to a plurality of contiguous tags. A common codeword typically encodes a region ID or page ID for the substrate.
  • Optionally, each symbol group comprises a fragment of at least one of the common codewords, and contiguous symbol groups are arranged such that any tag-sized portion of the coding pattern is guaranteed to contain the plurality of common codewords irrespective of whether a whole tag is contained in the portion.
  • Optionally, each cell comprises a registration symbol encoded by a respective set of the data elements, the registration symbol identifying one or more of:
  • a translation of the cell relative to a tag containing the cell;
  • an orientation of a layout of tag data with respect to the target grid;
  • a number of cells in each tag;
  • a flag associated with the tag.
  • Optionally, each cell comprises first and second registration symbols, the first registration symbol identifying a first orthogonal translation of the cell, the second registration symbol identifying a second orthogonal translation of the cell.
  • Optionally, the first registration symbol identifies a first direction component of the orientation, and the second registration symbol identifies a second direction component of the orientation, such that the first and second orthogonal registration symbols together identify the orientation via the first and second direction components.
  • Optionally, the target elements are target dots and the data elements are macrodots, and each target dot has a diameter of at least twice that of each macrodot. This enables low-pass filtration of captured images to retain target elements but obscure macrodots.
  • In a sixth aspect, there is provided a method of imaging a coding pattern disposed on a surface of a substrate, the method comprising the steps of:
  • (a) operatively positioning an optical reader relative to the surface and capturing an image of a portion of the coding pattern, the coding pattern comprising:
  • a plurality of contiguous square tags of length l, each tag comprising x-coordinate data and y-coordinate data; and
  • a plurality of data elements contained in each tag, the x-coordinate data being represented by a respective set of data elements and the y-coordinate data being represented by a respective set of data elements,
  • wherein:
  • all the x-coordinate data is represented in a column of the tag parallel with a y-axis;
  • all the y-coordinate data is represented in a row of the tag parallel with an x-axis; and
  • the column and the row each have a width v,
  • (b) sampling and decoding x-coordinate data and y-coordinate data within the imaged portion; and
  • (c) determining a position of the reader,
  • wherein the imaged portion has a diameter of at least (l+v)√2 and less than (2)√2.
  • Since the field of view of the optical reader is not required to have a diameter of at least two tag diameters, then the imaging requirements of the reader are reduced. Hence, the position-coding pattern not only provides efficient use of tag space, but also allows the imaging field of view of the tag reader to be minimized.
  • Optionally, each tag comprises a plurality of common codewords, each common codeword being comprised of a respective set of the Reed-Solomon symbols, wherein the plurality of common codewords are defined as codewords common to a plurality of contiguous tags, the method further comprising the step of:
  • sampling and decoding the common codeword within the imaged portion.
  • Optionally, one or more of the common codewords encode region identity data uniquely identifying a region of the surface, the method further comprising:
  • determining the an identity of the region.
  • Optionally, the region identity data uniquely identifies the substrate.
  • In a seventh aspect, there is provided a system for imaging a coding pattern disposed on a surface of a substrate, the system comprising:
  • (A) the substrate, wherein the coding pattern comprises:
  • a plurality of contiguous square tags of length l, each tag comprising x-coordinate data and y-coordinate data; and
  • a plurality of data elements contained in each tag, the x-coordinate data being represented by a respective set of data elements and the y-coordinate data being represented by a respective set of data elements,
  • wherein:
  • all the x-coordinate data is represented in a column of the tag parallel with a y-axis;
  • all the y-coordinate data is represented in a row of the tag parallel with an x-axis; and
  • the column and the row each have a width v,
  • (B) an optical reader comprising:
  • an image sensor for capturing an image of a portion of the coding pattern, the image sensor having a field-of-view of at least (l+v)√2 and less than (2l)√2; and
  • a processor configured for performing the steps of:
      • (i) sampling and decoding x-coordinate data and y-coordinate data contained in an imaged portion; and
      • (ii) determining a position of the reader.
  • In an eighth aspect, there is provided an optical reader for imaging a coding pattern disposed on a surface of a substrate, the coding pattern comprising:
  • a plurality of contiguous square tags of length l, each tag comprising x-coordinate data and y-coordinate data; and
  • a plurality of data elements contained in each tag, the x-coordinate data being represented by a respective set of data elements and the y-coordinate data being represented by a respective set of data elements,
  • wherein:
  • all the x-coordinate data is represented in a column of the tag parallel with a y-axis;
  • all the y-coordinate data is represented in a row of the tag parallel with an x-axis; and
  • the column and the row each have a width v, the optical reader comprising:
  • an image sensor for capturing an image of a portion of the coding pattern, the image sensor having a field-of-view of at least (l+v)√2 and less than (2)√2; and
  • a processor configured for performing the steps of:
      • (i) sampling and decoding x-coordinate data and y-coordinate data contained in an imaged portion; and
      • (ii) determining a position of the reader.
  • It will be appreciated that optional embodiments of the fifth aspect may also be optional embodiments of sixth, seventh and eighth aspects.
  • BRIEF DESCRIPTION OF DRAWINGS
  • Preferred and other embodiments of the invention will now be described, by way of non-limiting example only, with reference to the accompanying drawings, in which:
  • FIG. 1 is a schematic of a relationship between a sample printed netpage and its online page description;
  • FIG. 2 shows an embodiment of basic netpage architecture with various alternatives for the relay device;
  • FIG. 3 shows the structure of a tag for a first position-coding pattern;
  • FIG. 4 shows a group of twelve data symbols and four targets for the first position-coding pattern;
  • FIG. 5 shows the layout of a 2-6PPM and 3-6PPM data symbol for the first position-coding pattern;
  • FIG. 6 shows the spacing of macrodot positions in the first position-coding pattern;
  • FIG. 7 shows the layout of a 2-6PPM registration symbol for the first position-coding pattern;
  • FIG. 8 shows a semi-replicated x-coordinate codeword X for the first position-coding pattern;
  • FIG. 9 shows a semi-replicated y-coordinate codeword Y for the first position-coding pattern;
  • FIG. 10 shows common codewords A, B, C and D, with codeword A shown in bold outline for the first position-coding pattern;
  • FIG. 11 shows an optional codeword E for the first position-coding pattern;
  • FIG. 12 shows the layout of a complete tag for the first position-coding pattern;
  • FIG. 13 shows the layout of a Reed-Solomon codeword for the first position-coding pattern;
  • FIG. 14 shows the structure of a tag for a second position-coding pattern;
  • FIG. 15 shows a group of eight data symbols and four targets for the second position-coding pattern;
  • FIG. 16 shows the layout of a 2-9PPM data symbol for the second position-coding pattern;
  • FIG. 17 shows an x-coordinate codeword X for the second position-coding pattern;
  • FIG. 18 shows a y-coordinate codeword Y for the second position-coding pattern;
  • FIG. 19 shows a common codeword A for the second position-coding pattern;
  • FIG. 20 shows the layout of a complete tag for the second position-coding pattern;
  • FIG. 21 shows the layout of a Reed-Solomon codeword for the second position-coding pattern;
  • FIG. 22 is a flowchart of initial image processing by the Netpage pen;
  • FIG. 23 is a flowchart of codeword decoding subsequent to the initial image processing;
  • FIG. 24 shows a nib and elevation of the Netpage pen held by a user;
  • FIG. 25 shows the pen held by a user at a typical incline to a writing surface;
  • FIG. 26 is a lateral cross section through the pen;
  • FIG. 27A is a bottom and nib end partial perspective of the pen;
  • FIG. 27B is a bottom and nib end partial perspective with the fields of illumination and field of view of the sensor window shown in dotted outline;
  • FIG. 28 is a longitudinal cross section of the pen;
  • FIG. 29A is a partial longitudinal cross section of the nib and barrel molding;
  • FIG. 29B is a partial longitudinal cross section of the IR LED's and the barrel molding;
  • FIG. 30 is a ray trace of the pen optics adjacent a sketch of the ink cartridge;
  • FIG. 31 is a side elevation of the lens;
  • FIG. 32 is a side elevation of the nib and the field of view of the optical sensor; and
  • FIG. 33 is a block diagram of the pen electronics.
  • DETAILED DESCRIPTION OF PREFERRED AND OTHER EMBODIMENTS 1.1 Netpage System Architecture
  • In a preferred embodiment, the invention is configured to work with the netpage networked computer system, an overview of which follows. In brief summary, the preferred form of the netpage system employs a computer interface in the form of a mapped surface, that is, a physical surface which contains references to a map of the surface maintained in a computer system. The map references can be queried by an appropriate sensing device. Depending upon the specific implementation, the map references may be encoded visibly or invisibly, and defined in such a way that a local query on the mapped surface yields an unambiguous map reference both within the map and among different maps. The computer system can contain information about features on the mapped surface, and such information can be retrieved based on map references supplied by a sensing device used with the mapped surface. The information thus retrieved can take the form of actions which are initiated by the computer system on behalf of the operator in response to the operator's interaction with the surface features.
  • In its preferred form, the netpage system relies on the production of, and human interaction with, netpages. These are pages of text, graphics and images printed on ordinary paper, but which work like interactive webpages. Information is encoded on each page using ink which is substantially invisible to the unaided human eye. The ink, however, and thereby the coded data, can be sensed by an optically imaging sensing device (or reader) and transmitted to the netpage system. The sensing device may take the form of a clicker (for clicking on a specific position on a surface), a pointer having a stylus (for pointing or gesturing on a surface using pointer strokes), or a pen having a marking nib (for marking a surface with ink when pointing, gesturing or writing on the surface). References herein to “pen” or “netpage pen” are provided by way of example only. It will, of course, be appreciated that the pen may take the form of any of the sensing devices or readers described herein.
  • In one embodiment, active buttons and hyperlinks on each page can be clicked with the sensing device to request information from the network or to signal preferences to a network server. In one embodiment, text written by hand on a netpage is automatically recognized and converted to computer text in the netpage system, allowing forms to be filled in. In other embodiments, signatures recorded on a netpage are automatically verified, allowing e-commerce transactions to be securely authorized. In other embodiments, text on a netpage may be clicked or gestured to initiate a search based on keywords indicated by the user.
  • As illustrated in FIG. 1, a printed netpage 1 can represent a interactive form which can be filled in by the user both physically, on the printed page, and “electronically”, via communication between the pen and the netpage system. The example shows a “Request” form containing name and address fields and a submit button. The netpage 1 consists of graphic data 2, printed using visible ink, and a surface coding pattern 3 superimposed with the graphic data. The surface coding pattern 3 comprises a collection of tags 4. A typical tag 4 is shown in the shaded region of FIG. 1, although it will be appreciated that contiguous tags 4, defined by the coding pattern 3, are densely tiled over the whole netpage 1.
  • The corresponding page description 5, stored on the netpage network, describes the individual elements of the netpage. In particular it describes the type and spatial extent (zone) of each interactive element (i.e. text field or button in the example), to allow the netpage system to correctly interpret input via the netpage. The submit button 6, for example, has a zone 7 which corresponds to the spatial extent of the corresponding graphic 8.
  • As illustrated in FIG. 2, a netpage sensing device 400, such as the pen described in Section 5, works in conjunction with a netpage relay device 601, which is an Internet-connected device for home, office or mobile use. The pen 400 is wireless and communicates securely with the netpage relay device 601 via a short-range radio link 9. In an alternative embodiment, the netpage pen 400 utilises a wired connection, such as a USB or other serial connection, to the relay device 601.
  • The relay device 601 performs the basic function of relaying interaction data to a page server 10, which interprets the interaction data. As shown in FIG. 2, the relay device 601 may, for example, take the form of a personal computer 601 a, a netpage printer 601 b or some other relay 601 c (e.g. personal computer or mobile phone incorporating a web browser).
  • The netpage printer 601 b is able to deliver, periodically or on demand, personalized newspapers, magazines, catalogs, brochures and other publications, all printed at high quality as interactive netpages. Unlike a personal computer, the netpage printer is an appliance which can be, for example, wall-mounted adjacent to an area where the morning news is first consumed, such as in a user's kitchen, near a breakfast table, or near the household's point of departure for the day. It also comes in tabletop, desktop, portable and miniature versions. Netpages printed on-demand at their point of consumption combine the ease-of-use of paper with the timeliness and interactivity of an interactive medium.
  • Alternatively, the netpage relay device 601 may be a portable device, such as a mobile phone or PDA, a laptop or desktop computer, or an information appliance connected to a shared display, such as a TV. If the relay device 601 is not a netpage printer 601 b which prints netpages digitally and on demand, the netpages may be printed by traditional analog printing presses, using such techniques as offset lithography, flexography, screen printing, relief printing and rotogravure, as well as by digital printing presses, using techniques such as drop-on-demand inkjet, continuous inkjet, dye transfer, and laser printing.
  • As shown in FIG. 2, the netpage sensing device 400 interacts with a portion of the tag pattern on a printed netpage 1, or other printed substrate such as a label of a product item 251, and communicates, via a short-range radio link 9, the interaction to the relay device 601. The relay 601 sends corresponding interaction data to the relevant netpage page server 10 for interpretation. Raw data received from the sensing device 400 may be relayed directly to the page server 10 as interaction data. Alternatively, the interaction data may be encoded in the form of an interaction URI and transmitted to the page server 10 via a user's web browser 601 c. The web browser 601 c may then receive a URI from the page server 10 and access a webpage via a webserver 201. In some circumstances, the page server 10 may access application computer software running on a netpage application server 13.
  • The netpage relay device 601 can be configured to support any number of sensing devices, and a sensing device can work with any number of netpage relays. In the preferred implementation, each netpage sensing device 400 has a unique identifier. This allows each user to maintain a distinct profile with respect to a netpage page server 10 or application server 13.
  • Digital, on-demand delivery of netpages 1 may be performed by the netpage printer 601 b, which exploits the growing availability of broadband Internet access. Netpage publication servers 14 on the netpage network are configured to deliver print-quality publications to netpage printers. Periodical publications are delivered automatically to subscribing netpage printers via pointcasting and multicasting Internet protocols. Personalized publications are filtered and formatted according to individual user profiles.
  • A netpage pen may be registered with a netpage registration server 11 and linked to one or more payment card accounts. This allows e-commerce payments to be securely authorized using the netpage pen. The netpage registration server compares the signature captured by the netpage pen with a previously registered signature, allowing it to authenticate the user's identity to an e-commerce server. Other biometrics can also be used to verify identity. One version of the netpage pen includes fingerprint scanning, verified in a similar way by the netpage registration server.
  • 1.2 Netpages
  • Netpages are the foundation on which a netpage network is built. They provide a paper-based user interface to published information and interactive services.
  • As shown in FIG. 1, a netpage consists of a printed page (or other surface region) invisibly tagged with references to an online description 5 of the page. The online page description 5 is maintained persistently by the netpage page server 10. The page description describes the visible layout and content of the page, including text, graphics and images. It also describes the input elements on the page, including buttons, hyperlinks, and input fields. A netpage allows markings made with a netpage pen on its surface to be simultaneously captured and processed by the netpage system.
  • Multiple netpages (for example, those printed by analog printing presses) can share the same page description. However, to allow input through otherwise identical pages to be distinguished, each netpage may be assigned a unique page identifier. This page ID (or, more generally, region ID) has sufficient precision to distinguish between a very large number of netpages.
  • Each reference to the page description 5 is repeatedly encoded in the netpage pattern. Each tag (and/or a collection of contiguous tags) identifies the unique page on which it appears, and thereby indirectly identifies the page description 5. Each tag also identifies its own position on the page. Characteristics of the tags are described in more detail below.
  • Tags are typically printed in infrared-absorptive ink on any substrate which is infrared-reflective, such as ordinary paper, or in infrared fluorescing ink. Near-infrared wavelengths are invisible to the human eye but are easily sensed by a solid-state image sensor with an appropriate filter.
  • A tag is sensed by a 2D area image sensor in the netpage sensing device, and the tag data is transmitted to the netpage system via the nearest netpage relay device 601. The pen 400 is wireless and communicates with the netpage relay device 601 via a short-range radio link. It is important that the pen recognize the page ID and position on every interaction with the page, since the interaction is stateless. Tags are error-correctably encoded to make them partially tolerant to surface damage.
  • The netpage page server 10 maintains a unique page instance for each unique printed netpage, allowing it to maintain a distinct set of user-supplied values for input fields in the page description 5 for each printed netpage 1.
  • 2 NETPAGE TAGS 2.1 Tag Data Content
  • Each tag 4 identifies an absolute location of that tag within a region of a substrate.
  • Each interaction with a netpage should also provide a region identity together with the tag location. In a preferred embodiment, the region to which a tag refers coincides with an entire page, and the region ID is therefore synonymous with the page ID of the page on which the tag appears. In other embodiments, the region to which a tag refers can be an arbitrary subregion of a page or other surface. For example, it can coincide with the zone of an interactive element, in which case the region ID can directly identify the interactive element.
  • As described in the Applicant's previous applications (e.g. U.S. Pat. No. 6,832,717), the region identity may be encoded discretely in each tag 4. As will be described in more detail below, the region identity may be encoded by a plurality of contiguous tags in such a way that every interaction with the substrate still identifies the region identity, even if a whole tag is not in the field of view of the sensing device.
  • Each tag 4 should preferably identify an orientation of the tag relative to the substrate on which the tag is printed. Orientation data read from a tag enables the rotation (yaw) of the pen 400 relative to the substrate to be determined
  • A tag 4 may also encode one or more flags which relate to the region as a whole or to an individual tag. One or more flag bits may, for example, signal a sensing device to provide feedback indicative of a function associated with the immediate area of the tag, without the sensing device having to refer to a description of the region. A netpage pen may, for example, illuminate an “active area” LED when in the zone of a hyperlink.
  • A tag 4 may also encode a digital signature or a fragment thereof. Tags encoding (partial) digital signatures are useful in applications where it is required to verify a product's authenticity. Such applications are described in, for example, US Publication No. 2007/0108285, the contents of which is herein incorporated by reference. The digital signature may be encoded in such a way that it can be retrieved from every interaction with the substrate. Alternatively, the digital signature may be encoded in such a way that it can be assembled from a random or partial scan of the substrate.
  • It will, of course, be appreciated that other types of information (e.g. tag size etc) may also be encoded into each tag or a plurality of tags, as will be explained in more detail below.
  • 2.2 Position-Coding Pattern Variants
  • Although the adoption of a ubiquitous position-coding Netpage tag pattern for all users and all applications of the Netpage system is desirable, there may be technological or other barriers to such a ubiquitous coding pattern, at least during initial uptake of the Netpage system. One such barrier is a print resolution at which the position-coding pattern is printed. The Netpage tag pattern is advantageously designed to be printed using the Applicant's high-resolution (1600 dpi) pagewidth inkjet printers. The Netpage system complements the Applicant's inkjet printers, which are able to print Netpages having a high degree of functionality and position resolution via the printed tags 4. Ideally, Netpages are printed using ‘Netpage-aware’ printers, which are specifically tailored for printing Netpages.
  • However, the Netpage system is a generic page-based system that need not be inextricably tied to such printers. Preferably, Netpages should be printable using other types of printers, including existing lower resolution (e.g. 300 dpi) print-on-demand printers, such as laser printers and other inkjet printers. Netpages should also be printable using traditional analogue printing presses, which use, for example, established offset, rotogravure or photogravure printing techniques.
  • Self-evidently, position-coding patterns designed to be printed with high-resolution printers may not be printable using lower resolution printing technologies. If a dot spacing in the coding pattern is too small, then individual dots may not be resolvable by a relatively low resolution printing technology. Moreover, the resultant coding pattern, printed by a low-resolution printer, would not be readable by the Netpage pen 400 if adjacent dots are merged together.
  • One approach to this problem would be to provide a ubiquitous Netpage coding pattern, which is suitable for printing by both low-resolution and high-resolution printers. However, this is an unsatisfactory solution to the problem, because the higher degree of functionality and resolution of Netpages printed by the Applicant's pagewidth inkjet printers would be lost unnecessarily.
  • The present invention therefore provides two variants of the Netpage position-coding pattern, both of which are readable by the same Netpage pen 400. A first position-coding pattern (dubbed “Yarrow” by the present Applicant) is suitable for printing by the Applicant's high-resolution (1600 dpi) pagewidth inkjet printers and has a high degree of functionality and resolution. A second position-coding pattern (dubbed “Saffron” by the present Applicant) is suitable for printing by relatively low resolution (e.g. 300 dpi) printers and has a lower degree of functionality and resolution.
  • Importantly, both the first and second position-coding patterns are readable by the Netpage pen 400 by virtue of features common to each pattern. The Netpage pen 400 is able to determine whether it is reading the first or second position-coding pattern by decoding a registration symbol in each tag 4, as will be explained in more detail below. Once the pen 400 has recognized the coding pattern it is reading, decoding of tag data can proceed in accordance with that particular coding pattern.
  • 3 First Position—Coding Pattern (“Yarrow”) 3.1 Background
  • An earlier version of the first position-coding pattern (“Yarrow”) was described in Applicant's U.S. application Ser. Nos. 12/178,611 and 12/178,619 (Attorney Docket Nos. NPT087US and NPT092US). This earlier version of the first position-coding pattern has been modified for compatibility with the second position-coding pattern described herein in Section 4. In particular, the registration symbols now map to translation code symbol values specifically identifying the first position-coding pattern, as described in more detail in Section 3.6.1. The complete first position-coding pattern will now be described in detail below.
  • 3.2 General Tag Structure
  • As described above in connection with FIG. 1, the netpage surface coding generally consists of a dense planar tiling of tags. In the first position-coding pattern (“Yarrow”), each tag 4 is represented by two kinds of elements. Referring to FIGS. 3 and 4, the first kind of element is a target element. Target elements in the form of target dots 301 allow a tag 4 to be located in an image of a coded surface, and allow the perspective distortion of the tag to be inferred. The second kind of element is a data element in the form of a macrodot 302 (see FIG. 6). The macrodots 302 encode data values. As described in the Applicant's earlier disclosures (e.g. U.S. Pat. No. 6,832,717), the presence or absence of a macrodot was be used to represent a binary bit. However, the tag structure of the first position-coding pattern encodes a data value using multi-pulse position modulation, which is described in more detail in Section 3.3.
  • The coding pattern 3 is represented on the surface in such a way as to allow it to be acquired by an optical imaging system, and in particular by an optical system with a narrowband response in the near-infrared. The pattern 3 is typically printed onto the surface using a narrowband near-infrared ink.
  • FIG. 3 shows the structure of a complete tag 4A from the first position-coding pattern, with target elements 301 shown. The tag 4A is square and contains sixteen target elements. Those target elements 301 located at the edges and corners of the tag (twelve in total) are shared by adjacent tags and define the perimeter of the tag. The high number of target elements 301 advantageously facilitates accurate determination of a perspective distortion of the tag 4 when it is imaged by the sensing device 400. This improves the accuracy of tag sensing and, ultimately, position determination.
  • The tag 4A consists of a square array of nine symbol groups 303. Symbol groups 303 are demarcated by the target elements 301 so that each symbol group is contained within a square defined by four target elements. Adjacent symbol groups 303 are contiguous and share targets.
  • Since the target elements 301 are all identical, they do not demarcate one tag from its adjacent tags. Viewed purely at the level of target elements, only symbol groups 303, which define cells of a target grid, can be distinguished—the tags 4A themselves are indistinguishable by viewing only the target elements. Hence, tags 4A must be aligned with the target grid as part of tag decoding.
  • The tag 4A is designed to allow all tag data, with the exception of an embedded data object (see Section 3.9.3), to be recovered from an imaging field of view substantially the size of the tag.
  • 3.3 Symbol Groups
  • As shown in FIG. 4, each of the nine symbol groups 303 comprises twelve data symbols 304A, each data symbol being part of a codeword. In addition, each symbol group 303 comprises a pair of registration symbols—a vertical registration symbol (‘VRS’) and a horizontal registration symbol (‘HRS’). These allow the orientation and/or translation of the tag 4A in the field of view to be determined. Translation refers to the translation of tag(s) relative to the symbol groups 303 in the field of view. In other words, the registration symbols enable alignment of the ‘invisible’ tags with the target grid.
  • Each data symbol 304A is a multi-pulse position modulated (PPM) data symbol. Typically, each PPM data symbol 304A encodes a single 4-bit Reed-Solomon symbol using 3 macrodots in any of 6 positions {p0, p1, p2, p3, p4, p5}, i.e. using 3-6 pulse-position modulation (PPM). However, it will be appreciated that other forms of multi-PPM encoding are equally possible.
  • 3-6 PPM has a range of 20 codes, or 4.3 bits, and is used for Reed-Solomon data symbols and Reed-Solomon redundancy symbols.
  • Each symbol group also contains a 2-6 PPM vertical registration symbol (VRS) and a 2-6 PPM horizontal registration symbol (HRS). These allow the orientation and translation of the tag in the field of view to be determined. This is described in more detail in Section 3.6.1.
  • FIG. 5 shows the layout for a 2-6 PPM or 3-6 PPM data symbol 304.
  • Table 1 defines the mapping from 3-6 PPM symbol values to Reed-Solomon symbol values. Unused symbol values can be treated as erasures.
  • TABLE 1
    3-6PPM to Reed-Solomon symbol mapping
    Corresponding
    Reed-Solomon
    3-6PPM symbol symbol value
    value (p5-p0) (base 16)
    000111 unused
    001011 unused
    001101 0
    001110 1
    010011 2
    010101 3
    010110 4
    011001 5
    011010 6
    011100 7
    100011 8
    100101 9
    100110 a
    101001 b
    101010 c
    101100 d
    110001 e
    110010 f
    110100 unused
    111000 unused
  • 3.4 Targets and Macrodots
  • The spacing of macrodots 302 in both dimensions, as shown in FIG. 6, is specified by the parameter s. It has a nominal value of 127 μm, based on 8 dots printed at a pitch of 1600 dots per inch.
  • Only macrodots 302 are part of the representation of a symbol 304A in the pattern. The outline of a symbol 304A is shown in, for example, FIGS. 3 and 4 merely to elucidate more clearly the structure of the tag 4A.
  • A macrodot 302 is nominally square with a nominal size of (4/8)s. However, it is allowed to vary in size by ±10% according to the capabilities of the device used to produce the pattern.
  • A target 301 is nominally circular with a nominal diameter of (12/8)s. However, it is allowed to vary in size by 110% according to the capabilities of the device used to produce the pattern.
  • Each symbol group 303 has a width of 10s. Therefore, each tag 4A has a width of 30s and a length of 30s. However, it should be noted from FIG. 3 that the tag 4A is configured so that some data symbols 304A extend beyond the perimeter edge of the tag 4A by one macrodot unit (is), and interlock with complementary data symbols from adjacent tags. This arrangement provides a tessellated pattern of data symbols 304A within the target grid. From a data acquisition standpoint, tessellation of data symbols in this way increases the effective length of each tag 4A by one macrodot unit.
  • The macrodot spacing, and therefore the overall scale of the tag pattern, is allowed to vary between 127 μm and 120 μm according to the capabilities of the device used to produce the pattern. Any deviation from the nominal scale is recorded in each tag (via a macrodot size ID field) to allow accurate generation of position samples.
  • These tolerances are independent of one another. They may be refined with reference to particular printer characteristics.
  • 3.5 Field of View
  • As mentioned above, the tag 4A is designed to allow all tag data to be recovered from an imaging field of view roughly the size of the tag. Any data common to a set of contiguous tags only needs to appear once within each tag, since fragments of the common data can be recovered from adjacent tags. Any data common only to a column or row of tags may appear twice within the tag—i.e. once in each horizontal half or vertical half of the tag respectively. However, special symbol arrangements may be used to ameliorate this requirement, as described in more detail in Section 3.6.3. Finally, any data unique to the tag must appear four times within the tag—i.e. once in each quadrant.
  • Although data which is common to a set of tags, in one or both spatial dimensions, may be decoded from fragments from adjacent tags, pulse-position modulated values are best decoded from spatially-coherent samples (i.e. from a whole symbol as opposed to partial symbols at opposite sides of the field of view), since this allows raw sample values to be compared without first being normalised. This implies that the field of view must be large enough to contain two complete copies of each such pulse-position modulated value. The tag is designed so that the maximum extent of a pulse-position modulated value is three macrodots (see FIG. 3). Making the field of view at least as large as the tag plus three macrodot units guarantees that pulse-position modulated values can be coherently sampled.
  • The only exceptions are the translation codes described in the next section, which are four macrodot units long. However, these are highly redundant and the loss of up to four symbols at the edge of the field of view is not a problem.
  • 3.6 Encoded Codes and Codewords
  • In this section (Section 3.6), each symbol in FIGS. 8 to 12 is shown with a unique label. The label consists of an alphabetic prefix which identifies which codeword the symbol is part of, and a numeric suffix which indicates the index of the symbol within the codeword. For simplicity only data symbols 304A are shown, not registration symbols.
  • Although some symbol labels are shown rotated to indicate the symmetry of the layout of certain codewords, the layout of each symbol is determined by its position within a symbol group and not by the rotation of the symbol label (as described in, for example, the Applicant's US Publication No. 2006/146069).
  • 3.6.1 Registration Symbols
  • Each registration symbol is encoded using 2-6 PPM. FIG. 7 shows the layout of the registration symbol.
  • As shown in FIG. 4, the horizontal and vertical registration symbols each appear once within a symbol group 303. The registration symbols of an entire tag typically indicate the vertical and horizontal translation of the tag by coding two orthogonal translation codes, and the orientation of the tag by coding two orthogonal direction codes.
  • Each registration symbol may also encode a one-bit symbol of a flag code (see Section 3.6.2).
  • Table 2 defines the mapping from 2-6 PPM registration symbol values to flag code, direction code and translation code symbol values.
  • TABLE 2
    2-6PPM registration symbol values to flag code, direction code and
    translation code symbol mapping
    2-6PPM translation direction flag code
    symbol value code symbol code symbol symbol
    {p5-p0} value value value
    001, 001 0 0 unspecified
    100, 010 1
    001, 010 1 0 0
    000, 101 1
    010, 100 1 0
    101, 000 1
    010, 001 2 0 unspecified
    100, 100 1
    000, 011 3 0
    000, 110 1
    011, 000 4 0
    110, 000 1
    001, 100 unused
    010, 010
    100, 001
  • The first position-coding pattern (“Yarrow”) uses the first eight registration symbol values in Table 2 i.e. those registration symbol values mapping to a translation code symbol value of 0, 1 or 2. In other words, if the registration symbol value maps to a translation code symbol value of 0, 1 or 2, then the position-coding pattern is identified as the first position-coding pattern having 9 symbol groups 303 contained in one tag 4A.
  • The additional translation code symbol values (i.e. 3 and 4) shown in Table 2 are reserved for the second position-coding pattern (“Saffron”) described in Section 4.6.1. Thus, if the registration symbol value maps to a translation code symbol value of 3 or 4, then the position-coding pattern is identified as the second position-coding pattern having 4 symbol groups 303 contained in one tag 4B. In this way, the registration symbol provides a means of distinguishing the first position-coding pattern from the second position-coding pattern. Subsequent decoding of PPM data symbols proceeds in accordance with the position-coding pattern identified from decoding the registration symbol(s).
  • In the first position-coding pattern, each row of symbol groups and each column of symbol groups encodes a three-symbol 3-ary cyclic position code. (The Applicant's cyclic position codes are described in U.S. Pat. No. 7,082,562, the contents of which is herein incorporated by reference). The code consists of the codeword (0, 1, 2) and its cyclic shifts. The code has a minimum distance of 3, allowing a single symbol error to be corrected. For each of the two orthogonal translations, the three translation codes of an entire tag form a code with a minimum distance of 9, allowing 4 symbol errors to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy.
  • The translation code symbol in the middle of the codeword (i.e. 1) is mapped to a set of 2-6 PPM symbol values that are each other's reverse, while the two translation code symbols at the ends of the codeword (i.e. 0 and 2) are each mapped to a set of 2-6 PPM symbol values that are the reverses of the 2-6 PPM symbol values in the other set. Thus a 0 read upside-down (i.e. rotated 180 degrees) becomes a 2, and vice versa, while a 1 read upside-down remains a 1. This allows translation to be determined independently of rotation.
  • Furthermore, in the first position-coding pattern, each 2-6 PPM symbol value and its reverse map to opposite direction code symbol values (Table 2). The vertical registration symbols of an entire tag encode 9 symbols of a vertical direction code. This has a minimum distance of 9, allowing 4 symbol errors to be corrected. The horizontal registration symbols of an entire tag encode 9 symbols of a horizontal direction code. This has a minimum distance of 9, allowing 4 symbol errors to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy. Any erasures detected during decoding of a translation code can also be used during decoding of a direction code, and vice versa. Together the orthogonal direction codes allow the orientation of the tag to be determined.
  • The top left corner of an un-rotated tag is identified by a symbol group whose translation symbols are both zero and whose direction symbols are both zero.
  • 3.6.2 Active Area Flag Code
  • The flag symbol consists of one bit of data, and is encoded in some of the vertical and horizontal registration symbols, as shown in Table 2.
  • The flag symbol is unique to a tag and is therefore coded redundantly in each quadrant of the tag. Since the flag symbol is encoded in each registration code symbol, it appears four times within each quadrant (assuming the central registration code symbols participate in each quadrant, as usually supported by the minimum field of view). Four symbols form a code with a minimum distance of 4, allowing 1 error to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy. Any errors detected during decoding of translation and/or direction codes can also be used to flag erasures during decoding of the flag code. Since the flag code encodes the active area flag, it can meaningfully be interpreted as set even if ambiguous.
  • 3.6.3 Coordinate Data
  • The tag 4A contains an x-coordinate codeword and a y-coordinate codeword used to encode the x and y coordinates of the tag respectively. The codewords are of a shortened 24-ary (11, 3) or (11, 5) Reed-Solomon code. The tag therefore encodes either 12-bit or 20-bit coordinates. An (11, 5) code is used if the <region has long coordinates> flag in the region flags is set (see Table 5). An (11, 3) code is used otherwise.
  • Each x coordinate codeword is replicated twice within the tag—in each horizontal half (“north” and “south”), and is constant within the column of tags containing the tag. Likewise, each y coordinate codeword is replicated twice within the tag—in each vertical half (“east” and “west”), and is constant within the row of tags containing the tag. This guarantees that an image of the tag pattern large enough to contain a complete tag is guaranteed to contain a complete instance of each coordinate codeword, irrespective of the alignment of the image with the tag pattern. The instance of either coordinate codeword may consist of fragments from different tags.
  • It should be noted that, in the first position-coding pattern, some coordinate symbols are not replicated and are placed on the dividing line between the two halves of the tag. This arrangement saves tag space since there are not two complete replications of each x-coordinate codeword and each y-coordinate codeword contained in a tag. Since the field of view is at least three macrodot units larger than the tag (as discussed in Section 3.10), the coordinate symbols placed on the dividing line (having a width 2 macrodot units) are still captured when the surface is imaged. Hence, each interaction with the coded surface still provides the tag location.
  • The layout of the x-coordinate codeword is shown in FIG. 8. The layout of the y-coordinate codeword is shown in FIG. 9. It can be seen that x-coordinate symbols X4, X5, X6, X7, X8 and X9 are placed in a central column 310 of the tag 4A, which divides the eastern half of the tag from the western half. Likewise, the y-coordinate symbols Y4, Y5, Y6, Y7, Y8 and Y9 are placed in a central row 312 of the tag 4A, which divides the northern half of the tag from the southern half.
  • The central column 310 and central row 312 each have a width q, which corresponds to a width of 2s, where s is the macrodot spacing.
  • 3.6.4 Common Data
  • The tag 4A contains four codewords A, B, C and D which encode information common to a set of contiguous tags in a surface region. The A codeword is of a 24-ary (15, 5) Reed-Solomon code. The B, C and D codewords are of a 24-ary (15, 7) or (15, 9) Reed-Solomon code. The tag therefore encodes either 112 or 136 bits of information common to a set of contiguous tags. A (15, 9) code is used for the B, C and D codewords if the <region has a long region ID> flag in the region flags is set (see Table 6). A (15, 7) code is used otherwise.
  • The common codewords are replicated throughout a tagged region. This guarantees that an image of the tag pattern large enough to contain a complete tag is guaranteed to contain a complete instance of each common codeword, irrespective of the alignment of the image with the tag pattern. The instance of each common codeword may consist of fragments from different tags.
  • The layout of the common codewords is shown in FIG. 10. The codewords have the same layout, rotated 90 degree relative to each other.
  • 3.6.5 Optional Data
  • The tag optionally contains a codeword E. This codeword may be used to encode a secret-key signature or a fragment of an embedded data object. These are discussed further in Sections 3.6.6 and Section 3.9.3 respectively. The codeword is of a 24-ary (15, 9) Reed-Solomon code.
  • The layout of the optional codeword is shown in FIG. 11.
  • 3.6.6 Secret-Key Signature
  • The tag optionally contains an entire secret-key digital signature common to a set of contiguous tags in a surface region. The signature consists of sixteen 24-ary symbols (i.e. symbol E15 is also used). The tag therefore optionally encodes up to 64 bits of secret-key signature data.
  • The signature is replicated throughout a tagged region. This guarantees that an image of the tag pattern large enough to contain a complete tag is guaranteed to contain a complete instance of the signature, irrespective of the alignment of the image with the tag pattern. The instance of the signature may consist of fragments from different tags.
  • The signature, if present, is encoded in the E codeword described in Section 3.6.5.
  • Digital signatures are discussed further in Section 3.9.4.
  • 3.6.7 Complete Tag
  • FIG. 12 shows the layout of the data of a complete tag, with each symbol group comprising ten data symbols. The vertical and horizontal registration symbols are not shown in FIG. 12.
  • 3.7 Reed-Solomon Encoding 3.7.1 Reed-Solomon Codes
  • All data is encoded using a Reed-Solomon code defined over GF(24). The code has a natural length n of 15. The dimension k of the code is chosen to balance the error correcting capacity and data capacity of the code, which are (n−k)/2 and k symbols respectively.
  • The code may be punctured, by removing high-order redundancy symbols, to obtain a code with reduced length and reduced error correcting capacity. The code may also be shortened, by replacing high-order data symbols with zeros, to obtain a code with reduced length and reduced data capacity. Both puncturing and shortening can be used to obtain a code with particular parameters. Shortening is preferred, where possible, since this avoids the need for erasure decoding.
  • The code has the following primitive polynomial:

  • p(x)=x 4 +x+1
  • The code has the following generator polynomial:
  • g ( x ) = i = 1 n - k ( x + α i )
  • For a detailed description of Reed-Solomon codes, refer to Wicker, S. B. and V. K. Bhargava, eds., Reed-Solomon Codes and Their Applications, IEEE Press, 1994.
  • 3.7.2 Codeword Organization
  • As shown in FIG. 13, redundancy coordinates ri and data coordinates di of the code are indexed from left to right according to the power of their corresponding polynomial terms. The symbols Xi of a complete codeword are indexed from right to left to match the bit order of the data. The bit order within each symbol is the same as the overall bit order.
  • 3.7.3 Code Instances
  • Table 3 defines the parameters of the different codes used in the tag.
  • TABLE 3
    Codeword instances
    error-
    correcting data
    length dimension capacity capacitya
    name description (n) (k) (symbols) (bits)
    X, Y coordinate 11a 3 4 12
    codewords (see 5 3 20
    Section 3.6.3)
    A first common 15 5 5 20
    codeword
    B, C, D other common 15 7 3 28
    codewords (see 9 3 36
    Section 3.6.4)
    E optional 15 9 3 36
    codeword (see
    Section 3.6.5)
    ashortened
  • 3.7.4 Cyclic Redundancy Check
  • The region ID is protected by a 16-bit cyclic redundancy check (CRC). This provides an added layer of error detection after Reed-Solomon error correction, in case a codeword containing a part of the region ID is mis-corrected.
  • The CRC has the following generator polynomial:

  • g(x)=x 16 +x 12 +x 5+1
  • The CRC is initialised to 0xFFFF. The most significant bit of the region ID is treated as the most significant coefficient of the data polynomial.
  • 3.8 Tag Coordinate Space
  • The tag coordinate space has two orthogonal axes labelled x and y respectively. When the positive x axis points to the right then the positive y axis points down.
  • The surface coding does not specify the location of the tag coordinate space origin on a particular tagged surface, nor the orientation of the tag coordinate space with respect to the surface. This information is application-specific. For example, if the tagged surface is a sheet of paper, then the application which prints the tags onto the paper may record the actual offset and orientation, and these can be used to normalise any digital ink subsequently captured in conjunction with the surface.
  • The position encoded in a tag is defined in units of tags and is defined to be the centre of the top left target. The origin of a particular tag pattern is therefore the centre of the top left target of the tag that encodes coordinate pair (0, 0).
  • The surface coding is optionally displaced from its nominal position relative to the surface by an amount derived from the region ID. This ensures that the utilisation of a pagewidth digital printhead used to print the surface coding is uniform. The displacement of the surface coding is negative, hence the displacement of the region described by the surface coding is positive relative to the surface coding. The magnitude of the displacement is the region ID modulo the width of the tag in 1600 dpi dots (i.e. 240). To accommodate non-1600 dpi printers the actual magnitude of the displacement may vary from its nominal value by up to half the dot pitch of the printer.
  • 3.9 Tag Information Content 3.9.1 Field Definitions
  • Table 4 defines the information fields embedded in the first position-coding pattern.
  • TABLE 4
    Field Definitions
    width
    field (bits) description
    unique to tag
    active area flag 1 A flag indicating whether the areaa immediately
    surrounding a tag intersects an active area.
    x coordinate 12 or The unsigned x coordinate of the tagb.
    20
    y coordinate 12 or The unsigned y coordinate of the tagb.
    20
    common to
    tagged region
    encoding
    2 The format of the encoding.
    format 0: the present encoding. Other values are reserved
    region flags 10 Flags controlling the interpretation of region data
    (see Table 5).
    coordinate 2 A value (p) indicating the precision of x and y
    precision coordinates according to the formula 8 + 4p.
    macrodot size 4 The ID of the macrodot size.
    ID
    region ID 72 or The ID of the region containing the tags.
    96
    CRC 16 A CRC of the region ID (see Section 3.7.4)
    secret-key 64 An optional secret-key signature of the region.
    signature
    athe diameter of the area, centered on the tag, is nominally 2.5 times the diagonal size of the tag; this is to accommodate the worst-case distance between the nib position and the imaged tag
    ballows a coordinate value ranges of 14.8 m and 3.8 km for the minimum tag size of 3.6 mm (based on the minimum macrodot size of 120 microns and 30 macrodots per tag)
  • An active area is an area within which any captured input should be immediately forwarded to the corresponding Netpage server 10 for interpretation. This also allows the Netpage server 10 to signal to the user that the input has had an immediate effect. Since the server has access to precise region definitions, any active area indication in the surface coding can be imprecise so long as it is inclusive.
  • TABLE 5
    Region flags
    bit meaning
    0 Region is interactive, i.e. x and y-coordinates are present.
    1 Region is active, i.e. the entire region is an active area. Otherwise
    active areas are identified by individual tags' active area flags.
    2 Region ID is not serializeda.
    3 Region has secret-key signature (see Section 3.9.4)
    4 Region has embedded data.
    5 Embedded data is a public-key signature (see Sections 3.9.3
    and 3.9.4).
    6 Region has long coordinatesb.
    7 Region has a long region IDc.
    8 Region ID is an EPC.
    9 Region is displaced according to region ID
    aFor an EPC this means that the serial number is replaced by a layout number, to allow the package design associated with a product to vary over time (see US 2007/0108285, the contents of which is herein incorporated by reference).
    bHence the X and Y Reed-Solomon codewords have less redundancy.
    cHence, the B, C and D Reed-Solomon codewords have less redundancy.
  • 3.9.2 Mapping of Fields to Codewords
  • Table 6, Table 7 and Table 8 define how the information fields map to codewords in the first position-coding pattern.
  • TABLE 6
    Mapping of fields to coordinate codewords X and Y
    X and Y
    codeword
    data codeword
    codeword field capacity field width field bits bits
    X x coordinate 12 all all
    20
    Y y coordinate 12 all all
    20
  • TABLE 7
    Mapping of fields to common codewords A, B, C and D
    A, B, C and
    D codeword
    data field field codeword
    codeword field capacity width bits bits
    A encoding format any 2 all 1:0
    region flags 10 all 11:2 
    macrodot size ID 4 all 15:12
    region ID 28 4 71:68 19:16
    36 95:92
    B CRC any 16 all 15:0 
    region ID 28 12 11:0  27:16
    36 20 19:0  35:16
    C region ID 28 39:12 all
    36 55:20
    D region ID 28 67:40 all
    36 91:56
  • TABLE 8
    Mapping of fields to optional codeword E
    E
    codeword
    data field codeword
    codeword field capacity width field bits bits
    E data fragment 36 all all
    secret-key digital 64a all all
    signature
    aEntire codeword (including 16th symbol) is used for data i.e. there is no redundancy
  • As shown in Table 8, codeword E either contains a data fragment or a secret-key signature. These are described in Section 3.9.3 and Section 3.9.4 respectively. The secret-key signature is present in a particular tag if the <region has secret-key signature> flag in the region flags is set, and the tag's active area flag is set. The data fragment is present in a particular tag if the <region contains embedded data> flag in the region flags is set and the tag does not already contain a secret-key signature.
  • When the region flags indicate that a particular codeword is absent then the codeword is not coded in the tag pattern, i.e. there are no macrodots representing the codeword. This applies to the X, Y and E codewords i.e. the X and Y codewords are present if the <region is interactive> flag in the region flags is set. The E codeword is present if a secret-key signature or data fragment is present.
  • 3.9.3 Embedded Data Object
  • If the <region has embedded data> flag in the region flags is set then the surface coding contains embedded data. The embedded data is encoded in multiple contiguous tags' data fragments, and is replicated in the surface coding as many times as it will fit.
  • The embedded data is encoded in such a way that a random and partial scan of the surface coding containing the embedded data can be sufficient to retrieve the entire data. The scanning system reassembles the data from retrieved fragments, and reports to the user when sufficient fragments have been retrieved without error.
  • As shown in Table 9, each block has a data capacity of 176-bits. The block data is encoded in the data fragments of a contiguous group of six tags arranged in a 3×2 rectangle.
  • The block parameters are as defined in Table 9. The E codeword of each tag may encode a fragment of the embedded data.
  • TABLE 9
    Block parameters
    parameter value description
    w
    3 The width of the block, in tags
    h
    2 The height of the block, in tags.
    b 176 The data capacity of the block, in bits
  • If the E codeword of a particular tag does not contain a fragment of the embedded data, then the pen 400 can discover this implicitly by the failure of the codeword to decode, or explicitly from the tag's active area flag.
  • Data of arbitrary size may be encoded into a superblock consisting of a contiguous set of blocks, typically arranged in a rectangle. The size of the superblock may be encoded in each block.
  • The superblock is replicated in the surface coding as many times as it will fit, including partially along the edges of the surface coding.
  • The data encoded in the superblock may include, for example, more precise type information, more precise size information, and more extensive error detection and/or correction data.
  • 3.9.4 Digital Signatures
  • As described in Section 3.6.6, a region may contain a digital signature.
  • If the <region has a secret-key signature> flag in the region flags is set, then the region has a secret-key digital signature. In an online environment the secret-key signature can be verified, in conjunction with the region ID, by querying a server with knowledge of the secret-key signature or the corresponding secret key.
  • If the region contains embedded data and the <embedded data is a public-key signature> flag in the region flag is set, then the surface coding contains an embedded public-key digital signature of the region ID.
  • In an online environment any number of signature fragments can be used, in conjunction with the region ID and optionally the secret-key signature, to validate the public-key signature by querying a server with knowledge of the full public-key signature or the corresponding private key.
  • In an offline (or online) environment the entire public-key signature can be recovered by reading multiple tags, and can then be verified using the corresponding public signature key. The actual length and type of the signature are determined from the region ID during signature validation i.e. typically from a previously-retrieved digital signature associated with a sequence of region IDs.
  • Digital signature verification is discussed in the Applicant's US Publication No. 2007/0108285, the contents of which are herein incorporated by reference.
  • 3.10 Tag Imaging
  • The minimum imaging field of view required to guarantee acquisition of data from an entire tag 4A has a diameter of 46.7s (i.e. ((3×10)+3)√2s), allowing for arbitrary rotation and translation of the surface coding in the field of view. Notably, the imaging field of view does not have to be large enough to guarantee capture of an entire tag—the arrangement of the data symbols within each tag ensures that a any square portion of length (l+3s) captures the requisite information in full, irrespective of whether a whole tag is actually visible in the field-of-view. As used herein, l is defined as the length of a tag.
  • In terms of imaging the coding pattern, the imaging field-of-view is typically a circle. Accordingly, the imaging field-of-view should preferably have diameter of at least (l+3s)√2 and less than two tag diameters. Importantly, the field-of-view is not required to be at least two tag diameters, in contrast with prior art tag designs, because it is not essential to capture an entire tag 4A in the field of view.
  • The extra three macrodot units ensure that pulse-position modulated values can be decoded from spatially coherent samples. Furthermore, the extra three macrodot units ensure that all requisite data symbols 304A can be read with each interaction. These include the coordinate symbols from a central column or row of a tag (see Section 3.6.3) having a width of 2s.
  • In the present context, a “tag diameter” is given to mean the length of a tag diagonal.
  • Given a maximum macrodot spacing of 127 microns, this gives a required field of view of 5.93 mm.
  • 4 Second Position—Coding Pattern (“Saffron”) 4.1 Background
  • As will be appreciated from the following description, the second position-coding pattern bears many similarities with the first position coding pattern. The most notable difference is that each tag comprises 4 rather than 9 symbol groups 303. Furthermore, the registration symbols in the second position-coding pattern map to translation code symbol values (3, 4) specifically identifying the second position-coding pattern, as described earlier in Section 3.6.1.
  • The complete second position-coding pattern will now be described in detail below.
  • 4.2 General Tag Structure
  • In common with the first position-coding pattern, each tag 4B of the second position-coding pattern is represented by two kinds of elements. Referring to FIGS. 14 and 15, the first kind of element is a target element. Target elements in the form of target dots 301 allow the tag 4B to be located in an image of a coded surface, and allow the perspective distortion of the tag to be inferred. The second kind of element is a data element in the form of a macrodot 302 (see FIG. 6). The macrodots 302 encode data values.
  • FIG. 14 shows the structure of a complete tag 4B from the second position-coding pattern, with target elements 301 shown. The tag 4B is square and contains nine target elements. Those target elements 301 located at the edges and corners of the tag (eight in total) are shared by adjacent tags and define the perimeter of the tag 4B.
  • The tag 4B consists of a square array of four symbol groups 303. Symbol groups 303 are demarcated by the target elements 301 so that each symbol group is contained within a square defined by four target elements. Adjacent symbol groups 303 are contiguous and share targets.
  • Since the target elements 301 are all identical, they do not demarcate one tag from its adjacent tags. Viewed purely at the level of target elements, only symbol groups 303, which define cells of a target grid, can be distinguished—the tags 4B themselves are indistinguishable by viewing only the target elements. Hence, tags 4B must be aligned with the target grid as part of tag decoding.
  • The tag 4B is designed to allow all tag data to be recovered from an imaging field of view substantially the size of the tag.
  • 4.3 Symbol Groups
  • As shown in FIG. 15, each of the nine symbol groups 303 comprises eight data symbols 304B, each data symbol being part of a codeword. In addition, each symbol group 303 comprises a pair of registration symbols—a vertical registration symbol (‘VRS’) and a horizontal registration symbol (‘HRS’). These allow the orientation and/or translation of the tag 4B in the field of view to be determined.
  • Each data symbol 304B is a multi-pulse position modulated (PPM) data symbol. Typically, each PPM data symbol 304B encodes 5-bits using 2-9 PPM encoding. i.e. 2 macrodots in any of 9 positions {p0, p2, p3, p4, p5, p6, p7, p8}
  • FIG. 16 shows the layout for a 2-9 PPM data symbol 304B.
  • Each symbol group also contains a 2-6 PPM vertical registration symbol (VRS) and a 2-6 PPM horizontal registration symbol (HRS), as described in Sections 3.3 and 3.6.1 above.
  • Table 10 defines the mapping from 2-6 PPM symbol values to data symbol values. Unused symbol values can be treated as erasures.
  • TABLE 10
    2-9PPM symbol to data symbol value mapping
    2-9PPM symbol
    value data symbol value
    (p8-p0) (base 16)
    000, 000, 011  0
    000, 000, 101  1
    000, 000, 110  2
    000, 001, 001  3
    000, 001, 010  4
    000, 001, 100  5
    000, 010, 001  6
    000, 010, 010  7
    000, 010, 100  8
    000, 011, 000  9
    000, 100, 001 a
    000, 100, 010 b
    000, 100, 100 c
    000, 101, 000 d
    000, 110, 000 e
    001, 000, 001 f
    001, 000, 010 10
    001, 000, 100 11
    001, 001, 000 12
    001, 010, 000 13
    001, 100, 000 14
    010, 000, 001 15
    010, 000, 010 16
    010, 000, 100 17
    010, 001, 000 18
    010, 010, 000 19
    010, 100, 000 1a
    011, 000, 000 1b
    100, 000, 001 1c
    100, 000, 010 1d
    100, 000, 100 1e
    100, 001, 000 1f
    100, 010, 000 unused
    100, 100, 000 unused
    101, 000, 000 unused
    110, 000, 000 unused
  • 4.4 Targets and Macrodots
  • The spacing of macrodots 302 in both dimensions, as shown in FIG. 6, is specified by the parameter s. In the second position-coding pattern, it has a nominal value of 159 μm, based on 10 dots printed at a pitch of 1600 dots per inch.
  • A macrodot 302 is nominally square with a nominal size of (5/10)s. However, it is allowed to vary in size by 110% according to the capabilities of the device used to produce the pattern.
  • A target 301 is nominally circular with a nominal diameter of (15/10)s. However, it is allowed to vary in size by 110% according to the capabilities of the device used to produce the pattern.
  • Each symbol group 303 has a width of 10s. Therefore, each tag 4B has a width of 20s and a length of 20s. However, it should be noted from FIG. 15 that the tag 4B is configured so that some data symbols 304 extend beyond the perimeter edge of the tag 4B by one macrodot unit (1s), and interlock with complementary data symbols from adjacent tags. This arrangement provides a tessellated pattern of data symbols 304A within the target grid. From a data acquisition standpoint, tessellation of data symbols in this way increases the effective length of each tag 4B by one macrodot unit.
  • The macrodot spacing, and therefore the overall scale of the tag pattern, is allowed to vary between 152 μm and 169 μm according to the capabilities of the device used to produce the pattern. Any deviation from the nominal scale is recorded in each tag (via a macrodot size ID field) to allow accurate generation of position samples.
  • These tolerances are independent of one another. They may be refined with reference to particular printer characteristics.
  • 4.5 Field of View
  • As mentioned above, the tag 4B is designed to allow all tag data to be recovered from an imaging field of view roughly the size of the tag.
  • Although data which is common to a set of tags, in one or both spatial dimensions, may be decoded from fragments from adjacent tags, pulse-position modulated values are best decoded from spatially-coherent samples (i.e. from a whole symbol as opposed to partial symbols at opposite sides of the field of view), since this allows raw sample values to be compared without first being normalised. This implies that the field of view must be large enough to contain two complete copies of each such pulse-position modulated value. The tag is designed so that the maximum extent of a pulse-position modulated value is four macrodots. Making the field of view at least as large as the tag plus four macrodot units guarantees that pulse-position modulated values can be coherently sampled.
  • 4.6 Encoded Codes and Codewords
  • In this section (Section 4.6), each symbol in FIGS. 17 to 20 is shown with a unique label. The label consists of an alphabetic prefix which identifies which codeword the symbol is part of, and a numeric suffix which indicates the index of the symbol within the codeword. For simplicity only data symbols 304B are shown in FIGS. 17 to 20, not registration symbols.
  • Although some symbol labels are shown rotated to indicate the symmetry of the layout of certain codewords, the layout of each symbol is determined by its position within a symbol group and not by the rotation of the symbol label (as described in, for example, the Applicant's US Publication No. 2006/146069).
  • 4.6.1 Registration Symbols
  • Each registration symbol of the second position-coding pattern is encoded using 2-6 PPM, as described above in Section 3.6.1 and FIG. 7. Furthermore, each registration symbol of the second position-coding pattern is positioned and configured in the same way as each registration symbol of the first position-coding pattern. However, the second position-coding pattern utilizes only those registration symbol values mapping to the translation code symbol values (3, 4). This enables the registration symbol to identify the second position-coding pattern, and distinguish it from the first position-coding pattern.
  • In other words, if the registration symbol value maps to a translation code symbol value of 3 or 4, then the position-coding pattern is identified as the second position-coding pattern having 4 symbol groups 304B contained in one tag 4B.
  • In the first position-coding pattern, each row of symbol groups and each column of symbol groups encodes a two-symbol 2-ary cyclic position code. (The Applicant's cyclic position codes are described in U.S. Pat. No. 7,082,562, the contents of which is herein incorporated by reference). The code consists of the codeword (3, 4) and its cyclic shifts. For each of the two orthogonal translations, the two translation codes of an entire tag form a code with a minimum distance of 4, allowing 1 symbol error to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy.
  • The two translation code symbols (3 and 4) are each mapped to a set of 2-6 PPM symbol values that are the reverses of the 2-6 PPM symbol values in the other set. Thus a 3 read upside-down (i.e. rotated 180 degrees) becomes a 4, and vice versa. This allows translation to be determined independently of rotation.
  • Furthermore, in the first position-coding pattern, each 2-6 PPM symbol value and its reverse map to opposite direction code symbol values (Table 2). The vertical registration symbols of an entire tag encode 4 symbols of a vertical direction code. This has a minimum distance of 4, allowing 1 symbol error to be corrected. The horizontal registration symbols of an entire tag encode 4 symbols of a horizontal direction code. This has a minimum distance of 4, allowing 1 symbol error to be corrected. If additional symbols are visible within the field of view then they can be used for additional redundancy. Any erasures detected during decoding of a translation code can also be used during decoding of a direction code, and vice versa. Together the orthogonal direction codes allow the orientation of the tag to be determined.
  • The top left corner of an un-rotated tag is identified by a symbol group whose translation symbols are both zero and whose direction symbols are both zero.
  • Although as shown in Table 2, the 2-6 PPM registration symbol does not allow flag codes for the second position-coding pattern, it will be appreciated that a 3-6 PPM registration symbol mapping to 20 available symbol values would allow the second position-coding pattern to contain flag codes, if desired. In this case, 12 registration symbol values (3×2×2) would be used for the first position-coding pattern and 8 registration symbols value (2×2×2) would be used for the second position-coding pattern.
  • 4.6.2 Coordinate Data
  • The tag 4B contains an x-coordinate codeword and a y-coordinate codeword used to encode the x and y coordinates of the tag respectively. The codewords are of a shortened 25-ary (4, 2) Reed-Solomon code. The tag therefore encodes 10-bit coordinates.
  • Each x coordinate codeword is constant within the column of tags containing the tag. Likewise, each y coordinate codeword is constant within the row of tags containing the tag.
  • It should be noted that, in the second position-coding pattern, none of the coordinate symbols are replicated. Instead, all coordinate symbols are placed in either one column or one row of the tag. This arrangement saves tag space since it obviates the requirement for each tag to contain two complete replications of each x-coordinate codeword and each y-coordinate codeword. Since the field of view is at least four macrodot units larger than the length of the tag, the coordinate symbols placed in a column or row line having a width of three macrodot units are still captured when the surface is imaged. Hence, each interaction with the coded surface still provides the tag location. The instance of either coordinate codeword may consist of fragments from different tags.
  • FIG. 17 shows the layout of an x-coordinate codeword X. The outline of the codeword X is shown in bold. It should be noted that the entire x-coordinate codeword is encoded by data symbols X0, X1, X2 and X3 contained in a single column 313 of width v. Likewise, as shown in FIG. 18, the entire y-coordinate codeword is encoded by data symbols Y0, Y1, Y2 and Y3 contained in a single row 315 of width v.
  • The column of x-coordinate symbols and the row of y-coordinate symbols each have a width v, which corresponds to a width of 3s, where s is the macrodot spacing. Provided that an imaged portion of the second position-coding pattern contains a square of length (l+v), where l is the length of the tag, then the imaged portion is guaranteed to contain the x-coordinate codeword and the y-coordinate codeword.
  • 4.6.3 Common Data
  • The tag 4B contains one codeword A which encodes information common to a set of contiguous tags in a surface region. The A codeword is of a shortened 25-ary (24, 16) Reed-Solomon code. The tag 4B therefore encodes 80 bits of information common to a set of contiguous tags.
  • The common codeword is replicated throughout a tagged region. This guarantees that an image of the tag pattern large enough to contain a complete tag is guaranteed to contain a complete instance of the common codeword, irrespective of the alignment of the image with the tag pattern. The instance of the common codeword may consist of fragments from different tags.
  • The layout of the common codeword is shown in FIG. 19.
  • 4.6.3 Complete Tag
  • FIG. 20 shows the layout of the data of a complete tag 4B, with each symbol group comprising eight data symbols. The vertical and horizontal registration symbols are not shown in FIG. 20.
  • 4.7 Reed-Solomon Encoding 4.7.1 Reed-Solomon Codes
  • All data of the second position-coding pattern is encoded using a Reed-Solomon code defined over GF(25). The code has a natural length n of 31. The dimension k of the code is chosen to balance the error correcting capacity and data capacity of the code, which are (n−k)/2 and k symbols respectively.
  • The code may be punctured, by removing high-order redundancy symbols, to obtain a code with reduced length and reduced error correcting capacity. The code may also be shortened, by replacing high-order data symbols with zeros, to obtain a code with reduced length and reduced data capacity. Both puncturing and shortening can be used to obtain a code with particular parameters. Shortening is preferred, where possible, since this avoids the need for erasure decoding.
  • The code has the following primitive polynomial:

  • p(x)=x 5 +x 2+1
  • The code has the following generator polynomial:
  • g ( x ) = i = 1 n - k ( x + α i )
  • For a detailed description of Reed-Solomon codes, refer to Wicker, S. B. and V. K. Bhargava, eds., Reed-Solomon Codes and Their Applications, IEEE Press, 1994.
  • 4.7.2 Codeword Organization
  • As shown in FIG. 21, redundancy coordinates ri and data coordinates di of the code are indexed from left to right according to the power of their corresponding polynomial terms.
  • The symbols Xi of a complete codeword are indexed from right to left to match the bit order of the data. The bit order within each symbol is the same as the overall bit order.
  • 4.7.3 Code Instances
  • Table 11 defines the parameters of the different codes used in the tag 4B.
  • TABLE 11
    Codeword instances
    error-
    correcting data
    length dimension capacity capacitya
    name description (n) (k) (symbols) (bits)
    X, Y coordinate  4a 2 1 10
    codewords (see
    Section 4.6.3)
    A first common 24a 16 8 80
    codeword
    ashortened
  • 4.7.4 Cyclic Redundancy Check
  • The region ID is protected by a 16-bit cyclic redundancy check (CRC). This provides an added layer of error detection after Reed-Solomon error correction, in case a codeword containing a part of the region ID is mis-corrected.
  • The CRC has the following generator polynomial:

  • g(x)=x 16 +x 12 +x 5+1
  • The CRC is initialised to 0xFFFF. The most significant bit of the region ID is treated as the most significant coefficient of the data polynomial.
  • 4.8 Tag Coordinate Space
  • The tags 4B of the second position-coding pattern use a coordinate space corresponding to the first position-coding pattern having two orthogonal axes labelled x and y respectively. For a further discussion, see Section 3.8 above.
  • 4.9 Tag Information Content 4.9.1 Field Definitions
  • Table 12 defines the information fields embedded in the second position-coding pattern.
  • TABLE 12
    Field Definitions
    width
    field (bits) description
    unique to tag
    x coordinate 10 The unsigned x coordinate of the taga.
    y coordinate 10 The unsigned y coordinate of the taga.
    common to tagged
    region
    encoding format
    2 The format of the encoding.
    0: the present encoding. Other values are
    reserved
    region flags 6 Flags controlling the interpretation of region
    data (see Table 13).
    macrodot size ID 4 The ID of the macrodot size.
    region ID 52 The ID of the region containing the tags.
    CRC 16 A CRC of the region ID (see Section 4.7.4)
    aallows a coordinate value ranges of 3.1 m for the minimum tag size of 3.04 mm (based on the minimum macrodot size of 152 microns and 20 macrodots per tag)
  • TABLE 13
    Region flags
    bit meaning
    0 Region is interactive, i.e. x and y-coordinates are present.
    1 Region is active, i.e. the entire region is an active area.
    2 Region ID is serialized
    3 Region is displaced according to region ID
    other Reserved for future use.
  • 4.9.2 Mapping of Fields to Codewords
  • Tables 14 and 15 define how the information fields map to codewords in the second position-coding pattern.
  • TABLE 14
    Mapping of fields to coordinate codewords X and Y
    X and Y
    codeword
    data codeword
    codeword field capacity field width field bits bits
    X x coordinate 10 all all
    Y y coordinate 10 all all
  • TABLE 15
    Mapping of fields to common codewords A, B, C and D
    codeword
    codeword field field width field bits bits
    A CRC 16 all 15:0 
    region ID 52 all 67:16
    encoding format 2 all 69:68
    region flags 6 all 75:70
    macrodot size ID 4 all 79:76
  • When the region flags indicate that a particular codeword is absent then the codeword is not coded in the tag pattern, i.e. there are no macrodots representing the codeword. This applies to the X and Y i.e. the X and Y codewords are present if the <region is interactive> flag in the region flags is set.
  • 4.10 Tag Imaging
  • The minimum imaging field of view required to guarantee acquisition of data from an entire tag 4B has a diameter of 33.9s (i.e. ((2×10)+4)√2s), allowing for arbitrary rotation and translation of the surface coding in the field of view. Notably, the imaging field of view does not have to be large enough to guarantee capture of an entire tag—the arrangement of the data symbols within each tag ensures that a any square portion of length (l+4s) captures the requisite information in full, irrespective of whether a whole tag is actually visible in the field-of-view. As used herein, l is defined as the length of a tag.
  • In terms of imaging the coding pattern, the imaging field-of-view is typically a circle. Accordingly, the imaging field-of-view should preferably have diameter of at least (l+4s)√2 and less than two tag diameters. Importantly, the field-of-view is not required to be at least two tag diameters, in contrast with prior art tag designs, because it is not essential to capture an entire tag 4B in the field of view.
  • The extra four macrodot units ensure that pulse-position modulated values can be decoded from spatially coherent samples. Furthermore, the extra four macrodot units ensure that all requisite data symbols 304B can be read with each interaction. These include the coordinate symbols from a column or row of a tag (see Section 4.6.2) having a width of 3s.
  • In the present context, a “tag diameter” is given to mean the length of a tag diagonal.
  • Given a maximum macrodot spacing of 169 microns, this gives a required field of view of 5.74 mm.
  • Thus, a field of view of at least 5.93 mm (see Section 3.10) is sufficient to capture data from an entire tag 4A from the first position-coding pattern or an entire tag 4B from the second position-coding pattern. Self-evidently, the requisite field of view for capturing either tag 4A or tag 4B will vary depending on the macrodot spacing in either the first or second position coding patterns. This, in turn, depends on the print resolution of a printer used to print the respective position-coding pattern.
  • 4.11 Tag Decoding
  • FIG. 22 shows a tag image processing and decoding process flow up to the stage of sampling registration symbols and decoding the translation codewords. Firstly, a raw image 802 of the tag pattern is acquired (at 800), for example via an image sensor such as a CCD image sensor, CMOS image sensor, or a scanning laser and photodiode image sensor. The raw image 802 is then typically enhanced (at 804) to produce an enhanced image 806 with improved contrast and more uniform pixel intensities. Image enhancement may include global or local range expansion, equalization, and the like. The enhanced image 806 is then typically filtered (at 808) to produce a filtered image 810. Image filtering may consist of low-pass filtering, with the low-pass filter kernel size tuned to obscure macrodots 302 but to preserve targets 301. The filtering step 808 may include additional filtering (such as edge detection) to enhance target features 301. Encoding of data symbols 304 using pulse position modulation (PPM) provides a more uniform coding pattern 3 than simple binary dot encoding (as described in, for example, U.S. Pat. No. 6,832,717). Advantageously, this helps separate targets 301 from data areas, thereby allowing more effective low-pass filtering of the PPM-encoded data compared to binary-coded data.
  • Following low-pass filtering, the filtered image 810 is then processed (at 812) to locate the targets 301. This may consist of a search for target features whose spatial inter-relationship is consistent with the known geometry of the tag pattern (i.e. targets positioned at the corners of square cells). Candidate targets may be identified directly from maxima in the filtered image 810, or may be the subject of further characterization and matching, such as via their (binary or grayscale) shape moments (typically computed from pixels in the enhanced image 806 based on local maxima in the filtered image 810), as described in U.S. Pat. No. 7,055,739, the contents of which is herein incorporated by reference.
  • The identified targets 301 are then assigned (at 816) to a target grid 818. Each cell of the grid 818 contains a symbol group 303, and several symbol groups will of course be visible in the image. At this stage, individual tags 4 will not be identifiable in the target grid 818, since the targets 301 do not themselves demarcate one tag from another.
  • To allow macrodot values to be sampled accurately, the perspective transform of the captured image must be inferred. Four of the targets 301 are taken to be the perspective-distorted corners of a square of known size in tag space, and the eight-degree-of-freedom perspective transform 822 is inferred (at 820), based on solving the well-understood equations relating the four tag-space and image-space point pairs. Calculation of the 2D perspective transform is described in detail in, for example, Applicant's U.S. Pat. No. 6,832,717, the contents of which is herein incorporated by reference.
  • Since each image of either the first or second position-coding pattern will typically contain at least 9 targets arranged in a square grid, the accuracy of calculating the 2D perspective transform is improved compared to the Applicant's previous tag designs described in, for example, U.S. Pat. No. 6,832,717. Hence, more accurate position calculation can be achieved with the tag design of the present invention.
  • The inferred tag-space to image-space perspective transform 822 is used to project each known macrodot position in tag space into image space. Since all bits in the tags are represented by PPM-encoding, the presence or absence of each macrodot 302 can be determined using a local intensity reference, rather than a separate intensity reference. Thus, PPM-encoding provides improved data sampling compared with pure binary encoding.
  • The next stage determines a type of position-coding pattern being imaged by the pen 400 from a translation codeword. In other words, this stage distinguishes the first position-coding pattern from the second position-coding pattern for subsequent sampling and decoding.
  • Two or more orthogonal registration symbols (‘VRS’ and ‘HRS’) are sampled (at 824), to allow decoding of the orthogonal translation codewords and the orthogonal direction codewords. A flag symbol value may also be decoded subsequently from the decoded registration symbols.
  • Decoding of the orthogonal translation codewords (at 828) yields either a (0, 1, 2) translation codeword or a (3, 4) translation codeword (at 830).
  • Referring now to FIG. 23, the (0, 1, 2) translation codeword indicates nine symbol groups per tag, thereby identifying (at 832A) the imaged position-coding pattern as being the first position-coding pattern (“Yarrow”) containing tags 4A. Alternatively, the (3, 4) translation codeword indicates four symbol groups per tag, thereby identifying (at 832B) the imaged position-coding pattern as being the second position-coding pattern (“Saffron”) containing tags 4B.
  • Once the position-coding pattern has been identified at 832A or 832B, subsequent sampling and decoding proceeds in accordance with the position-coding pattern thus identified. Accordingly, the decoded orthogonal translation codewords are used to determine the translation of tags(s) in the field of view relative to the target grid 818. This enables alignment of the tags 4A or 4B with the target grid 818, thereby allowing individual tag(s), or portions thereof, to be distinguished in the coding pattern 3 in the field of view. In the case of the first position-coding pattern, the tags 4A (each containing nine symbol groups) are aligned (at 834A) with the target grid 818. In the case of the second position-coding pattern, the tags 4B (each containing four symbol groups) are aligned (at 834B) with the target grid 818.
  • Since each symbol group 303 contains orthogonal registration symbols, multiple translation codes can be decoded to provide robust translation determination. As described in Sections 3.6.1 and 4.6.1, the translation code is a cyclic position code. Since each row and each column of a tag contains M symbol groups, the code has minimum distance M×M. This allows robust determination of the alignment of tags 4A or 4B with the target grid 818. The alignment needs to be both robust and accurate since there are many possible alignments when each tag contains multiple symbol groups 303.
  • After the translation of symbol groups 303 relative to tags 4A or 4B has been determined, then at least two orthogonal direction codes are decoded (at 836A or 836B) to provide the orientation 838A or 838B. As described in Sections 3.6.1 and 4.6.1, since N vertical registration symbols in a tag form a vertical direction code with minimum distance N, the vertical direction code is capable of correcting (N−1)/2 errors. The horizontal direction code is similarly capable of correcting (N−1)/2 errors using N horizontal registration symbols. Hence, orientation determination is very robust and capable of correcting errors, depending on the number of registration symbols sampled.
  • Once initial imaging and decoding has yielded the 2D perspective transform, the orientation, and the translation of tag(s) relative to the target grid, the data codewords can then be sampled and decoded (at 840A or 840B) to yield the requisite decoded codewords 842A or 842B.
  • Decoding of data codewords in the first position-coding pattern (“Yarrow”) typically proceeds as follows:
      • sample and decode Reed-Solomon codeword containing encoding format etc. (A)
      • determine encoding format, and reject unknown encoding
      • on decode error flag bad region ID sample
      • determine region ID Reed-Solomon codeword format from region flags
      • sample and decode Reed-Solomon codeword containing region ID (B, C and D)
      • verify CRC of region ID
      • on decode error flag bad region ID sample
      • determine region ID determine x and y coordinate Reed-Solomon codeword format from region flags
      • sample and decode x and y coordinate Reed-Solomon codewords (X and Y)
      • determine tag x-y location from codewords
      • determine nib x-y location from tag x-y location and perspective transform taking into account macrodot size (from macrodot size ID)
      • decode four or more flag symbols to determine active area flag
      • determine active area status of nib location with reference to active area flag
      • encode region ID, nib x-y location, and nib active area status in digital ink (“interaction data”)
  • Decoding of data codewords in the second position-coding pattern (“Saffron”) typically proceeds as follows:
      • sample and decode common Reed-Solomon codeword (A)
      • determine encoding format, and reject unknown encoding
      • on decode error flag bad format sample
      • determine region ID Reed-Solomon codeword format from region flags
      • verify CRC of region ID
      • on decode error flag bad region ID sample
      • determine region ID sample and decode x and y coordinate Reed-Solomon codewords (X and Y)
      • determine tag x-y location from codewords
      • determine nib x-y location from tag x-y location and perspective transform taking into account macrodot size (from macrodot size ID)
      • encode region ID and nib x-y location in digital ink (“interaction data”)
  • In practice, when decoding a sequence of images of a tag pattern, it is useful to exploit inter-frame coherence to obtain greater effective redundancy.
  • Region ID decoding need not occur at the same rate as position decoding.
  • The skilled person will appreciate that the decoding sequence described above represents one embodiment of the present invention. It will, of course, be appreciated that the interaction data sent from the pen 400 to the netpage system may include other data e.g. digital signature (see Section 3.9.4), pen mode (see US 2007/125860 incorporated herein by reference), orientation data, force data, pen ID, nib ID etc.
  • An example of interpreting interaction data, received by the netpage system from the netpage pen 400, is discussed briefly above in Section 1. A more detailed discussion of how the netpage system may interpret interaction data can be found in the Applicant's previously-filed applications (see, for example, US 2007/130117 and US 2007/108285, the contents of which are herein incorporated by reference).
  • 5. Netpage Pen 5.1 Functional Overview
  • The active sensing device (or “reader”) of the netpage system may take the form of a clicker (for clicking on a specific position on a surface), a pointer having a stylus (for pointing or gesturing on a surface using pointer strokes), or a pen having a marking nib (for marking a surface with ink when pointing, gesturing or writing on the surface). For a description of various netpage readers, reference is made to U.S. Pat. No. 7,105,753; U.S. Pat. No. 7,015,901; U.S. Pat. No. 7,091,960; and US Publication No. 2006/0028459, the contents of each of which are herein incorporated by reference.
  • It will be appreciated that the present invention may utilize any suitable optical reader. However, the Netpage pen 400 will be described herein as one such example.
  • In accordance with the present invention, either the first position-coding pattern (as described in Section 3) or the second position-coding pattern (as described in Section 4) may be read using the same Netpage pen 400 using the image processing and decoding steps described in Section 4.11.
  • The Netpage pen 400 is a motion-sensing writing instrument which works in conjunction with a tagged Netpage surface containing either the first or second position-coding patterns. The pen 400 incorporates a conventional ballpoint pen cartridge for marking the surface, an image sensor and processor for simultaneously capturing the absolute path of the pen on the surface and identifying the surface, a force sensor for simultaneously measuring the force exerted on the nib, and a real-time clock for simultaneously measuring the passage of time.
  • While in contact with a tagged surface, as indicated by the force sensor, the pen continuously images the surface region adjacent to the nib, and decodes the nearest tag in its field of view to determine both the identity of the surface, its own instantaneous position on the surface and the pose of the pen. The pen thus generates a stream of timestamped position samples relative to a particular surface, and transmits this stream to the Netpage server 10. The sample stream describes a series of strokes, and is conventionally referred to as digital ink (DInk). Each stroke is delimited by a pen down and a pen up event, as detected by the force sensor. More generally, any data resulting from an interaction with a Netpage, and transmitted to the Netpage server 10, is referred to herein as “interaction data”.
  • The pen samples its position at a sufficiently high rate (nominally 100 Hz) to allow a Netpage server to accurately reproduce hand-drawn strokes, recognise handwritten text, and verify hand-written signatures.
  • The Netpage pen also supports hover mode in interactive applications. In hover mode the pen is not in contact with the paper and may be some small distance above the surface of the paper (or other substrate). This allows the position of the pen, including its height and pose to be reported. In the case of an interactive application the hover mode behaviour can be used to move a cursor without marking the paper, or the distance of the nib from the coded surface could be used for tool behaviour control, for example an air brush function.
  • The pen includes a Bluetooth radio transceiver for transmitting digital ink via a relay device to a Netpage server. When operating offline from a Netpage server the pen buffers captured digital ink in non-volatile memory. When operating online to a Netpage server the pen transmits digital ink in real time.
  • The pen is supplied with a docking cradle or “pod”. The pod contains a Bluetooth to USB relay. The pod is connected via a USB cable to a computer which provides communications support for local applications and access to Netpage services.
  • The pen is powered by a rechargeable battery. The battery is not accessible to or replaceable by the user. Power to charge the pen can be taken from the USB connection or from an external power adapter through the pod. The pen also has a power and USB-compatible data socket to allow it to be externally connected and powered while in use.
  • The pen cap serves the dual purpose of protecting the nib and the imaging optics when the cap is fitted and signalling the pen to leave a power-preserving state when uncapped.
  • 5.2 Ergonomics and Layout
  • FIG. 24 shows a rounded triangular profile giving the pen 400 an ergonomically comfortable shape to grip and use the pen in the correct functional orientation. It is also a practical shape for accommodating the internal components. A normal pen-like grip naturally conforms to a triangular shape between thumb 402, index finger 404 and middle finger 406.
  • As shown in FIG. 25, a typical user writes with the pen 400 at a nominal pitch of about 30 degrees from the normal toward the hand 408 when held (positive angle) but seldom operates a pen at more than about 10 degrees of negative pitch (away from the hand). The range of pitch angles over which the pen 400 is able to image the pattern on the paper has been optimised for this asymmetric usage. The shape of the pen 400 helps to orient the pen correctly in the user's hand 408 and to discourage the user from using the pen “upside-down”. The pen functions “upside-down” but the allowable tilt angle range is reduced.
  • The cap 410 is designed to fit over the top end of the pen 400, allowing it to be securely stowed while the pen is in use. Multi colour LEDs illuminate a status window 412 in the top edge (as in the apex of the rounded triangular cross section) of the pen 400 near its top end. The status window 412 remains un-obscured when the cap is stowed. A vibration motor is also included in the pen as a haptic feedback system (described in detail below).
  • As shown in FIG. 26, the grip portion of the pen has a hollow chassis molding 416 enclosed by a base molding 528 to house the other components. The ink cartridge 414 for the ball point nib (not shown) fits naturally into the apex 420 of the triangular cross section, placing it consistently with the user's grip. This in turn provides space for the main PCB 422 in the centre of the pen and for the battery 424 in the base of the pen. By referring to FIG. 27A, it can be seen that this also naturally places the tag-sensing optics 426 unobtrusively below the nib 418 (with respect to nominal pitch). The nib molding 428 of the pen 400 is swept back below the ink cartridge 414 to prevent contact between the nib molding 428 and the paper surface when the pen is operated at maximum pitch.
  • As best shown in FIG. 27B, the imaging field of view 430 emerges through a centrally positioned IR filter/window 432 below the nib 418, and two near- infrared illumination LEDs 434, 436 emerge from the two bottom corners of the nib molding 428. Each LED 434, 436 has a corresponding illumination field 438, 440.
  • As the pen is hand-held, it may be held at an angle that causes reflections from one of the LED's that are detrimental to the image sensor. By providing more than one LED, the LED causing the offending reflections can be extinguished.
  • Specific details of the pen mechanical design can be found in US Publication No. 2006/0028459, the contents of which are herein incorporated by reference.
  • 5.3 Pen Feedback Indications
  • FIG. 28 is a longitudinal cross section through the centre-line if the pen 400 (with the cap 410 stowed on the end of the pen). The pen incorporates red and green LEDs 444 to indicate several states, using colours and intensity modulation. A light pipe 448 on the LEDs 444 transmit the signal to the status indicator window 412 in the tube molding 416. These signal status information to the user including power-on, battery level, untransmitted digital ink, network connection on-line, fault or error with an action, detection of an “active area” flag, detection of an “embedded data” flag, further data sampling to required to acquire embedded data, acquisition of embedded data completed etc.
  • A vibration motor 446 is used to haptically convey information to the user for important verification functions during transactions. This system is used for important interactive indications that might be missed due to inattention to the LED indicators 444 or high levels of ambient light. The haptic system indicates to the user when:
      • The pen wakes from standby mode
      • There is an error with an action
      • To acknowledge a transaction
    5.4 Pen Optics
  • The pen incorporates a fixed-focus narrowband infrared imaging system. It utilizes a camera with a short exposure time, small aperture, and bright synchronised illumination to capture sharp images unaffected by defocus blur or motion blur.
  • TABLE 16
    Optical Specifications
    Magnification ~0.225
    Focal length of 6.0 mm
    lens
    Viewing distance 30.5 mm
    Total track length 41.0 mm
    Aperture diameter 0.8 mm
    Depth of field 6.5 mm
    Exposure time 200 us
    Wavelength 810 nm
    Image sensor size 140 × 140 pixels
    Pixel size
    10 um
    Pitch range ~15 to. 45 deg
    Roll range ~30 to. 30 deg
    Yaw range
    0 to 360 deg
    Minimum sampling 2.25 pixels per
    rate macrodot
    Maximum pen 0.5 m/s
    velocity
    1Allowing 70 micron blur radius
    2Illumination and filter
    3Pitch, roll and yaw are relative to the axis of the pen
  • Cross sections showing the pen optics are provided in FIGS. 29A and 29B. An image of the Netpage tags printed on a surface 548 adjacent to the nib 418 is focused by a lens 488 onto the active region of an image sensor 490. A small aperture 494 ensures the available depth of field accommodates the required pitch and roll ranges of the pen 400.
  • First and second LEDs 434 and 436 brightly illuminate the surface 549 within the field of view 430. The spectral emission peak of the LEDs is matched to the spectral absorption peak of the infrared ink used to print Netpage tags to maximise contrast in captured images of tags. The brightness of the LEDs is matched to the small aperture size and short exposure time required to minimise defocus and motion blur.
  • A longpass IR filter 432 suppresses the response of the image sensor 490 to any coloured graphics or text spatially coincident with imaged tags and any ambient illumination below the cut-off wavelength of the filter 432. The transmission of the filter 432 is matched to the spectral absorption peak of the infrared ink to maximise contrast in captured images of tags. The filter also acts as a robust physical window, preventing contaminants from entering the optical assembly 470.
  • 5.5 Pen Imaging System
  • A ray trace of the optic path is shown in FIG. 30. The image sensor 490 is a CMOS image sensor with an active region of 140 pixels squared. Each pixel is 10 μm squared, with a fill factor of 93%. Turning to FIG. 31, the lens 488 is shown in detail. The dimensions are:
      • D=3 mm
      • R1=3.593 mm
      • R2=15.0 mm
      • X=0.8246 mm
      • Y=1.0 mm
      • Z=0.25 mm
  • This gives a focal length of 6.15 mm and transfers the image from the object plane (tagged surface 548) to the image plane (image sensor 490) with the correct sampling frequency to successfully decode all images over the specified pitch, roll and yaw ranges. The lens 488 is biconvex, with the most curved surface facing the image sensor. The minimum imaging field of view 430 required to guarantee acquisition of sufficient tag data with each interaction is dependent on the specific coding pattern. The required field of view for the coding patterns of the present invention is described in Section 4.10.
  • The required paraxial magnification of the optical system is defined by the minimum spatial sampling frequency of 2.25 pixels per macrodot for the fully specified tilt range of the pen 400, for the image sensor 490 of 10 μm pixels. Typically, the imaging system employs a paraxial magnification of 0.225, the ratio of the diameter of the inverted image at the image sensor to the diameter of the field of view at the object plane, on an image sensor 490 of minimum 128×128 pixels. The image sensor 490 however is 140×140 pixels, in order to accommodate manufacturing tolerances. This allows up to +/−120 μm (12 pixels in each direction in the plane of the image sensor) of misalignment between the optical axis and the image sensor axis without losing any of the information in the field of view.
  • The lens 488 is made from Poly-methyl-methacrylate (PMMA), typically used for injection moulded optical components. PMMA is scratch resistant, and has a refractive index of 1.49, with 90% transmission at 810 nm. The lens is biconvex to assist moulding precision and features a mounting surface to precisely mate the lens with the optical barrel molding 492.
  • A 0.8 mm diameter aperture 494 is used to provide the depth of field requirements of the design.
  • The specified tilt range of the pen is 15.0 to 45.0 degree pitch, with a roll range of 30.0 to 30.0 degrees. Tilting the pen through its specified range moves the tilted object plane up to 6.3 mm away from the focal plane. The specified aperture thus provides a corresponding depth of field of 6.5 mm, with an acceptable blur radius at the image sensor of 16 μm.
  • Due to the geometry of the pen design, the pen operates correctly over a pitch range of 33.0 to 45.0 degrees.
  • Referring to FIG. 32, the optical axis 550 is pitched 0.8 degrees away from the nib axis 552. The optical axis and the nib axis converge toward the paper surface 548. With the nib axis 552 perpendicular to the paper, the distance A between the edge of the field of view 430 closest to the nib axis and the nib axis itself is 1.2 mm.
  • The longpass IR filter 432 is made of CR-39, a lightweight thermoset plastic heavily resistant to abrasion and chemicals such as acetone. Because of these properties, the filter also serves as a window. The filter is 1.5 mm thick, with a refractive index of 1.50. Each filter may be easily cut from a large sheet using a CO2 laser cutter.
  • 5.6 Electronics Design
  • TABLE 17
    Electrical Specifications
    Processor ARM7 (Atmel AT91FR40162) running at
    80 MHz
    with 256 kB SRAM and 2 MB flash memory
    Digital ink storage 5 hours of writing
    capacity
    Bluetooth 1.2
    Compliance
    USB Compliance 1.1
    Battery standby 12 hours (cap off), >4 weeks (cap on)
    time
    Battery writing 4 hours of cursive writing (81% pen down,
    time assuming easy offload of digital ink)
    Battery charging 2 hours
    time
    Battery Life Typically 300 charging cycles or 2 years
    (whichever occurs first) to 80% of initial
    capacity.
    Battery ~340 mAh at 3.7 V, Lithium-ion Polymer
    Capacity/Type (LiPo)
  • FIG. 33 is a block diagram of the pen electronics. The electronics design for the pen is based around five main sections. These are:
      • the main ARM7 microprocessor 574,
      • the image sensor and image processor 576,
      • the Bluetooth communications module 578,
      • the power management unit IC (PMU) 580 and
      • the force sensor microprocessor 582.
    5.6.1 Microprocessor
  • The pen uses an Atmel AT91FR40162 microprocessor (see Atmel, AT91 ARM Thumb Microcontrollers—A T91FR40162 Preliminary, http://www.keil.com/dd/docs/datashts/atmel/at91fr40162.pdf) running at 80 MHz. The AT91FR40162 incorporates an ARM7 microprocessor, 256 kBytes of on-chip single wait state SRAM and 2 MBytes of external flash memory in a stack chip package.
  • This microprocessor 574 forms the core of the pen 400. Its duties include:
      • setting up the Jupiter image sensor 584,
      • decoding images of Netpage coding pattern (see Section 4.11), with assistance from the image processing features of the image sensor 584, for inclusion in the digital ink stream along with force sensor data received from the force sensor microprocessor 582,
      • setting up the power management IC (PMU) 580,
      • compressing and sending digital ink via the Bluetooth communications module 578, and
      • programming the force sensor microprocessor 582.
  • The ARM7 microprocessor 574 runs from an 80 MHz oscillator. It communicates with the Jupiter image sensor 576 using a Universal Synchronous Receiver Transmitter (USRT) 586 with a 40 MHz clock. The ARM7 574 communicates with the Bluetooth module 578 using a Universal Asynchronous Receiver Transmitter (UART) 588 running at 115.2 kbaud. Communications to the PMU 580 and the Force Sensor microprocessor (FSP) 582 are performed using a Low Speed Serial bus (LSS) 590. The LSS is implemented in software and uses two of the microprocessor's general purpose IOs.
  • The ARM7 microprocessor 574 is programmed via its JTAG port.
  • 5.6.2 Image Sensor
  • The ‘Jupiter’ Image Sensor 584 (see US Publication No. 2005/0024510, the contents of which are incorporated herein by reference) contains a monochrome sensor array, an analogue to digital converter (ADC), a frame store buffer, a simple image processor and a phase lock loop (PLL). In the pen, Jupiter uses the USRT's clock line and its internal PLL to generate all its clocking requirements. Images captured by the sensor array are stored in the frame store buffer. These images are decoded by the ARM7 microprocessor 574 with help from the ‘Callisto’ image processor contained in Jupiter. The Callisto image processor performs, inter alia, low-pass filtering of captured images (see Section 4.11 and US Publication No. 2005/0024510) before macrodot sampling and decoding by the microprocessor 574.
  • Jupiter controls the strobing of two infrared LEDs 434 and 436 at the same time as its image array is exposed. One or other of these two infrared LEDs may be turned off while the image array is exposed to prevent specular reflection off the paper that can occur at certain angles.
  • 5.6.3 Bluetooth Communications Module
  • The pen uses a CSR BlueCore4-External device (see CSR, BlueCore4-External Data Sheet rev c, 6 Sep. 2004) as the Bluetooth controller 578. It requires an external 8 Mbit flash memory device 594 to hold its program code. The BlueCore4 meets the Bluetooth v1.2 specification and is compliant to v0.9 of the Enhanced Data Rate (EDR) specification which allows communication at up to 3 Mbps.
  • A 2.45 GHz chip antenna 486 is used on the pen for the Bluetooth communications.
  • The BlueCore4 is capable of forming a UART to USB bridge. This is used to allow USB communications via data/power socket 458 at the top of the pen 456.
  • Alternatives to Bluetooth include wireless LAN and PAN standards such as IEEE 802.11 (Wi-Fi) (see IEEE, 802.11 Wireless Local Area Networks, http://grouper.ieee.org/groups/802/11/index.html), IEEE 802.15 (see IEEE, 802.15 Working Groupfor WPAN, http://grouper.ieee.org/groups/802/15/index.html), ZigBee (see ZigBee Alliance, http://www.zigbee.org), and WirelessUSB Cypress (see WirelessUSB LR 2.4-GHz DSSS Radio SoC, http://www.cypress.com/cfuploads/img/products/cywusb6935.pdf), as well as mobile standards such as GSM (see GSM Association, http://www.gsmworld.com/index.shtml), GPRS/EDGE, GPRSPlatform, http://www.gsmworld.com/technology/gprs/index.shtml), CDMA (see CDMA Development Group, http://www.cdg.org/, and Qualcomm, http://www.qualcomm.com), and UMTS (see 3rd Generation Partnership Project (3GPP), http://www.3gpp.org).
  • 5.6.4 Power Management Chip
  • The pen uses an Austria Microsystems AS3603 PMU 580 (see Austria Microsystems, AS3603 Multi-Standard Power Management Unit Data Sheet v2.0). The PMU is used for battery management, voltage generation, power up reset generation and driving indicator LEDs and the vibrator motor.
  • The PMU 580 communicates with the ARM7 microprocessor 574 via the LSS bus 590.
  • 5.6.5 Force Sensor Subsystem
  • The force sensor subsystem comprises a custom Hokuriku force sensor 500 (based on Hokuriku, HFD-500 Force Sensor, http://www.hdk.cojp/pdf/eng/e1381AA.pdf), an amplifier and low pass filter 600 implemented using op-amps and a force sensor microprocessor 582.
  • The pen uses a Silicon Laboratories C8051F330 as the force sensor microprocessor 582 (see Silicon Laboratories, C8051F330/1 MCUData Sheet, rev 1.1). The C8051F330 is an 8051 microprocessor with on chip flash memory, 10 bit ADC and 10 bit DAC. It contains an internal 24.5 MHz oscillator and also uses an external 32.768 kHz tuning fork.
  • The Hokuriku force sensor 500 is a silicon piezoresistive bridge sensor. An op-amp stage 600 amplifies and low pass (anti-alias) filters the force sensor output. This signal is then sampled by the force sensor microprocessor 582 at 5 kHz.
  • Alternatives to piezoresistive force sensing include capacitive and inductive force sensing (see Wacom, “Variable capacity condenser and pointer”, US Patent Application 20010038384, filed 8 Nov. 2001, and Wacom, Technology, http://www.wacom-components.com/english/tech.asp).
  • The force sensor microprocessor 582 performs further (digital) filtering of the force signal and produces the force sensor values for the digital ink stream. A frame sync signal from the Jupiter image sensor 576 is used to trigger the generation of each force sample for the digital ink stream. The temperature is measured via the force sensor microprocessor's 582 on chip temperature sensor and this is used to compensate for the temperature dependence of the force sensor and amplifier. The offset of the force signal is dynamically controlled by input of the microprocessor's DAC output into the amplifier stage 600.
  • The force sensor microprocessor 582 communicates with the ARM7 microprocessor 574 via the LSS bus 590. There are two separate interrupt lines from the force sensor microprocessor 582 to the ARM7 microprocessor 574. One is used to indicate that a force sensor sample is ready for reading and the other to indicate that a pen down/up event has occurred.
  • The force sensor microprocessor flash memory is programmed in-circuit by the ARM7 microprocessor 574.
  • The force sensor microprocessor 582 also provides the real time clock functionality for the pen 400. The RTC function is performed in one of the microprocessor's counter timers and runs from the external 32.768 kHz tuning fork. As a result, the force sensor microprocessor needs to remain on when the cap 472 is on and the ARM7 574 is powered down. Hence the force sensor microprocessor 582 uses a low power LDO separate from the PMU 580 as its power source. The real time clock functionality includes an interrupt which can be programmed to power up the ARM7 574.
  • The cap switch 602 is monitored by the force sensor microprocessor 582. When the cap assembly 472 is taken off (or there is a real time clock interrupt), the force sensor microprocessor 582 starts up the ARM7 572 by initiating a power on and reset cycle in the PMU 580.
  • 5.7 Pen Software
  • The Netpage pen software comprises that software running on microprocessors in the Netpage pen 400 and Netpage pod.
  • The pen contains a number of microprocessors, as detailed in Section 5.6. The Netpage pen software includes software running on the Atmel ARM7 CPU 574 (hereafter CPU), the Force Sensor microprocessor 582, and also software running in the VM on the CSR BlueCore Bluetooth module 578 (hereafter pen BlueCore). Each of these processors has an associated flash memory which stores the processor specific software, together with settings and other persistent data. The pen BlueCore 578 also runs firmware supplied by the module manufacturer, and this firmware is not considered a part of the Netpage pen software.
  • The pod contains a CSR BlueCore Bluetooth module (hereafter pod BlueCore). The Netpage pen software also includes software running in the VM on the pod BlueCore.
  • As the Netpage pen 400 traverses a Netpage tagged surface 548, a stream of correlated position and force samples are produced. This stream is referred to as DInk. Note that DInk may include samples with zero force (so called “Hover DInk”) produced when the Netpage pen is in proximity to, but not marking, a Netpage tagged surface.
  • The CPU component of the Netpage pen software is responsible for DInk capture, tag image processing and decoding (in conjunction with the Jupiter image sensor 576), storage and offload management, host communications, user feedback and software upgrade. It includes an operating system (RTOS) and relevant hardware drivers. In addition, it provides a manufacturing and maintenance mode for calibration, configuration or detailed (non-field) fault diagnosis. The Force Sensor microprocessor 582 component of the Netpage pen software is responsible for filtering and preparing force samples for the main CPU. The pen BlueCore VM software is responsible for bridging the CPU UART 588 interface to USB when the pen is operating in tethered mode. The pen BlueCore VM software is not used when the pen is operating in Bluetooth mode.
  • The pod BlueCore VM software is responsible for sensing when the pod is charging a pen 400, controlling the pod LEDs appropriately, and communicating with the host PC via USB.
  • For a detailed description of the software modules, reference is made to US Publication No. 2006/0028459, the contents of which are herein incorporated by reference.
  • The present invention has been described with reference to a preferred embodiment and number of specific alternative embodiments. However, it will be appreciated by those skilled in the relevant fields that a number of other embodiments, differing from those specifically described, will also fall within the spirit and scope of the present invention. Accordingly, it will be understood that the invention is not intended to be limited to the specific embodiments described in the present specification, including documents incorporated by cross-reference as appropriate. The scope of the invention is only limited by the attached claims.

Claims (20)

1. A method of imaging a coding pattern disposed on a surface of a substrate, said method comprising the steps of:
(a) operatively positioning an optical reader relative to said surface and capturing an image of a portion of said coding pattern, said coding pattern comprising:
a plurality of contiguous square tags of length l, each tag comprising x-coordinate data and y-coordinate data; and
a plurality of data elements contained in each tag, said x-coordinate data being represented by a respective set of data elements and said y-coordinate data being represented by a respective set of data elements,
wherein:
all said x-coordinate data is represented in a column of said tag parallel with a y-axis;
all said y-coordinate data is represented in a row of said tag parallel with an x-axis; and
said column and said row each have a width v,
(b) sampling and decoding x-coordinate data and y-coordinate data within said imaged portion; and
(c) determining a position of said reader,
wherein said imaged portion has a diameter of at least (l+v)√2 and less than (21) V2.
2. The method of claim 1, wherein said coding pattern comprises:
a plurality of target elements defining a target grid, said target grid comprising a plurality of cells, wherein neighboring cells share target elements and wherein each tag is defined by a plurality of contiguous cells.
3. The method of claim 2, wherein each tag comprises M2 contiguous square cells, wherein M is an integer having a value of at least 1.
4. The method of claim 1, wherein said data elements are macrodots.
5. The method of claim 1, wherein v=ts,
wherein:
s is defined as a spacing between adjacent macrodots;
t is an integer value of 2 or more.
6. The method of claim 4, wherein said macrodots encode data values by pulse position modulation (PPM).
7. The method of claim 6, wherein a portion of data is represented by m macrodots, each of said macrodots occupying a respective position from a plurality of predetermined possible positions p within said cell, the respective positions of said macrodots representing one of a plurality of possible data values.
8. The method of claim 7, wherein m is an integer of 1 or more, and p>m.
9. The method of claim 7, wherein said portion of data is a Reed-Solomon symbol.
10. The method of claim 9, wherein each cell defines a symbol group, each symbol group comprising a plurality of said Reed-Solomon symbols.
11. The method of claim 9, wherein said x-coordinate data is encoded as an x-coordinate codeword comprised of a respective set of said X-Reed-Solomon symbols, and said y-coordinate data is encoded as a y-coordinate codeword comprised of a respective set of said Y-Reed-Solomon symbols.
12. The method of claim 11, wherein said X-Reed-Solomon symbols are configured and oriented in said column so as to have said width v, and wherein said Y-Reed-Solomon symbols are configured and oriented in said row so as to have said width v.
13. The method of claim 10, wherein each tag comprises a plurality of common codewords, each common codeword being comprised of a respective set of said Reed-Solomon symbols, wherein said plurality of common codewords are defined as codewords common to a plurality of contiguous tags, said method further comprising:
sampling and decoding said common codeword within said imaged portion.
14. The method of claim 13, wherein each symbol group comprises a fragment of at least one of said common codewords, and contiguous symbol groups are arranged such that any tag-sized portion of said coding pattern is guaranteed to contain said plurality of common codewords irrespective of whether a whole tag is contained in said portion.
15. The method of claim 13, wherein said one or more of said common codewords encode region identity data uniquely identifying a region of said surface, said method further comprising:
determining said an identity of said region.
16. The method of claim 15, wherein said region identity data uniquely identifies said substrate.
17. The method of claim 2, wherein each cell comprises a registration symbol encoded by a respective set of said data elements, said method further comprising sampling and decoding said registration symbol to identifying one or more of:
a translation of said cell relative to a tag containing said cell;
an orientation of a layout of tag data with respect to said target grid;
a number of cells in each tag;
a flag associated with said tag.
18. The method of claim 17, wherein each cell comprises a first and second registration symbols, said first registration symbol identifying a first orthogonal translation of said cell, said second registration symbol identifying a second orthogonal translation of said cell.
19. A system for imaging a coding pattern disposed on a surface of a substrate, said system comprising:
(A) said substrate, wherein said coding pattern comprises:
a plurality of contiguous square tags of length l, each tag comprising x-coordinate data and y-coordinate data; and
a plurality of data elements contained in each tag, said x-coordinate data being represented by a respective set of data elements and said y-coordinate data being represented by a respective set of data elements,
wherein:
all said x-coordinate data is represented in a column of said tag parallel with a y-axis;
all said y-coordinate data is represented in a row of said tag parallel with an x-axis; and
said column and said row each have a width v,
(B) an optical reader comprising:
an image sensor for capturing an image of a portion of said coding pattern, said image sensor having a field-of-view of at least (l+v)√2 and less than (21)√2; and
a processor configured for performing the steps of:
(i) sampling and decoding x-coordinate data and y-coordinate data contained in an imaged portion; and
(ii) determining a position of said reader.
20. An optical reader for imaging a coding pattern disposed on a surface of a substrate, said coding pattern comprising:
a plurality of contiguous square tags of length l, each tag comprising x-coordinate data and y-coordinate data; and
a plurality of data elements contained in each tag, said x-coordinate data being represented by a respective set of data elements and said y-coordinate data being represented by a respective set of data elements,
wherein:
all said x-coordinate data is represented in a column of said tag parallel with a y-axis;
all said y-coordinate data is represented in a row of said tag parallel with an x-axis; and
said column and said row each have a width v, said optical reader comprising:
an image sensor for capturing an image of a portion of said coding pattern, said image sensor having a field-of-view of at least (l+v)√2 and less than (2l)√2; and
a processor configured for performing the steps of:
(i) sampling and decoding x-coordinate data and y-coordinate data contained in an imaged portion; and
(ii) determining a position of said reader.
US12/539,586 2008-10-02 2009-08-11 Method of imaging coding pattern comprising columns and rows of coordinate data Abandoned US20100084468A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/539,586 US20100084468A1 (en) 2008-10-02 2009-08-11 Method of imaging coding pattern comprising columns and rows of coordinate data

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10229908P 2008-10-02 2008-10-02
US12/539,586 US20100084468A1 (en) 2008-10-02 2009-08-11 Method of imaging coding pattern comprising columns and rows of coordinate data

Publications (1)

Publication Number Publication Date
US20100084468A1 true US20100084468A1 (en) 2010-04-08

Family

ID=42072943

Family Applications (13)

Application Number Title Priority Date Filing Date
US12/539,597 Abandoned US20100086236A1 (en) 2008-10-02 2009-08-11 Method of imaging position-coding pattern having tag coordinates encoded by successive subsequences of cyclic position code
US12/539,592 Expired - Fee Related US8282016B2 (en) 2008-10-02 2009-08-11 Position-coding pattern having tag coordinates encoded by successive subsequences of cyclic position code
US12/539,589 Abandoned US20100086209A1 (en) 2008-10-02 2009-08-11 Method of imaging position-coding pattern having tag coordinates encoded by bit-shifted subsequences of cyclic position code
US12/539,583 Abandoned US20100084472A1 (en) 2008-10-02 2009-08-11 Method of distinguishing first coding pattern from second coding pattern
US12/539,586 Abandoned US20100084468A1 (en) 2008-10-02 2009-08-11 Method of imaging coding pattern comprising columns and rows of coordinate data
US12/539,588 Abandoned US20100084479A1 (en) 2008-10-02 2009-08-11 Position-coding pattern having tag coordinates encoded by bit-shifted subsequences of cyclic position code
US12/539,605 Abandoned US20100085607A1 (en) 2008-10-02 2009-08-11 Method of encoding coding pattern
US12/539,580 Abandoned US20100084478A1 (en) 2008-10-02 2009-08-11 Coding pattern comprising columns and rows of coordinate data
US12/539,603 Abandoned US20100086171A1 (en) 2008-10-02 2009-08-11 Method of imaging coding pattern having merged data symbols
US12/539,599 Abandoned US20100084481A1 (en) 2008-10-02 2009-08-11 Coding pattern having merged data symbols
US12/539,579 Expired - Fee Related US8328109B2 (en) 2008-10-02 2009-08-11 Coding pattern comprising registration symbols for identifying the coding pattern
US13/532,781 Abandoned US20120267439A1 (en) 2008-10-02 2012-06-26 Position-coding pattern having tag coordinates encoded by bit-shifted subsequences of cyclic position code
US13/711,567 Abandoned US20130175349A1 (en) 2008-10-02 2012-12-11 Coding pattern comprising registration symbols for identifying the coding pattern

Family Applications Before (4)

Application Number Title Priority Date Filing Date
US12/539,597 Abandoned US20100086236A1 (en) 2008-10-02 2009-08-11 Method of imaging position-coding pattern having tag coordinates encoded by successive subsequences of cyclic position code
US12/539,592 Expired - Fee Related US8282016B2 (en) 2008-10-02 2009-08-11 Position-coding pattern having tag coordinates encoded by successive subsequences of cyclic position code
US12/539,589 Abandoned US20100086209A1 (en) 2008-10-02 2009-08-11 Method of imaging position-coding pattern having tag coordinates encoded by bit-shifted subsequences of cyclic position code
US12/539,583 Abandoned US20100084472A1 (en) 2008-10-02 2009-08-11 Method of distinguishing first coding pattern from second coding pattern

Family Applications After (8)

Application Number Title Priority Date Filing Date
US12/539,588 Abandoned US20100084479A1 (en) 2008-10-02 2009-08-11 Position-coding pattern having tag coordinates encoded by bit-shifted subsequences of cyclic position code
US12/539,605 Abandoned US20100085607A1 (en) 2008-10-02 2009-08-11 Method of encoding coding pattern
US12/539,580 Abandoned US20100084478A1 (en) 2008-10-02 2009-08-11 Coding pattern comprising columns and rows of coordinate data
US12/539,603 Abandoned US20100086171A1 (en) 2008-10-02 2009-08-11 Method of imaging coding pattern having merged data symbols
US12/539,599 Abandoned US20100084481A1 (en) 2008-10-02 2009-08-11 Coding pattern having merged data symbols
US12/539,579 Expired - Fee Related US8328109B2 (en) 2008-10-02 2009-08-11 Coding pattern comprising registration symbols for identifying the coding pattern
US13/532,781 Abandoned US20120267439A1 (en) 2008-10-02 2012-06-26 Position-coding pattern having tag coordinates encoded by bit-shifted subsequences of cyclic position code
US13/711,567 Abandoned US20130175349A1 (en) 2008-10-02 2012-12-11 Coding pattern comprising registration symbols for identifying the coding pattern

Country Status (9)

Country Link
US (13) US20100086236A1 (en)
EP (2) EP2344975A1 (en)
JP (2) JP2012504799A (en)
KR (2) KR20110069822A (en)
CN (1) CN102171705A (en)
AU (2) AU2009299097A1 (en)
CA (2) CA2736310A1 (en)
TW (11) TWI456506B (en)
WO (2) WO2010037158A1 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140253465A1 (en) * 2013-03-11 2014-09-11 Barnesandnoble.Com Llc Stylus sensitive device with hover over stylus control functionality
US20140370921A1 (en) * 2011-09-20 2014-12-18 Sisvel Technology S.R.L. Method for reconstructing the map of an environment surrounding a wireless device and wireless device implementing such method
US9261985B2 (en) 2013-03-11 2016-02-16 Barnes & Noble College Booksellers, Llc Stylus-based touch-sensitive area for UI control of computing device
US9785259B2 (en) 2013-03-11 2017-10-10 Barnes & Noble College Booksellers, Llc Stylus-based slider functionality for UI control of computing device
US9946365B2 (en) 2013-03-11 2018-04-17 Barnes & Noble College Booksellers, Llc Stylus-based pressure-sensitive area for UI control of computing device
US10614275B2 (en) * 2016-06-21 2020-04-07 Mitutoyo Corporation Position specifying apparatus and position specifying method
US11195172B2 (en) * 2019-07-24 2021-12-07 Capital One Services, Llc Training a neural network model for recognizing handwritten signatures based on different cursive fonts and transformations

Families Citing this family (118)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8276049B2 (en) * 2007-09-04 2012-09-25 Ricoh Company Limited Information processing device and method
US20100086236A1 (en) * 2008-10-02 2010-04-08 Silverbrook Research Pty Ltd Method of imaging position-coding pattern having tag coordinates encoded by successive subsequences of cyclic position code
US9311593B2 (en) 2010-03-26 2016-04-12 Brain Corporation Apparatus and methods for polychronous encoding and multiplexing in neuronal prosthetic devices
US9122994B2 (en) 2010-03-26 2015-09-01 Brain Corporation Apparatus and methods for temporally proximate object recognition
US8315305B2 (en) 2010-03-26 2012-11-20 Brain Corporation Systems and methods for invariant pulse latency coding
US9405975B2 (en) * 2010-03-26 2016-08-02 Brain Corporation Apparatus and methods for pulse-code invariant object recognition
WO2011150444A1 (en) * 2010-05-31 2011-12-08 Silverbrook Research Pty Ltd Mobile phone assembly with microscope capability
US9906838B2 (en) 2010-07-12 2018-02-27 Time Warner Cable Enterprises Llc Apparatus and methods for content delivery and message exchange across multiple content delivery networks
US8942466B2 (en) 2010-08-26 2015-01-27 Brain Corporation Sensory input processing apparatus and methods
US9152915B1 (en) 2010-08-26 2015-10-06 Brain Corporation Apparatus and methods for encoding vector into pulse-code output
US8587585B2 (en) * 2010-09-28 2013-11-19 Intel Corporation Backface culling for motion blur and depth of field
US9015093B1 (en) 2010-10-26 2015-04-21 Michael Lamport Commons Intelligent control with hierarchical stacked neural networks
US8775341B1 (en) 2010-10-26 2014-07-08 Michael Lamport Commons Intelligent control with hierarchical stacked neural networks
US9566710B2 (en) 2011-06-02 2017-02-14 Brain Corporation Apparatus and methods for operating robotic devices using selective state space training
US9147156B2 (en) 2011-09-21 2015-09-29 Qualcomm Technologies Inc. Apparatus and methods for synaptic update in a pulse-coded network
US8990133B1 (en) 2012-12-20 2015-03-24 Brain Corporation Apparatus and methods for state-dependent learning in spiking neuron networks
US9047568B1 (en) 2012-09-20 2015-06-02 Brain Corporation Apparatus and methods for encoding of sensory data using artificial spiking neurons
US9070039B2 (en) 2013-02-01 2015-06-30 Brian Corporation Temporal winner takes all spiking neuron network sensory processing apparatus and methods
US9813727B2 (en) 2011-06-28 2017-11-07 Samsung Electronics Co., Ltd. Method and apparatus for image encoding and decoding using intra prediction
US9104973B2 (en) 2011-09-21 2015-08-11 Qualcomm Technologies Inc. Elementary network description for neuromorphic systems with plurality of doublets wherein doublet events rules are executed in parallel
US9412064B2 (en) 2011-08-17 2016-08-09 Qualcomm Technologies Inc. Event-based communication in spiking neuron networks communicating a neural activity payload with an efficacy update
US8725662B2 (en) 2011-09-21 2014-05-13 Brain Corporation Apparatus and method for partial evaluation of synaptic updates based on system events
US9460387B2 (en) 2011-09-21 2016-10-04 Qualcomm Technologies Inc. Apparatus and methods for implementing event-based updates in neuron networks
US8719199B2 (en) 2011-09-21 2014-05-06 Brain Corporation Systems and methods for providing a neural network having an elementary network description for efficient implementation of event-triggered plasticity rules
US8725658B2 (en) 2011-09-21 2014-05-13 Brain Corporation Elementary network description for efficient memory management in neuromorphic systems
US9098811B2 (en) 2012-06-04 2015-08-04 Brain Corporation Spiking neuron network apparatus and methods
US10210452B2 (en) 2011-09-21 2019-02-19 Qualcomm Incorporated High level neuromorphic network description apparatus and methods
US9146546B2 (en) 2012-06-04 2015-09-29 Brain Corporation Systems and apparatus for implementing task-specific learning using spiking neurons
US9015092B2 (en) 2012-06-04 2015-04-21 Brain Corporation Dynamically reconfigurable stochastic learning apparatus and methods
US9117176B2 (en) 2011-09-21 2015-08-25 Qualcomm Technologies Inc. Round-trip engineering apparatus and methods for neural networks
US9104186B2 (en) 2012-06-04 2015-08-11 Brain Corporation Stochastic apparatus and methods for implementing generalized learning rules
US8712939B2 (en) 2011-09-21 2014-04-29 Brain Corporation Tag-based apparatus and methods for neural networks
US9213937B2 (en) 2011-09-21 2015-12-15 Brain Corporation Apparatus and methods for gating analog and spiking signals in artificial neural networks
US9156165B2 (en) 2011-09-21 2015-10-13 Brain Corporation Adaptive critic apparatus and methods
NL2009853A (en) 2011-12-23 2013-06-26 Asml Netherlands Bv Methods and apparatus for measuring a property of a substrate.
US20130163034A1 (en) * 2011-12-27 2013-06-27 Xerox Corporation Vendor selection method and system for wide format printing
US9224090B2 (en) 2012-05-07 2015-12-29 Brain Corporation Sensory input processing apparatus in a spiking neural network
US9129221B2 (en) 2012-05-07 2015-09-08 Brain Corporation Spiking neural network feedback apparatus and methods
US9412041B1 (en) 2012-06-29 2016-08-09 Brain Corporation Retinal apparatus and methods
US9111215B2 (en) 2012-07-03 2015-08-18 Brain Corporation Conditional plasticity spiking neuron network apparatus and methods
US8977582B2 (en) 2012-07-12 2015-03-10 Brain Corporation Spiking neuron network sensory processing apparatus and methods
US9256823B2 (en) 2012-07-27 2016-02-09 Qualcomm Technologies Inc. Apparatus and methods for efficient updates in spiking neuron network
US9256215B2 (en) 2012-07-27 2016-02-09 Brain Corporation Apparatus and methods for generalized state-dependent learning in spiking neuron networks
US9440352B2 (en) 2012-08-31 2016-09-13 Qualcomm Technologies Inc. Apparatus and methods for robotic learning
US9186793B1 (en) 2012-08-31 2015-11-17 Brain Corporation Apparatus and methods for controlling attention of a robot
US8793205B1 (en) 2012-09-20 2014-07-29 Brain Corporation Robotic learning and evolution apparatus
US9311594B1 (en) 2012-09-20 2016-04-12 Brain Corporation Spiking neuron network apparatus and methods for encoding of sensory data
US9189730B1 (en) 2012-09-20 2015-11-17 Brain Corporation Modulated stochasticity spiking neuron network controller apparatus and methods
US9367798B2 (en) 2012-09-20 2016-06-14 Brain Corporation Spiking neuron network adaptive control apparatus and methods
US9082079B1 (en) 2012-10-22 2015-07-14 Brain Corporation Proportional-integral-derivative controller effecting expansion kernels comprising a plurality of spiking neurons associated with a plurality of receptive fields
US9111226B2 (en) 2012-10-25 2015-08-18 Brain Corporation Modulated plasticity apparatus and methods for spiking neuron network
US9183493B2 (en) 2012-10-25 2015-11-10 Brain Corporation Adaptive plasticity apparatus and methods for spiking neuron network
US9218563B2 (en) 2012-10-25 2015-12-22 Brain Corporation Spiking neuron sensory processing apparatus and methods for saliency detection
US9275326B2 (en) 2012-11-30 2016-03-01 Brain Corporation Rate stabilization through plasticity in spiking neuron network
US9123127B2 (en) 2012-12-10 2015-09-01 Brain Corporation Contrast enhancement spiking neuron network sensory processing apparatus and methods
US9195934B1 (en) 2013-01-31 2015-11-24 Brain Corporation Spiking neuron classifier apparatus and methods using conditionally independent subsets
US9177245B2 (en) 2013-02-08 2015-11-03 Qualcomm Technologies Inc. Spiking network apparatus and method with bimodal spike-timing dependent plasticity
US8937010B2 (en) 2013-02-27 2015-01-20 International Business Machines Corporation Information encoding using wirebonds
US9764468B2 (en) 2013-03-15 2017-09-19 Brain Corporation Adaptive predictor apparatus and methods
US8996177B2 (en) 2013-03-15 2015-03-31 Brain Corporation Robotic training apparatus and methods
US9008840B1 (en) 2013-04-19 2015-04-14 Brain Corporation Apparatus and methods for reinforcement-guided supervised learning
US9242372B2 (en) 2013-05-31 2016-01-26 Brain Corporation Adaptive robotic interface apparatus and methods
US9384443B2 (en) 2013-06-14 2016-07-05 Brain Corporation Robotic training apparatus and methods
US9792546B2 (en) 2013-06-14 2017-10-17 Brain Corporation Hierarchical robotic controller apparatus and methods
US9314924B1 (en) * 2013-06-14 2016-04-19 Brain Corporation Predictive robotic controller apparatus and methods
US9239985B2 (en) 2013-06-19 2016-01-19 Brain Corporation Apparatus and methods for processing inputs in an artificial neuron network
US9436909B2 (en) 2013-06-19 2016-09-06 Brain Corporation Increased dynamic range artificial neuron network apparatus and methods
US9552546B1 (en) 2013-07-30 2017-01-24 Brain Corporation Apparatus and methods for efficacy balancing in a spiking neuron network
US9467177B1 (en) * 2013-08-23 2016-10-11 Applied Micro Circuits Corporation Product coded modulation scheme based on leech lattice and binary and nonbinary codes
US9579789B2 (en) 2013-09-27 2017-02-28 Brain Corporation Apparatus and methods for training of robotic control arbitration
US9296101B2 (en) 2013-09-27 2016-03-29 Brain Corporation Robotic control arbitration apparatus and methods
US9489623B1 (en) 2013-10-15 2016-11-08 Brain Corporation Apparatus and methods for backward propagation of errors in a spiking neuron network
US9597797B2 (en) 2013-11-01 2017-03-21 Brain Corporation Apparatus and methods for haptic training of robots
US9463571B2 (en) 2013-11-01 2016-10-11 Brian Corporation Apparatus and methods for online training of robots
US9248569B2 (en) 2013-11-22 2016-02-02 Brain Corporation Discrepancy detection apparatus and methods for machine learning
US9582864B2 (en) 2014-01-10 2017-02-28 Perkinelmer Cellular Technologies Germany Gmbh Method and system for image correction using a quasiperiodic grid
US9358685B2 (en) 2014-02-03 2016-06-07 Brain Corporation Apparatus and methods for control of robot actions based on corrective user inputs
US9364950B2 (en) 2014-03-13 2016-06-14 Brain Corporation Trainable modular robotic methods
US9987743B2 (en) 2014-03-13 2018-06-05 Brain Corporation Trainable modular robotic apparatus and methods
US9533413B2 (en) 2014-03-13 2017-01-03 Brain Corporation Trainable modular robotic apparatus and methods
US9630317B2 (en) 2014-04-03 2017-04-25 Brain Corporation Learning apparatus and methods for control of robotic devices via spoofing
US9613308B2 (en) 2014-04-03 2017-04-04 Brain Corporation Spoofing remote control apparatus and methods
US9346167B2 (en) 2014-04-29 2016-05-24 Brain Corporation Trainable convolutional network apparatus and methods for operating a robotic vehicle
US9713982B2 (en) 2014-05-22 2017-07-25 Brain Corporation Apparatus and methods for robotic operation using video imagery
US10194163B2 (en) 2014-05-22 2019-01-29 Brain Corporation Apparatus and methods for real time estimation of differential motion in live video
US9939253B2 (en) 2014-05-22 2018-04-10 Brain Corporation Apparatus and methods for distance estimation using multiple image sensors
US9848112B2 (en) 2014-07-01 2017-12-19 Brain Corporation Optical detection apparatus and methods
US10057593B2 (en) 2014-07-08 2018-08-21 Brain Corporation Apparatus and methods for distance estimation using stereo imagery
US9821470B2 (en) 2014-09-17 2017-11-21 Brain Corporation Apparatus and methods for context determination using real time sensor data
US9860077B2 (en) 2014-09-17 2018-01-02 Brain Corporation Home animation apparatus and methods
US9849588B2 (en) 2014-09-17 2017-12-26 Brain Corporation Apparatus and methods for remotely controlling robotic devices
US9579790B2 (en) 2014-09-17 2017-02-28 Brain Corporation Apparatus and methods for removal of learned behaviors in robots
US10055850B2 (en) 2014-09-19 2018-08-21 Brain Corporation Salient features tracking apparatus and methods using visual initialization
US9630318B2 (en) 2014-10-02 2017-04-25 Brain Corporation Feature detection apparatus and methods for training of robotic navigation
US9881349B1 (en) * 2014-10-24 2018-01-30 Gopro, Inc. Apparatus and methods for computerized object identification
US9426946B2 (en) 2014-12-02 2016-08-30 Brain Corporation Computerized learning landscaping apparatus and methods
CN107408214B (en) * 2015-01-30 2021-07-09 惠普发展公司,有限责任合伙企业 M-ary cyclic coding
US9717387B1 (en) 2015-02-26 2017-08-01 Brain Corporation Apparatus and methods for programming and training of robotic household appliances
US9840003B2 (en) 2015-06-24 2017-12-12 Brain Corporation Apparatus and methods for safe navigation of robotic devices
US10197664B2 (en) 2015-07-20 2019-02-05 Brain Corporation Apparatus and methods for detection of objects using broadband signals
CN107850951B (en) * 2015-08-19 2020-12-18 株式会社和冠 Method for detecting sensor controller by stylus, stylus and sensor controller
US9430682B1 (en) 2015-09-28 2016-08-30 King Saud University Pressure profile data coding system and method
EP3220304B1 (en) * 2016-02-22 2018-11-07 Eshard Method of testing the resistance of a circuit to a side channel analysis
US10295972B2 (en) 2016-04-29 2019-05-21 Brain Corporation Systems and methods to operate controllable devices with gestures and/or noises
CN110505814A (en) 2017-02-20 2019-11-26 3M创新有限公司 Optical goods and the system interacted
CN107103350B (en) * 2017-05-04 2020-06-09 网易(杭州)网络有限公司 Physical medium surface multi-dimensional position coding method and device and readable storage medium
CN107122067B (en) * 2017-05-04 2020-09-08 网易(杭州)网络有限公司 Method and device for encoding and decoding surface position of physical medium and readable storage medium
US11314971B2 (en) 2017-09-27 2022-04-26 3M Innovative Properties Company Personal protective equipment management system using optical patterns for equipment and safety monitoring
CN110232428A (en) * 2018-03-05 2019-09-13 中华映管股份有限公司 Binary positions label generating method
TWI661721B (en) * 2018-04-03 2019-06-01 奇景光電股份有限公司 Method and circuit for detection motion
CN110415264B (en) * 2018-04-25 2023-10-24 奇景光电股份有限公司 Motion detection circuit and method
GB2576164B (en) * 2018-08-06 2020-07-29 John Edward Aras Richard Multi-axis position sensing system
CN111918003B (en) * 2019-05-08 2022-11-25 上海耕岩智能科技有限公司 Image sensor, signal acquisition method and circuit thereof, storage medium and terminal
WO2020255575A1 (en) * 2019-06-19 2020-12-24 ソニー株式会社 Encryption key generation device and encryption key generation method
CN112769573B (en) * 2020-12-26 2022-08-05 西安电子科技大学 Digital signature method, signature verification method and device based on GRS code
TW202306805A (en) * 2021-01-25 2023-02-16 瑞士商明門瑞士股份有限公司 Infant car seat anchoring assembly with retractable foot
CN113850100B (en) * 2021-09-24 2023-08-11 杭州海康威视数字技术股份有限公司 Method for correcting two-dimensional code and electronic equipment
CN114549423A (en) * 2022-01-26 2022-05-27 环旭电子股份有限公司 Label integrity self-adaptive detection method and system

Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4864618A (en) * 1986-11-26 1989-09-05 Wright Technologies, L.P. Automated transaction system with modular printhead having print authentication feature
US5051736A (en) * 1989-06-28 1991-09-24 International Business Machines Corporation Optical stylus and passive digitizing tablet data input system
US5477012A (en) * 1992-04-03 1995-12-19 Sekendur; Oral F. Optical position determination
US5612524A (en) * 1987-11-25 1997-03-18 Veritec Inc. Identification symbol system and method with orientation mechanism
US5652412A (en) * 1994-07-11 1997-07-29 Sia Technology Corp. Pen and paper information recording system
US5661506A (en) * 1994-11-10 1997-08-26 Sia Technology Corporation Pen and paper information recording system using an imaging pen
US5692073A (en) * 1996-05-03 1997-11-25 Xerox Corporation Formless forms and paper web using a reference-based mark extraction technique
US5852434A (en) * 1992-04-03 1998-12-22 Sekendur; Oral F. Absolute optical position determination
US6076734A (en) * 1997-10-07 2000-06-20 Interval Research Corporation Methods and systems for providing human/computer interfaces
US6267296B1 (en) * 1998-05-12 2001-07-31 Denso Corporation Two-dimensional code and method of optically reading the same
US20040173687A1 (en) * 2003-03-04 2004-09-09 Paul Lapstun Symmetric tags
US6964374B1 (en) * 1998-10-02 2005-11-15 Lucent Technologies Inc. Retrieval and manipulation of electronically stored information via pointers embedded in the associated printed material
US7980480B2 (en) * 2007-09-21 2011-07-19 Silverbrook Research Pty Ltd Method of imaging a coding pattern having registration symbols
US8006911B2 (en) * 2004-04-21 2011-08-30 Voiceye, Inc. System and method for encoding and decoding large capacity 2-dimensional color bar code which can be color-corrected
US8006912B2 (en) * 2007-02-08 2011-08-30 Silverbrook Research Pty Ltd Coding pattern with flags for determining tag data or block data

Family Cites Families (52)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US654768A (en) * 1900-05-03 1900-07-31 James M Thoburn Bottle-finisher.
EP0565738A1 (en) * 1990-01-05 1993-10-20 Symbol Technologies, Inc. System for encoding and decoding data in machine readable graphic form
DE69202975T2 (en) * 1991-04-03 1996-02-15 Hewlett Packard Co POSITIONING DEVICE.
US6182901B1 (en) * 1993-12-22 2001-02-06 Xerox Corporation Orientational disambiguation for self-clocking glyph codes
US6415398B1 (en) * 1995-09-29 2002-07-02 Kabushiki Kaisha Toshiba Coding system and decoding system
US6081261A (en) 1995-11-01 2000-06-27 Ricoh Corporation Manual entry interactive paper and electronic document handling and processing system
US6672511B1 (en) * 1996-06-03 2004-01-06 Symbol Technologies, Inc. Omnidirectional reading of two-dimensional symbols
US6330976B1 (en) * 1998-04-01 2001-12-18 Xerox Corporation Marking medium area with encoded identifier for producing action through network
WO1999050751A1 (en) 1998-04-01 1999-10-07 Xerox Corporation Routing document identifiers
US6427219B1 (en) * 1998-06-24 2002-07-30 Conexant Systems, Inc. Method and apparatus for detecting and correcting errors using cyclic redundancy check
EP1009098A1 (en) * 1998-12-10 2000-06-14 Sony International (Europe) GmbH Error correction using a turbo code and a CRC
US7178718B2 (en) * 1999-05-25 2007-02-20 Silverbrook Research Pty Ltd Methods and systems for object identification and interaction
US7233320B1 (en) * 1999-05-25 2007-06-19 Silverbrook Research Pty Ltd Computer system interface surface with reference points
EP1208420A1 (en) * 1999-05-28 2002-05-29 Anoto AB Calendar
AU2002952259A0 (en) * 2002-10-25 2002-11-07 Silverbrook Research Pty Ltd Methods and apparatus
SE517445C2 (en) * 1999-10-01 2002-06-04 Anoto Ab Position determination on a surface provided with a position coding pattern
US6817539B2 (en) * 2000-06-30 2004-11-16 Silverbrook Research Pty Ltd Generating landscape and portrait oriented tags
WO2002029976A1 (en) * 2000-10-06 2002-04-11 Samsung Electronics Co., Ltd APPARATUS AND METHOD FOR GENERATING (n,3) CODE AND (n,4) CODE USING SIMPLEX CODES
AUPR440901A0 (en) 2001-04-12 2001-05-17 Silverbrook Research Pty. Ltd. Error detection and correction
US20020153720A1 (en) * 2001-04-23 2002-10-24 Asay Jon L. Tear-away label
US20020172796A1 (en) * 2001-05-18 2002-11-21 Ronnie Magee Multi-patterned floor covering sample element
JP3910493B2 (en) * 2002-06-14 2007-04-25 新光電気工業株式会社 Semiconductor device and manufacturing method thereof
JP2004054529A (en) 2002-07-18 2004-02-19 Sharp Corp Method and program for reading two-dimensional code, recording medium for two-dimensional code reading program, and two-dimensional code reading device
CA2502483C (en) * 2002-10-25 2010-12-21 Silverbrook Research Pty Ltd Orientation-indicating cyclic position codes
US20040117250A1 (en) * 2002-12-17 2004-06-17 Allen Lubow Method and system for providing coupon savings using existing credit card processing infrastructure, and barcoded coupon having 2-D component
SE0203853D0 (en) * 2002-12-23 2002-12-23 Anoto Ab Data code
JP3996520B2 (en) 2003-01-30 2007-10-24 株式会社デンソーウェーブ Two-dimensional information code and generation method thereof
US6839870B2 (en) * 2003-03-21 2005-01-04 Terayon Communications Systems, Inc. Error-correcting code interleaver
US20040196489A1 (en) * 2003-04-07 2004-10-07 Kia Silverbrook Coupon redemption
EP1620828B1 (en) * 2003-04-29 2014-12-24 Anoto AB Methods, apparatus, computer program and storage medium for position decoding
KR100541052B1 (en) * 2003-09-22 2006-01-11 삼성전자주식회사 Laser annealing processes of a semiconductor material using a free carrier generation technique
SE0303370D0 (en) * 2003-12-16 2003-12-16 Anoto Ab Method, apparatus, computer program and storage medium for recording a movement of a user unit
US7385594B2 (en) * 2004-02-19 2008-06-10 Au Optronics Corporation Position encoded sensing device and a method thereof
CN1969300B (en) * 2004-05-18 2012-07-04 西尔弗布鲁克研究有限公司 Method and apparatus for security document tracking
KR20050114162A (en) * 2004-05-31 2005-12-05 삼성전자주식회사 Method and apparatus for decoding inner code and outer code in a mobile communication system using reed-solomon code
US7543197B2 (en) * 2004-12-22 2009-06-02 Qualcomm Incorporated Pruned bit-reversal interleaver
JP4409455B2 (en) * 2005-01-31 2010-02-03 株式会社ルネサステクノロジ Manufacturing method of semiconductor device
JP4556705B2 (en) * 2005-02-28 2010-10-06 富士ゼロックス株式会社 Two-dimensional coordinate identification apparatus, image forming apparatus, and two-dimensional coordinate identification method
JP4688526B2 (en) * 2005-03-03 2011-05-25 Okiセミコンダクタ株式会社 Semiconductor device and manufacturing method thereof
CN101180797A (en) * 2005-04-20 2008-05-14 新加坡科技研究局 Apparatus and method for generating monocycle pulse
EP1907987A4 (en) * 2005-07-25 2010-11-10 Silverbrook Res Pty Ltd Product item having coded data identifying a layout
JP4810918B2 (en) * 2005-08-01 2011-11-09 富士ゼロックス株式会社 Code pattern image generating apparatus and method, code pattern image reading apparatus and method, and code pattern image medium
EP1922673A2 (en) * 2005-08-19 2008-05-21 Global Payment Technologies, Inc. Information readers, apparatuses including information readers, and related methods
JP4586677B2 (en) * 2005-08-24 2010-11-24 富士ゼロックス株式会社 Image forming apparatus
US20070070311A1 (en) * 2005-09-23 2007-03-29 Asml Netherlands B.V. Contacts to microdevices
JP5934459B2 (en) * 2006-04-17 2016-06-15 オムニビジョン テクノロジーズ, インコーポレイテッド Arrayed imaging system and related method
MX2008015959A (en) * 2006-06-14 2009-03-02 Veritec Inc Multi-dimensional symbologies and related methods.
US20080144432A1 (en) * 2006-09-18 2008-06-19 Gideon Samid MIXFIX: fine-tuned graded mixing/entropic alphabet for chemical and visual encoding, efficient processing, and decorative painting
JP4688766B2 (en) * 2006-09-21 2011-05-25 パナソニック株式会社 Solid-state imaging device, driving method thereof and camera
WO2009108562A2 (en) * 2008-02-25 2009-09-03 Rambus Inc. Code-assisted error-detection technique
US8627163B2 (en) * 2008-03-25 2014-01-07 Micron Technology, Inc. Error-correction forced mode with M-sequence
US20100086236A1 (en) * 2008-10-02 2010-04-08 Silverbrook Research Pty Ltd Method of imaging position-coding pattern having tag coordinates encoded by successive subsequences of cyclic position code

Patent Citations (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4864618A (en) * 1986-11-26 1989-09-05 Wright Technologies, L.P. Automated transaction system with modular printhead having print authentication feature
US5612524A (en) * 1987-11-25 1997-03-18 Veritec Inc. Identification symbol system and method with orientation mechanism
US5051736A (en) * 1989-06-28 1991-09-24 International Business Machines Corporation Optical stylus and passive digitizing tablet data input system
US5477012A (en) * 1992-04-03 1995-12-19 Sekendur; Oral F. Optical position determination
US5852434A (en) * 1992-04-03 1998-12-22 Sekendur; Oral F. Absolute optical position determination
US5652412A (en) * 1994-07-11 1997-07-29 Sia Technology Corp. Pen and paper information recording system
US5661506A (en) * 1994-11-10 1997-08-26 Sia Technology Corporation Pen and paper information recording system using an imaging pen
US5692073A (en) * 1996-05-03 1997-11-25 Xerox Corporation Formless forms and paper web using a reference-based mark extraction technique
US6076734A (en) * 1997-10-07 2000-06-20 Interval Research Corporation Methods and systems for providing human/computer interfaces
US6267296B1 (en) * 1998-05-12 2001-07-31 Denso Corporation Two-dimensional code and method of optically reading the same
US6964374B1 (en) * 1998-10-02 2005-11-15 Lucent Technologies Inc. Retrieval and manipulation of electronically stored information via pointers embedded in the associated printed material
US20040173687A1 (en) * 2003-03-04 2004-09-09 Paul Lapstun Symmetric tags
US8006911B2 (en) * 2004-04-21 2011-08-30 Voiceye, Inc. System and method for encoding and decoding large capacity 2-dimensional color bar code which can be color-corrected
US8006912B2 (en) * 2007-02-08 2011-08-30 Silverbrook Research Pty Ltd Coding pattern with flags for determining tag data or block data
US7980480B2 (en) * 2007-09-21 2011-07-19 Silverbrook Research Pty Ltd Method of imaging a coding pattern having registration symbols
US7992793B2 (en) * 2007-09-21 2011-08-09 Silverbrook Research Pty Ltd Method of imaging coding pattern and identifying cell translations from different orientations

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140370921A1 (en) * 2011-09-20 2014-12-18 Sisvel Technology S.R.L. Method for reconstructing the map of an environment surrounding a wireless device and wireless device implementing such method
US9538322B2 (en) * 2011-09-20 2017-01-03 Sisvel Technology S.R.L. Method for reconstructing the map of an environment surrounding a wireless device and wireless device implementing such method
USRE49189E1 (en) * 2011-09-20 2022-08-23 Sisvel Technology S.R.L. Method for reconstructing the map of an environment surrounding a wireless device and wireless device implementing such method
US20140253465A1 (en) * 2013-03-11 2014-09-11 Barnesandnoble.Com Llc Stylus sensitive device with hover over stylus control functionality
US9261985B2 (en) 2013-03-11 2016-02-16 Barnes & Noble College Booksellers, Llc Stylus-based touch-sensitive area for UI control of computing device
US9766723B2 (en) * 2013-03-11 2017-09-19 Barnes & Noble College Booksellers, Llc Stylus sensitive device with hover over stylus control functionality
US9785259B2 (en) 2013-03-11 2017-10-10 Barnes & Noble College Booksellers, Llc Stylus-based slider functionality for UI control of computing device
US9946365B2 (en) 2013-03-11 2018-04-17 Barnes & Noble College Booksellers, Llc Stylus-based pressure-sensitive area for UI control of computing device
US10614275B2 (en) * 2016-06-21 2020-04-07 Mitutoyo Corporation Position specifying apparatus and position specifying method
US11195172B2 (en) * 2019-07-24 2021-12-07 Capital One Services, Llc Training a neural network model for recognizing handwritten signatures based on different cursive fonts and transformations

Also Published As

Publication number Publication date
US20100084481A1 (en) 2010-04-08
EP2344975A1 (en) 2011-07-20
US8328109B2 (en) 2012-12-11
US20100084472A1 (en) 2010-04-08
TW201015447A (en) 2010-04-16
TW201015445A (en) 2010-04-16
AU2009299097A1 (en) 2010-04-08
KR20110059894A (en) 2011-06-07
KR20110069822A (en) 2011-06-23
CN102171705A (en) 2011-08-31
US20100086236A1 (en) 2010-04-08
CA2736310A1 (en) 2010-04-08
US20100084477A1 (en) 2010-04-08
US20130175349A1 (en) 2013-07-11
TW201110031A (en) 2011-03-16
TW201110032A (en) 2011-03-16
TWI444902B (en) 2014-07-11
TW201035803A (en) 2010-10-01
JP2012504798A (en) 2012-02-23
US20100085607A1 (en) 2010-04-08
TWI457831B (en) 2014-10-21
CA2736267A1 (en) 2010-04-08
US20100084480A1 (en) 2010-04-08
TW201019230A (en) 2010-05-16
US20100084479A1 (en) 2010-04-08
US20100084478A1 (en) 2010-04-08
WO2010037157A1 (en) 2010-04-08
JP2012504799A (en) 2012-02-23
US20100086209A1 (en) 2010-04-08
TW201110030A (en) 2011-03-16
TWI456506B (en) 2014-10-11
US20100086171A1 (en) 2010-04-08
US8282016B2 (en) 2012-10-09
WO2010037158A1 (en) 2010-04-08
TW201023049A (en) 2010-06-16
TW201032144A (en) 2010-09-01
EP2344976A1 (en) 2011-07-20
US20120267439A1 (en) 2012-10-25
TW201019229A (en) 2010-05-16
TW201015446A (en) 2010-04-16
AU2009299096A1 (en) 2010-04-08

Similar Documents

Publication Publication Date Title
US8328109B2 (en) Coding pattern comprising registration symbols for identifying the coding pattern
US8397141B2 (en) Coding pattern comprising Reed-Solomon codewords encoded by mixed multi-pulse position modulation
US8413027B2 (en) Method of decoding a pattern-encoded coordinate
US8276828B2 (en) Method of decoding coding pattern comprising control symbols
US8276827B2 (en) Coding pattern comprising control symbols
US20110180612A1 (en) Coding pattern comprising multi-ppm data symbols with minimal clustering of macrodots
US20110180614A1 (en) Coding pattern comprising non-replicated coordinate data symbols
US20110185252A1 (en) Coding pattern comprising multi-ppm data symbols with different layouts
US20110180611A1 (en) Coding pattern comprising multi-ppm data symbols in a format identified by registration symbols
US20110182514A1 (en) Method of decoding coding pattern having self-encoded format
US20110181916A1 (en) Method of encoding coding pattern to minimize clustering of macrodots

Legal Events

Date Code Title Description
AS Assignment

Owner name: SILVERBROOK RESEARCH PTY LTD,AUSTRALIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LAPSTUN, PAUL;REEL/FRAME:023088/0044

Effective date: 20090105

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO PAY ISSUE FEE