This invention relates generally to mechanical displays and more specifically to a new and unique mechanical non-binary brixel and brixel display in the field of mechanical displays.
The following description of embodiments of the invention is not intended to limit the invention to these embodiments but rather to enable a person skilled in the art to make and use this invention. Variations, configurations, implementations, example implementations, and examples described herein are optional and are not exclusive to the variations, configurations, implementations, example implementations, and examples they describe. The invention described herein can include any and all permutations of these variations, configurations, implementations, example implementations, and examples.
As shown in
In one variation, each brixel unit 110 in the set of brixel units 110 includes: a chassis 130 that includes a motor mount 132, a arm 134 extending outwardly from the motor mount 132 and defining a drive post mount opposite the motor mount 132, and a mounting latch 136 adjacent the motor mount 132, opposite the drive post mount, and configured to transiently engage and support the chassis 130 on a mounting bracket 170 installed on a display surface; a motor 130 coupled to the motor mount 132; a drive pinion 142 coupled to an output shaft of the motor 130; a drive post 144 pivotably coupled to the drive post mount and including a driven pinion coupled to the drive pinion 142; a pixel element 112 mounted to and configured to rotate with the drive post 144 including a first face 113 defining a first visual characteristic and a second face 114 opposite the first face 113 and defining a second visual characteristic; and a local controller 120 configured to store an actuation routine in local memory at the brixel unit 110 and configured to drive the motor 130 to locate the pixel element 112 over a sequence of angular positions, relative to the arm 134, defined by the actuation routine.
A system 100 can thus include: a set of brixel units 110 arranged in an array; and a primary controller 160 configured to distribute a set of actuation routines to the set of brixel units 110.
In one variation, the system 100 can includes: a primary controller 160; a first set of brixel units 110 arranged in a first column (or a first row) and mounted to a display surface; a first column controller 150 coupled to the first set of brixel units 110 and configured to serve a first set of actuation routines, received from the primary controller 160, to local controllers 120 in the first set of brixel units 110; a second set of brixel units 110 arranged in a second column (or a second row) adjacent the first column and mounted to the display surface; and a second column controller 150 coupled to the second set of brixel units 110 and configured to serve a second set of actuation routines, received from the primary controller 160, to local controllers 120 in the second set of brixel units 110.
Generally, a brixel unit 110 represents an independently-operable, non-binary mechanical “pixel” configured to store a sequence of non-binary values representing a range of pixel positions and configured to autonomously manipulate a physical pixel element 112 according to this sequence of values. In particular, the brixel unit 110 can include: a pixel element 112 defining two (or more) faces spaced radially about a rotational axis; a motor 130 configured to rotate the pixel element 112 about this rotational axis; and a local controller 120 configured to drive the motor 130—and thus the pixel element 112—over a range of angular positions based on a set of values contained in an actuation routine upload and stored in local memory on the brixel unit 110.
Furthermore, an array of brixel units 110 can be installed on a vertical surface (shown in
In particular, though the pixel element 112 defines two (or more) faces of different colors and/or textures (e.g., black and white, glossy or polished matte), the brixel unit 110 can drive and hold the pixel element 112 over a range of angular positions between two binary 0° (e.g., depicting the first face 113 of the pixel element 112 facing outwardly parallel to a display surface) and 180° (e.g., depicting the second face 114 of the pixel element 112 facing outwardly parallel to the display surface) positions. Brixel units 110 installed on a display surface can thus independently and autonomously execute (unique or semi-unique) actuation routines—received from the master and corresponding column controllers 150—to form an animated mechanical display that represents non-binary pixel values (e.g., grayscale values from “0” to “255”) in images by locating corresponding pixel elements 112 in brixel units 110 in the installation over a range of angular positions (e.g., between a 0° and 180° in 0.7° increments).
As shown in
However, the chassis 130 and the drive post 144 can define any structure or geometry.
Generally, a pixel element 112 in a brixel unit 110 is mounted to the drive post 144, is configured to rotate with the drive post 144, and defines two opposing, outwardly-facing faces exhibiting different colors, patterns, and/or textures.
In one implementation, a pixel element 112 includes two clamshell structures assemblable into a cuboid shell defining two planar, opposing faces of different colors and textures. For example, the pixel element 112 can define a two-inch-tall, two-inch-deep, eight-inch-wide cuboid, wherein a first large face of the cuboid—parallel to a rotational axis of the pixel element 112—is coated with a matte black coating, and wherein a second, opposing face of the cuboid is a mirror-polished metallic surface. In another example, the pixel element 112 defines a one-inch-tall, two-inch-deep, twenty-inch-wide cuboid, wherein a first large face of the cuboid is painted glossy white, and wherein the opposing large face of the cuboid is a matte black.
Thus, a pixel element 112 of a brixel unit 110 can include: a first face 113 defining a first light reflectivity; and a second face 114 defining a second light reflectivity less than the first light reflectivity. Additionally or alternatively, a pixel element 112 of a brixel unit 110 can include: a first face 113 defining a first optical transparency; and a second face 114 defining a second optical transparency less than the first optical transparency.
Furthermore, a brixel unit 110 can include a light element 122 (e.g., an LED) arranged behind the pixel element 112, such as mounted to the chassis 130 or installed on a PCB (e.g., with the local controller 120 and a motor 130 driver) arranged between the chassis 130 of the brixel unit 110 and the pixel element 112. Thus, the light element 122 can back-light the pixel element 112, and the opposing faces of the light element 122 can reflect or pass light emitted by the light element 122 in different magnitudes.
In a similar implementation, the drive post 144 includes a hollow axle or defines a light tube, and the brixel unit 110 includes a light element 122 arranged in the arm 134 and configured to illuminate the bore or light tube through the drive post 144, thereby illuminating the interior volume of the pixel element 112. In this implementation, one or more sides of the pixel element 112 can include a perforating, translucent, or transparent face configured to pass light output by the light element 122 and transmitted through the drive post 144.
However, the pixel element 112 can define any other form, color, pattern, or texture.
The motor 130 in a brixel unit 110 can include a stepper motor 130, a servo motor 130, or a brushed or brushless DC motor 130 installed in the motor mount 132 of the chassis 130. For example, the motor 130 can be installed in the motor mount 132 with an output shaft of the motor 130 facing downward and extending through the bottom of the motor mount 132, and a drive pinion 142 (e.g., a drive pulley) can be mounted to the output shaft of the motor 130.
In one implementation, the drive pinion 142 is coupled to the driven pinion on the drive post 144 via a timing belt, and a spring-loaded belt tensioner is mounted to the arm 134 and configured to maintain tension on the timing belt. Alternatively, the drive pinion 142 can be coupled to the driven pinion via a driveshaft or other power transmission.
The brixel unit 110 can also include a rotary encoder coupled to the motor 130, such as a rotary optical encoder configured to output “ticks” responsive to angular position changes of the output shaft of the motor 130. (Alternatively, the rotary encoder can be coupled to the drive post 144 and can output “ticks” responsive to angular position changes of the pixel element 112.)
A position indicator of a brixel unit 110 is mounted to the pixel element 112, and the home sensor is mounted to the chassis 130 (e.g., to the arm 134) and outputs a signal representative of proximity to the position indicator, which the local controller 120 can then monitor to calibrate and maintain a “home” (or “0°”) position of the pixel element 112 during operation.
For example, the home sensor can include a Hall effect sensor arranged on the arm 134 between the motor 130 and the drive post 144; and the position indicator can include a magnetic element integrated into or mounted to a bottom face of the pixel element 112 and configured to trigger the Hall effect sensor once per rotation of the pixel element 112 at a repeatable angular position of the pixel element 112 relative to the chassis 130. In another example, the home sensor includes a limit switch mounted to the chassis 130, such as on the arm 134 near the motor mount 132; and the position indicator includes a cam or other mechanical feature mounted to or integrated into the pixel element 112 and configured to contact the limit switch once per rotation of the pixel element 112 at a repeatable angular position of the pixel element 112. Thus, in these examples, the local controller 120 can detect and verify an absolute position of the pixel element 112 relative to the home sensor for instances in which rotation of the pixel element 112 moves the position indicator within proximity of the home sensor sufficient to change an output of the home sensor.
However, the home sensor and the position indicator can include any other sensor or indicator type and can cooperate in any other way to indicate an absolute position of the pixel element 112.
The local controller 120 of a brixel unit 110 is mounted to the chassis 130, such as proximal the motor 130, and includes an internal clock and local memory. As described below, the local controller 120 caches or stores an actuation routine and implements open-loop or closed-loop controls to drive the motor 130 through a sequence of steps and/or rotary encoder ticks corresponding to target changes in angular position of the pixel element 112 specified in or interpreted from the actuation routine.
A column (or row, a cluster) of brixel units 110 in an installation can be connected—in parallel or in series—to a column controller 150, and each column controller 150 in the installation can be connected—in parallel or in series—to a primary controller 160, such as described in U.S. patent application Ser. No. 15/824,244, which is incorporated in its entirety by this reference.
In particular, a column controller 150: can be located between a column or other cluster of brixel units 110, the primary controller 160, and a power supply; can distribute power to this column or cluster of brixel units 110; can receive actuation routines and actuation triggers from the primary controller 160; and can distribute these actuation routines and actuation triggers to corresponding brixel units 110 in this column or cluster. In one example, each brixel unit 110 in a column of brixel units 110 is connected to a numbered port on the column controller 150 based on a position of this brixel unit 110 in the column. In this example, a column controller 150 receives a set of actuation routines—each labeled with a port number based on a vertical position of a pixel represented by the actuation routine—from the primary controller 160 and outputs each actuation routine to a corresponding port number; each brixel unit 110 thus stores a local copy of its received actuation routine and executes this actuation routine upon receipt of a trigger from the primary controller 160 and/or from the column controller 150.
In another example, brixel units 110 in a column (or cluster) of brixel units 110 are connected in series—or “daisy-chained” together—with a first brixel unit 110 in the column or cluster connected to (or forming) the column controller 150. In this example, the column controller 150 (or the first brixel unit 110 in the column) receives a set of actuation routines—ordered from the bottom of the column to the top of the column—from the primary controller 160 and distributes the set of actuation routines to the first brixel unit 110 in its column. Upon receipt, the first brixel unit 110 extracts the first actuation routine from this set and passes the remaining, ordered actuation routines to the second brixel unit 110 in the column. The second brixel unit 110 then extracts the first actuation routine in this set and passes the remaining, ordered actuation routines to the next brixel unit 110 in the column. Subsequence brixel units 110 in this column repeat this process up to the top brixel unit 110 in the column in order to complete distribution of actuation routines to brixel units 110 in the column without necessitating unique identification of brixel units 110 in the column.
However, the master, column, and local controllers 120 can implement any other protocol to distribute and store actuation routines in preparation for or during operation.
As shown in
In one implementation, an array of mounting brackets 170 is installed on (e.g., fastened onto) a vertical surface, such as a planar wall. In this implementation, each mounting bracket 170 can include: a set of (e.g., one or more) alignment features configured to engage and align with corresponding features on a brixel unit 110; a mounting feature configured to transiently engage a mounting latch 136 of the brixel unit 110; and a power and data connector(s) configured to engage a corresponding power and data connector(s) of the brixel unit 110 when the brixel unit 110 is installed on the mounting bracket 170. A column controller 150 is then mounted below or connected to the bottom mounting bracket 170 in each column of mounting brackets 170 in this array. Power and data connector(s) from each column of mounting brackets 170 and the corresponding column controller 150 are connected in series, and these column controllers 150 are connected in parallel or in series to one primary controller 160 installed proximal a bottom-left mounting bracket 170 in the array.
In this implementation, a pixel element 112 of a first brixel unit 110 designated for the installation is manually rotated such that its long axis is substantially parallel to the arm 134 of its chassis 130, thereby enabling a technician to look past the pixel element 112—parallel to the long axis of the produce unit—and thus view the back of the chassis 130 and the mounting latch 136 behind the pixel element 112 in this brixel unit 110. The technician then aligns the alignment features of the chassis 130 with the corresponding features on a mounting bracket 170 and presses the brixel unit 110 toward the mounting bracket 170 until the mounting latch 136 engages a corresponding feature on the mounting bracket 170 to retain the chassis 130 on the mounting bracket 170, thereby mechanically coupling the brixel unit 110 to the mounting bracket 170 and connecting a power and data connector(s) in the mounting bracket 170 to a corresponding port(s) on the brixel unit 110. The technician repeats the process for each other mounting bracket 170 and brixel unit 110 to complete this installation.
Furthermore, in this implementation, to service or replace a brixel unit 110 in this installation at a later time, the technician may manually rotate the pixel element 112 of the brixel unit 110 such that the long axis of the pixel element 112 is substantially parallel to the arm 134 of its chassis 130, thereby enabling a technician to look past the pixel element 112—parallel to this long axis—and thus view the chassis 130 and mounting latch 136 behind the pixel element 112 in this brixel unit 110. The technician may then: insert an elongated tool past the pixel element 112 to engage the mounting latch 136; manipulate the tool to lift, depress, or otherwise retract the mounting latch 136 from the mounting bracket 170; and then pull the brixel unit 110 horizontally off of the mounting bracket 170 to remove the brixel unit 110 from the installation.
However, an array of mounting brackets 170 and brixel units 110 can be installed on a vertical surface and connected in any other way to complete an installation.
As shown in
In a similar implementation, the system 100 includes: a first column of mounting brackets 170 configured to mount a first subset of brixel units 110 to a planar display surface (e.g., a planar vertical or horizontal display surface); and a second column of mounting brackets 170 configured to mount a second subset of brixel units 110 to the planar display surface; etc. In this implementation, each mounting bracket 170 includes: a mounting feature configured to transiently engage a mounting latch 136 of a brixel unit 110 in the set of brixel units 110 and to transiently retain the brixel unit 110 against the display surface with the pixel element 112 cantilevered from the display surface via the arm 134 of the brixel unit 110; and an electrical connector configured to electrically couple to the local controller 120 in the brixel unit 110.
In this implementation, the first column of mounting brackets 170 can include a set of discrete mounting brackets 170 that are mechanically fastened and assembled to form a first mounting bracket 170 assembly configured to mount to the planar display surface. Alternatively, a singular or unitary structure can be fabricated to form the first column of mounting brackets 170. The second column of mounting brackets 170, etc. can be similarly assembled or constructed.
Furthermore, the mounting brackets 170 can define similar (e.g., approximately identical) depths, and the brixel units 110 in the system 100 can include arms 134 of similar length. Thus, the first faces 113 of pixel elements 112 in the first subset of brixel units 110, the second subset of brixel units 110, etc. can cooperate to interpolate a smooth, planar surface—parallel to and offset from the planar display surface—when occupying nominal “home” positions.
In this implementation, the system 100 can further includes a first column (or “group”) controller: arranged in the first mounting bracket 170 assembly; serially coupled to local controllers 120 in the first subset of brixel units 110 via electrical connectors arranged in the first column of mounting brackets 170; coupled to the primary controller 160; and configured to receive a first set of actuation routines from the primary controller 160. Thus, a first brixel unit 110 in the first subset of brixel units 110 can: receive the first set of actuation routines from the group controller 150 and pass the first set of actuation routines to a second brixel unit 110 in the first subset of brixel units 110; the second brixel unit 110 in the first subset of brixel units 110 can receive the first set of actuation routines from the first brixel unit 110 and pass the first set of actuation routines to a third brixel unit 110 in the first subset of brixel units 110; etc.
In this implementation, the system 100 can similarly include a second column (or “group”) controller: arranged in the second mounting bracket 170 assembly; serially coupled to local controllers 120 in the second subset of brixel units 110 via electrical connectors arranged in the second column of mounting brackets 170; coupled to the primary controller 160; and configured to receive a second set of actuation routines from the primary controller 160 and to distribute these actuation routines to the second subset of brixel units 110.
Conversely, in the foregoing implementation, the mounting brackets 170 can be installed on a planar display surface (e.g., a planar vertical or horizontal display surface), and the brixel units 110 in the system 100 can include arms 134 of dissimilar lengths. For example, in the foregoing implementation: a first arm 134 of a first brixel unit 110 in the first column of brixel units 110 can define a first length; a second arm 134 of a second brixel unit 110 in the first column of brixel units 110 can define a second length greater than the first length; a third arm 134 of a third brixel unit 110 in the second column of brixel units 110 can define a third length greater than the first length; and a fourth arm 134 of a fourth brixel unit 110 in the second column of brixel units 110 can define a fourth length greater than the third length; etc.
Thus, the first faces 113 of pixel elements 112 in brixel units 110 in the first column of brixel units 110, the second subset of brixel units 110, etc. can cooperate to: interpolate a smooth, non-planar (e.g., a three-dimensional) surface when occupying nominal “home” positions; and form a “textured” non-planar surface when offset from their nominal “home” positions.
As shown in
Once an array of brixel units 110 is installed on a display surface, the brixel units 110 can execute calibration routines to calibrate angular positions of their pixel elements 112.
In one implementation, after an array of brixel units 110 is installed on a display surface, a technician manually manipulates pixel elements 112 in these brixel units 110 in order to locate first faces 113 of these pixel elements 112 on a continuous plane (or on a contiguous surface). The technician then triggers the primary controller 160 to initiate calibration routines at these brixel units 110. Upon receipt of this trigger, the primary controller 160 distributes calibration routine commands to the column controllers 150, each of which distributes calibration triggers to its connected brixel units 110.
Upon receipt of a calibration trigger, a local controller 120 in a brixel unit 110: drives the motor 130 in a forward direction to rotate the pixel element 112; records a count of motor 130 steps completed by the motor 130 during this rotation; records a count of encoder ticks output by the rotary encoder during this rotation; and monitors outputs of the home sensor. In response to detecting a change in output of the home sensor—which indicates proximity of the position indicator to the home sensor—the local controller 120: records the current motor 130 step count as a motor 130 step calibration offset; and records the current encoder tick count as an encoder tick calibration offset.
Later during operation, the brixel unit 110 can “home” the pixel element 112 (i.e., align the first face 113 of the pixel element 112 with the continuous plane) by: driving the motor 130 in the forward direction to rotate the pixel element 112; monitoring the output of the home sensor; and then reversing the motor 130 through a set of steps equal to the motor 130 step calibration offset and confirming that a quantity of encoder ticks output by the rotary encoder during this reverse operation (approximately) equals the encoder tick calibration offset.
Furthermore, when executing an actuation routine, the local controller 120 can monitor the output of the home sensor and recalculate a home position of the pixel element 112—when the output of the home sensor indicates proximity of the position indicator as the motor 130 is driver in the forward direction—by subtracting the motor 130 step calibration offset from the current motor 130 step count and by subtracting the encoder tick calibration offset from the current encoder tick count.
In a similar implementation, each brixel unit 110 includes: a wireless communication module 126; and a home sensor 124 configured to output a signal corresponding to a reference angular position of a pixel element 112 of the brixel unit 110. In this implementation, a local controller 120 in a brixel unit 110: stores a home position of a pixel element 112 in the brixel unit 110 that triggers output of a signal from a home sensor 124 in the brixel unit 110; receives a stream of orientation values from an external position sensor, temporarily mated to a first face 113 of the pixel element 112 of the brixel unit 110, via the wireless communication module 126; drives a motor 130 in the brixel unit 110 according to a difference between the stream of orientation values and a target home orientation (i.e., to reduce this difference); and stores an angular offset (e.g., in the form of a count of encoder ticks or motors 130 steps) between the home position and an angular position of the pixel element 112 corresponding to receipt of an orientation value—in the stream of orientation values received from the external position sensor—approximating the target home orientation. Later, during operation, the local controller 120 drives the motor 130 in the brixel unit 110 to locate the pixel element 112 over a sequence of angular positions—defined by an assigned actuation routine—relative to the angular offset.
However, a brixel unit 110 can calibrate the angular position of its pixel element 112 and its motor 130 in any other way.
A computing device (e.g., a smartphone, a tablet a laptop computer) executing a user portal and/or a remote computer system can interface with a user to generate a set of actuation routines for brixel units 110 in the installation.
In one implementation, to generate actuation routines for an installation of brixel units 110, an operator: uploads a color video—including multiple frames spanning multiple seconds, minutes, or hours—to the user portal; and enters a geometry of the installation (e.g., a quantity of brixel unit 110 column, a quantity of brixel unit 110 rows, a width and height of each pixel element 112, and/or a pitch height and pitch width between adjacent brixel units 110) at the user portal. The computing device (or a remote computer system, etc.) then: converts the color video to grayscale, such as with each pixel including a value between “0” and “255”; crops or adjusts the grayscale video to an aspect ratio (i.e., a width to height ratio) equal to an aspect ratio of the installation; and downsamples the video to a frame rate equal to an update rate of brixel units 110 in the installation (e.g., 1 Hz).
In this implementation, the computing device then compresses frames in the downsampled grayscale video to a number of rows and columns of pixels equal to a number of rows and columns of brixel units 110 in the installation such that each pixel in each frame in the video corresponds to one brixel unit 110 in the installation. For example, the computing device can select a cluster of pixels—in a first grayscale frame in the grayscale video—that spans a geometry approximating a geometry of a corresponding brixel unit 110 in the installation, such as a 20-pixel-tall, 80-pixel-wide rectangular cluster of pixels for a brixel unit 110 that includes two-inch-tall, eight-inch-wide pixel element 112. The computer system can then: average the grayscale values in this pixel cluster; store this average grayscale value in a single corresponding pixel in a first compressed frame; and repeat this process for each other cluster of pixels in the first grayscale frame to complete the first compressed grayscale frame. The computing device can repeat this process for each other grayscale frame in the grayscale video in order to transform the grayscale video into a sequence of compressed grayscale frames.
Then, for a first pixel—in this sequence of compressed grayscale frames—corresponding to a first brixel unit 110 in the installation, the computing device can: extract an ordered sequence of grayscale color values from the first pixel in this sequence of compressed grayscale frames; store the ordered sequence of grayscale color values in a table or other singular file format; store this table in an actuation routine for the first brixel unit 110; and write a scalar time value—representing a time offset (e.g., in milliseconds) between consecutive grayscale color values—to this actuation routine. The computing device can repeat this process for each other pixel in the sequence of compressed grayscale frames in order to transform the compressed grayscale video into an actuation routine for each other brixel unit 110 in the installation, wherein each actuation routine: defines a singular file; is tagged with a position or identifier of the corresponding brixel unit 110 in the installation; and includes a sequence of values (e.g., from “0” to “255”) corresponding to grayscale values of a corresponding pixel in the sequence of compressed grayscale frames thus generated from the original color video.
In a similar implementation, the user portal ingests a set of still images—such as human portraits or still images of corporate iconography—uploaded by the user and records a dwell time for these still images entered by the user. The computing device (or the remote computer system) then implements the foregoing methods and techniques to convert each still image into a grayscale image sized to an aspect ratio of the brixel unit 110 installation and compressed to the arrangement of brixel units 110 in the installation. The computing device then: compiles grayscale values from a particular pixel location in each frame into one actuation routine for a corresponding brixel unit 110; writes a dwell time for each grayscale value to the actuation routine; and repeats this process for each other pixel location in this set of compressed grayscale images to generate an actuation routine for each other brixel unit 110 in the installation.
Alternatively, rather than transform an existing video into a discrete actuation routine for each brixel unit 110, the user portal can prompt the user to select a pattern from a menu of preexisting patterns, such as: a “linear wave” pattern; a “spiral wave” pattern; a “shimmer” pattern; an “earthquake” pattern; or a “snake” pattern.” The user portal can also prompt the user to confirm a pattern speed and an actuation duration (e.g., in second, minutes, hours, or days). The computing device can then: retrieve a sequence of grayscale frames representing the selected pattern; duplicate the sequence of grayscale frames based on the selected actuation duration; and adjust the sequence of grayscale frames to the aspect ratio of the brixel unit 110 installation and compressed to the arrangement of brixel units 110 in the installation. The computing device can then: compile grayscale values from a particular pixel location in each frame into one actuation routine for a corresponding brixel unit 110; write a speed or dwell time for each grayscale value to the actuation routine based on the pattern speed selected by the user; and repeat this process for each other pixel location in this set of compressed grayscale images to generate an actuation routine for each other brixel unit 110 in the installation.
In the foregoing implementations, the computing device can generate an actuation routine that specifies, for a brixel unit 110, sequences of: absolute angular positions (e.g., 32-bit representations of angular offsets in degrees from a home position); relative angular moves (e.g., 32-bit representations of angular offsets from a last angular position occupied by the brixel unit 110); angular speeds; angular accelerations; angular decelerations; directions of angular motion; absolute or relative “stop and go” positions; durations of continuous motion periods; durations of stop and go intervals; and/or motion profiles containing the foregoing parameters and spanning durations of time (e.g., multiple seconds, minutes, or hours). For example, the computing device can generate an actuation routine in the form of a single “frame,” which can be uploaded to the primary controller 160 and distributed to a corresponding local controller 120 in one brixel unit 110 in an installation via a column controller 150. The brixel unit 110 can thus load this actuation routine and execute angular positions, speeds, and accelerations over periods of time specified in this actuation routine independently of other brixel units 110 in the installation concurrently executing their own stored actuation routines. For example, each brixel unit 110 in the installation can execute its own assigned actuation routine independently of each other brixel unit 110 in the installation over a period of minutes or hours based on an internal clock (e.g., a quartz clock) in the brixel unit 110 and then time-synchronize itself to the primary controller 160—and thus other brixel units 110 in the installation—only after loading a new actuation routine minutes or hours later (or only upon receipt of a command to repeat the loaded actuation routine from the primary controller 160 some minutes or hours later).
However, the user portal, the computing device, and/or the remote computer system can generate an actuation routine for each brixel unit 110 in the installation in any other way.
The user may then upload a set of actuation routines to the primary controller 160, such as physically connecting the mobile device to the primary controller 160, wirelessly transmitting the set of actuation routines from the mobile device to the primary controller 160, or triggering upload of the set of actuation routines from a remote database to the primary controller 160 via a computer network (e.g., the Internet). The primary controller 160 can then distribute these actuation routines to column controllers 150 in the installation, and these column controllers 150 can disperse these actuation routines to their connected brixel units 110 as described above, and each brixel unit 110 can store its actuation routine in local memory. Once these actuation routines are loaded onto their corresponding brixel units 110, the primary controller 160 and column controllers 150 can distribute actuation triggers to these brixel units 110 responsive to receipt of a command from the technician to begin operation (e.g., via a physical button on the primary controller 160 or via the user portal executing on the computing device connected to the primary controller 160).
Responsive to receipt of an actuation trigger, a brixel unit 110 in the installation can: initiate a first actuation cycle for a duration based on the update rate of the installation (e.g., a one-second actuation cycle for a 1 Hz update rate); extract a first grayscale value from its stored actuation routine; and convert this first grayscale value into a target angular position of the pixel element 112. For example, the brixel unit 110 can: convert a “0” grayscale value to a target angular position of 0°, which corresponds to “0” motor 130 steps from a home position for a 1000-step stepper motor 130 and “0” encoder ticks from a home position for a 512-tick rotary encoder; convert a “63” grayscale value to a target angular position of 45°, which corresponds to “125” motor 130 steps and “64” ticks from the home position; convert a “127” grayscale value to a target angular position of 90°, which corresponds to “250” motor 130 steps and “128” ticks from the home position; and convert a “256” grayscale value to a target angular position of 180°, which corresponds to “500” motor 130 steps and “256” ticks from the home position. (Alternatively, the user portal can convert grayscale values into angular positions of pixel elements 112 when generating an actuation routine as described above.) The brixel unit 110 can then calculate a target motor 130 step offset and a target encoder tick offset to achieve the target angular position in this first actuation cycle based on differences between: the current motor 130 step and encoder tick count from the home position (e.g., “0” motor 130 steps and “0” encoder ticks if the pixel element 112 is currently occupying the home position); and the target angular position in motor 130 steps and encoder ticks.
In particular, the local controller 120 in the brixel unit 110 can calculate a first motor 130 step offset by subtracting the current position of the pixel element 112 in motor 130 steps from the home position from the target quantity of motor 130 steps from the home position represented in the first grayscale value in the actuation routine. The local controller 120 can also calculate a second motor 130 step offset by subtracting the target quantity of motor 130 steps from the home position represented in the first grayscale value in the actuation routine from the current position of the pixel element 112 in motor 130 steps from the home position. The local controller 120 can then select one of the first motor 130 step offset and the second motor 130 step offset representing the lowest absolute value and store this motor 130 step offset as a target motor 130 step offset for this first actuation cycle. Similarly, the local controller 120 can calculate a first encoder tick offset by subtracting the current position of the pixel element 112 in encoder ticks from the home position from the target quantity of encoder ticks from the home position represented in the first grayscale value in the actuation routine. The local controller 120 can also calculate a second encoder tick offset by subtracting the target quantity of encoder ticks from the home position represented in the first grayscale value in the actuation routine from the current position of the pixel element 112 in encoder ticks from the home position. The local controller 120 can then select one of the first encoder tick offset and the second encoder tick offset representing the lowest absolute value and store this encoder tick offset as a target encoder tick offset for the first actuation cycle.
The local controller 120 in the brixel unit 110 can then: drive the motor 130 a number of steps equal to the absolute value of the target motor 130 step offset and in a direction corresponding to the sign of the target motor 130 step offset; and verify that the pixel element 112 has reached the target angular position represented by the first grayscale value in the actuation routine if the number of ticks output by the rotary encoder during this first actuation cycle (approximately) equals the target encoder tick offset.
Furthermore, in this implementation, the local controller 120 can drive the motor 130 at a maximum speed (e.g., a “rapid speed”) to the target motor 130 step offset and then hold the motor 130 in this target angular position for the remainder of this first actuation cycle. Alternatively, the local controller 120 can calculate an angular speed of the motor 130 that will achieve this target motor 130 step offset by the conclusion of the first actuation cycle (e.g., over a duration of one second)—such as up to the maximum speed of the motor 130—and then drive the motor 130 through this target motor 130 step offset at this angular speed during the first actuation cycle. During this first actuation cycle, if the brixel unit 110 drives the position indicator in the pixel element 112 past the position sensor, then the local controller 120 can update its record of the current absolute position of the pixel element 112 according to a change in output of the position sensor in order to account for possible loss of motor 130 steps and encoder ticks during operation.
The local controller 120 can repeat the foregoing process: to calculate a next target motor 130 step offset based on a next grayscale value in the actuation routine; and to drive the motor 130 through this next target motor 130 step offset during this next actuation cycle. In particular, the local controller 120 can repeat this process until it reaches the last grayscale value in the actuation routine.
Upon reaching the conclusion of the actuation routine, the local controller 120 can: repeat the actuation routine from the first grayscale value forward; repeat the actuation routine from the last grayscale value backward; or return to the home position. Additionally or alternatively, upon reaching the conclusion of the actuation routine, the local controller 120 can also return confirmation of the actuation routine to the column controller 150, which can return such confirmation to the primary controller 160. Upon receipt of such confirmation from all brixel units 110 in the installation, the primary controller 160 and column controllers 150 can repeat the foregoing processes to distribute next actuation routines to the brixel units 110 in the installation and to trigger execution of these actuation routines by these brixel units 110.
Alternatively, rather than upload an actuation routine that includes pixel element 112 data spanning multiple actuation cycles (or “refresh periods”) of the installation, the primary controller 160 can: ingest a live or prerecorded stream of frames (e.g., a live video feed from a connected camera); implement methods and techniques described above to transform a current frame in this stream into a one grayscale value or target angular position for each brixel unit 110 in the assembly; and stream these grayscale values or target angular positions to the column controllers 150, which then stream these grayscale values or target angular positions to their connected brixel units 110. In this implementation, each brixel unit 110 can then implement the foregoing methods and techniques to automatically drive its pixel element 112 to the angular position thus received from its column controller 150.
In one example, a local controller 120 in a brixel unit 110, in the set of brixel units 110: reads a first target angular position from an actuation routine assigned to the brixel unit 110 by the primary controller 160; reads a first angular speed profile from the actuation routine; reads a first direction from the actuation routine; receives a start command issued by the primary controller 160 (such as separate from or coextensive (i.e., the same as) the actuation routine); and drives a motor 130 of the brixel unit 110 to rotate a pixel element 112 of the brixel unit 110 from a current angular position to the first target angular position along the first direction and according to the first angular speed profile responsive to receiving the start command (or responsive to receiving the actuation routine, receipt of which by the local controller 120 represents a “start command”). The local controller 120 then: reads a second target angular position from the actuation routine; reads a second angular speed profile from the actuation routine; reads a second direction from the actuation routine; and drives the motor 130 to rotate the pixel element 112 from the first angular position to the second target angular position along the second direction and according to the second angular speed profile.
In this example, in response to conclusion of an actuation routine assigned to the brixel unit 110 by the primary controller 160, the local controller 120 can: drive the motor 130 of the brixel unit 110 to rotate the pixel element 112 of the brixel unit 110 to a start (or “home”) angular position; and return confirmation of conclusion of the actuation routine to the primary controller 160, via the column (or “group”) controller.
The primary controller 160 can then issue a second actuation routine to the brixel unit 110 and transmit a second start command (separate from or contiguous with the second actuation routine) to the brixel unit 110—and to other brixel units 110 in the system 100, via their connected column controllers 150—to initiate execution of their assigned actuation routines. The local controller 120 can then: receive its second actuation routine—thus assigned to it by the primary controller 160—via its column controller 150; read a third target angular position from the second actuation routine; read a third angular speed profile from the third actuation routine; read a third direction from the third actuation routine; receive the second start command issued by the primary controller 160 (or contiguous with the second actuation routine); and drive the motor 130 of the brixel unit 110 to rotate the pixel element 112 from the start (or “home”) angular position to the third target angular position along the third direction and according to the third angular speed profile responsive to receiving the second start command (or responsive to receiving the second actuation routine, receipt of which by the local controller 120 represents a second “start command”).
Thus, in this implementation, a local controller 120 of a brixel unit 110 can drive the motor 130 and pixel element 112 in this brixel unit 110 through a sequence of angular positions—and in particular forward and/or reverse directions—defined in an actuation routine assigned to the brixel unit 110 and received from the primary controller 160 via a connected column controller 150.
Additionally or alternatively, a local controller 120 in a brixel unit 110, in the set of brixel units 110: reads a first acceleration profile and a first deceleration profile from the actuation routine; reads a first rotation duration from the actuation routine; reads a first direction from the actuation routine; and receives a start command issued by the primary controller 160 (or interprets receipt of the actuation routine generally as the start command). During a first rotation duration, the local controller 120 then: accelerates a motor 130 of the brixel unit 110 according to the first acceleration profile to rotate the pixel element 112 in the first direction responsive to receiving the start command (or responsive to receiving the actuation routine method or technique generally); and decelerates the motor 130 according to the first deceleration profile.
Similarly, the local controller 120 can: read a second acceleration profile and a second deceleration profile from the actuation routine; read a second rotation duration from the actuation routine; and read a second direction from the actuation routine. Then during the second rotation duration succeeding the first rotation duration, the local controller 120 can: accelerate the motor 130 according to the second acceleration profile to rotate the pixel element 112 in the second direction; and decelerate the motor 130 according to the second deceleration profile.
Thus, in this implementation, a local controller 120 of a brixel unit 110 can drive the motor 130 and pixel element 112 in this brixel unit 110 through a sequence of acceleration and deceleration profiles—and in particular forward and/or reverse directions—defined in an actuation routine assigned to the brixel unit 110 and received from the primary controller 160 via a connected column controller 150.
In a similar implementation, a local controller 120 in a brixel unit 110, in the set of brixel units 110: reads a first acceleration profile and a first deceleration profile from the actuation routine; reads a first rotation count from the actuation routine; reads a first direction from the actuation routine; and receives a start command issued by the primary controller 160 (or interprets receipt of the actuation routine as the start command). During a first rotation period, the local controller 120: accelerates a motor 130 of the brixel unit 110 according to the first acceleration profile to rotate the pixel element 112 in the first direction responsive to receiving the start command (or the actuation routine more generally); drives the motor 130 to rotate the pixel element 112 over the first rotation count; and decelerates the motor 130 according to the first deceleration profile. The local controller 120 then: reads a second acceleration profile and a second deceleration profile from the actuation routine; reads a second rotation count from the actuation routine; and reads a second direction from the actuation routine. During the second rotation period succeeding the first rotation period, the local controller 120 then: accelerates the motor 130 according to the second acceleration profile to rotate the pixel element 112 in the second direction; drives the motor 130 to rotate the pixel element 112 over the second rotation count; and decelerates the motor 130 according to the first deceleration profile.
Thus, in this implementation, a local controller 120 of a brixel unit 110 can drive the motor 130 and pixel element 112 in this brixel unit 110 through a target count of (full and partial) rotations—and in particular forward and/or reverse directions and according to particular acceleration and deceleration profiles—defined in an actuation routine assigned to the brixel unit 110 and received from the primary controller 160 via a connected column controller 150.
However, the primary controller 160, column controllers 150, and brixel units 110 in this installation can implement any other method or technique to depict a set of pre-recorded, pre-generated, or live frames.
In one variation shown in
The center column 180 includes a cylindrical tube 182 and defines a column of drive windows 184 with adjacent drive windows 184 offset at a vertical pixel pitch distance. The base 190 is configured to support the center column 180 and houses the column controller 150. The bearing collar 186 is coupled to the center column 180 adjacent a drive window 184 and defines a vertical thrust surface.
The brixel unit 110 includes: a pixel element 112; an internal ring gear 146; and a bearing housing 148. The pixel element 112 includes: a first face 113 defining a first visual characteristic; and a second face 114 opposite the first face 113 and defining a second visual characteristic. The internal ring gear 146 is coupled to the pixel element 112 and defines an axis of rotation parallel to a vertical axis of the pixel element 112 (e.g., a “C4 axis” of the pixel element 112). The bearing housing 148: is coupled to the pixel element 112; is configured to carry a vertical load of the brixel unit 110 into the vertical thrust surface of the bearing collar 186; and rotationally couples the brixel unit 110 to the center column 180.
The motor 130 is arranged in the drive window 184 within the center column 180. A rotary encoder (or other angular position sensor) is coupled to the output shaft of the motor 130 (or to the drive pinion 142) and outputs a signal representative of changes in angular position of the output shaft of the motor 130—and therefore representative of changes in angular position of the output shaft of the motor 130. A drive pinion 142: is coupled to the output shaft of the motor 130; is configured to rotate about a rotational axis offset from the cylindrical axis of the center column 180; and defines a set of teeth extending through the drive window 184 to engage teeth in a segment of the internal ring gear 146 of the brixel unit 110.
The local controller 120: receives an actuation routine from the column controller 150; includes local memory configured to store an actuation routine; and is configured to drive the motor 130 according to target angular positions represented in an actuation routine stored in local memory.
In a similar variation, the system 100 includes: a center column 180 including a tube 182 and defining a column of drive windows 184 arranged along the tube 182 at a vertical pixel pitch distance; a set of bearing collars 186, each bearing collar 186 in the set of bearing collars 186 coupled to the center column 180 adjacent a drive window 184, in the column of drive windows 184, and defining a vertical thrust surface; a set of brixel units 110; and a primary controller 160 configured to distribute a set of actuation routines to the set of brixel units 110. In this variation, each brixel unit 110 is located adjacent a drive window 184, in the set of drive windows 184 on the center column 180, and includes: a pixel element 112 including a first face 113 defining a first visual characteristic and a second face 114 opposite the first face 113 and defining a second visual characteristic different from the first visual characteristic; an internal ring gear 146 coupled to the pixel element 112 and defining an axis of rotation of the pixel element 112; and a bearing housing 148 coupled to the pixel element 112, configured to carry a vertical load of the pixel element 112 into a vertical thrust surface of a bearing collar 186, in the set of bearing collars 186, adjacent the drive window 184, and rotationally coupling the pixel element 112 to the center column 180; a motor 130 arranged in the drive window 184; a drive pinion 142 coupled to the output shaft of the motor 130 and extending through the drive window 184 to engage the internal ring gear 146; and a local controller 120 configured to store an actuation routine in local memory at the brixel unit 110 and configured to drive the motor 130 to locate the pixel element 112 over a sequence of angular positions, relative to the center column 180, defined by the actuation routine.
In this variation, the center column 180 can include a tube 182 defining a column of drive windows 184 spaced along the length of the steel tube at a pitch distance equal to a target vertical pitch distance between pixel elements 112 of vertically-adjacent brixel units 110 installed along the center column 180. For example, the center column 180 can include a contiguous steel tube of fixed length defining a fixed number of drive windows 184. In particular, in this example, the center column 180 can include a continuous cylindrical tube 182 relieved to form the column of drive windows 184 along a length of the continuous cylindrical tube 182; and a pixel element 112 of a brixel unit 110 can be configured to rotate about a rotation axis coaxial with the continuous cylindrical tube 182.
Alternatively, the center column 180 can be assembled from a set of center column 180 elements, each defining one drive window 184 (or a small set of drive windows 184). For example, these center column 180 elements can be fastened together, screwed together, or otherwise assembled to form a center column 180 with a target quantity of drive windows 184.
The center column 180 be similarly screwed, fastened, or otherwise assembled onto the base 190, and the column controller 150 can be arranged in the bottom of the center column 180 or in the base 190.
In one implementation, a bearing collar 186 includes a continuous annular ring defining an internal bore of diameter sized for a running fit over the center column 180. The bearing collar 186 can also include a setscrew configured to lock the bearing collar 186 to the center column 180 adjacent a drive window 184.
Furthermore, the top face of the bearing collar 186 defines the thrust surface configured to mate with and vertically support a downward-facing thrust bearing surface defined by the bearing housing 148 in the brixel unit 110. The external cylindrical face of the bearing collar 186 can similarly define a rotational bearing surface sized for a running fit inside the bearing housing 148 and can mate with the bearing housing 148 of the brixel unit 110, thereby locating the brixel unit 110 and enabling the brixel unit 110 to rotate about the center column 180. In particular, the bearing collar 186 can cooperate with the bearing housing 148 of the brixel unit 110 to constrain the brixel unit 110 in five degrees of freedom and to enable the brixel unit 110 to rotate about the center axis of the center column 180.
In another implementation, the bearing collar 186 includes a one-piece or two-piece split collar configured to clamp to the center column 180; and a flanged bearing or bushing can be located over the bearing collar 186 once the bearing collar 186 is clamped to the center column 180 to form the thrust surface and external rotational bearing surface described above.
As described above, the pixel element 112 of a brixel unit 110 can include two clamshell structures assemblable into a cuboid shell. In this implementation, a top face of the pixel element 112 can define an upper opening concentric with a center vertical axis (e.g., the C4 axis) of the cuboid shell and larger than the outer diameter of the center column 180, and the lower face of the pixel element 112 can similarly define a lower opening concentric with the upper opening and the center vertical axis of the cuboid shell and of similar size.
The bearing housing 148 of the brixel unit 110 defines an annular, downward-facing thrust bearing surface and a cylindrical, inward-facing rotational bearing surface. The bearing housing 148 can be arranged inside the cuboid shell—such as proximal the bottom face of the pixel element 112—and can be fastened, adhered, or otherwise assembled onto one or both clamshell structures of the pixel element 112 with the annular thrust bearing surface and the rotational bearing surface concentric with the center vertical axis of the cuboid shell.
The internal ring gear 146 includes a set of inwardly-facing involute gear teeth configured to mate with the drive pinion 142. In one implementation shown in
In the foregoing implementations, the brixel unit 110 can also include: a thrust washer or thrust bearing interposed between the annular, downward-facing thrust bearing surface and the thrust surface of the bearing housing 148; and a needle or ball bearing interposed between the cylindrical, inward-facing rotational bearing surface of the bearing housing 148 and the bearing collar 186. Additionally or alternatively, the brixel unit 110 can include a spring washer interposed between the annular, downward-facing thrust bearing surface and the thrust surface of the bearing housing 148 in order to fill a vertical gap between adjacent surfaces in the bearing housing 148 and the bearing collar 186.
In one variation, the brixel unit 110 includes a second bearing housing 148, such as arranged above the (first) bearing housing 148 described above and configured to rotationally couple the top face of the brixel unit 110 to the center column 180 and thus maintain concentricity of the vertical axis of the pixel element 112 and the center axis of the center column 180. In this variation, the second bearing housing 148 can include a bushing or bearing configured to mate directly with an exterior surface of the center column 180 or with a second bearing collar 186 installed on the center column 180.
In another variation, rather than define discrete thrust and rotation bearing surfaces, the bearing collar 186 supports a tapered bearing (or defines a tapered bushing surface), and the bearing housing 148 includes a tapered bearing race configured to mate with the tapered bearing (or the tapered bushing surface) to support the brixel unit 110 vertically on the center column 180 and to rotationally couple the brixel unit 110 to the center column 180.
As described above, the motor 130 can include a stepper motor 130, a servo motor 130, or a brushed or brushless DC motor 130. Generally, the motor 130 is located in the drive window 184 and is arranged (predominantly, fully) inside of the center column 180.
For example, the motor 130 can be fastened directly to the center column 180 with a set of threaded fasteners passing through the center column 180 adjacent the drive window 184. Alternatively, the motor 130 can be installed in a carriage, and the carriage can be installed in the drive window 184 and fastened to the center column 180. Yet alternatively, the motor 130 can be loosely inserted into the drive window 184 with its output shaft facing downward; and the bearing collar 186 can be slid down the center column 180, over the drive window 184, and over the body of the motor 130 with the bottom face of the bearing collar 186 adjacent and facing the pinion. The bearing collar 186 can then be fastened to both the center column 180 and the body of the motor 130 in order to rigidly couple the motor 130 to the center column 180.
In one implementation, the pinion is mounted directly to the output shaft of the motor 130, and the motor 130 is located in the center column 180 with the rotational axis of its output shaft laterally offset from the center axis of the center column 180 such that a sector of the pinion extends through the drive window 184 to mesh with teeth in a sector of the internal ring gear 146. Thus, actuation of the motor 130 directly rotates the pinion, which then rotates the internal ring gear 146 and the pixel element 112 about the center axis of the center column 180.
In another implementation, the motor 130 is located in the center column 180 with the rotational axis of its output shaft coaxial with the center axis of the center column 180. In this implementation, a sun gear can be mounted to the output shaft of the motor 130, and the pinion (e.g., a planetary gear) can be interposed between the sun gear and the internal ring gear 146 to transfer torque from the motor 130 into the brixel unit 110 to rotate the brixel unit 110. In this implementation, the system 100 can also include multiple pinions—such as a second pinion radially offset 180° from the (first) pinion—configured to transfer torque from the motor 130 into the internal ring gear 146 in order to rotate the brixel unit 110.
Thus, in this implementation, the output shaft of a motor 130, a drive pinion 142, and an internal ring gear 146 of a brixel unit 110 can define a planetary gearbox assembled over and extending through the tube 182 of the center column 180 at a drive window 184 (or “aperture”) in the center column 180.
Furthermore, a local controller 120, such as described above, can be arranged inside the center column 180. For example, the local controller 120 can be mounted to the motor 130 opposite the motor 130's output shaft.
The system 100 can also include a light element 122—such as an LED ring—mounted to the exterior of the center column 180 and configured to illuminate the interior of the pixel element 112 or a space between the pixel element 112 and a pixel element 112 of an adjacent brixel unit 110. In this variation, the light element 122 can be connected to and controlled via the local controller 120.
For example, a pixel element 112 of a brixel unit 110 can include: a first face 113 defining a first optical transparency; and a second face 114 defining a second optical transparency less than the first optical transparency. In this example, the brixel unit 110 can also include a light element 122: coupled to the center column 180 proximal a drive window 184, in the set of drive windows 184; enclosed by a pixel element 112 of the brixel unit 110; and configured to illuminate the interior of the pixel element 112, which includes faces that exhibit different transmission of light output by the light element 122.
Furthermore, the system 100 can include a home sensor and a position indicator, such as described above. For example, the home sensor can include a Hall effect sensor arranged in the bearing collar 186; and the position indicator can include a magnetic element arranged in the bearing housing 148 in the brixel.
As described above, the center column 180 can define a linear array of drive windows 184 offset along the length of the center column 180 at a vertical pitch distance equal to a target offset between adjacent brixel unit 110 pixel elements 112 (e.g., a sum of the height of a pixel element 112 and a target gap between adjacent top and bottom faces of pixel elements 112 in two adjacent brixel units 110).
In one example shown in
A first upper thrust washer and a first spring washer are then lowered from the top of the center column 180 downward to the bearing collar 186, followed by the bearing housing 148. The internal ring gear 146 is then offered up to the bearing housing 148 to enclose the first upper thrust washer, the first spring washer, the first bearing collar 186, and the first lower thrust washer between the internal ring gear 146 and the bearing housing 148; and the internal ring gear 146 is fastened to the bearing housing 148 with a set of threaded fasteners. (A light ring is then slide from the top of the center column 180 downward toward the drive window 184, fastened to the center column 180 above the bearing housing 148, and connected to the local controller 120.)
The foregoing process is then repeated to assemble a second motor 130, a second local controller 120, a second bearing collar 186, a second internal ring gear 146, and a second bearing housing 148 over the second drive window 184 on the center column 180 immediately about the first drive window 184, and a second wiring hardness from the second local controller 120 is connected to a power and data output of the first local controller 120. The process is again repeated for each addition drive window 184 defined by the center column 180 such that these local controllers 120 are connected in series to the column controller 150.
With the motors 130, local controllers 120, bearing collars 186, etc. thus assembled on the center column 180, a pair of pixel element 112 clamshell structures are then fastened to each internal ring gear 146 and/or bearing housing 148 at each drive window 184 on the center column 180 in order to complete assembly of a column of brixel units 110, as shown in
In a similar implementation, a set of tubes defining a series of drive windows is assembled to form a non-linear center column, and brixel units are installed over these drive windows to form a non-linear installation, as shown in
The foregoing process can be repeated to assemble multiple additional columns of brixel units 110. These columns of brixel units 110 can then be installed over a chassis 130, located on a floor or other horizontal surface, suspended from a ceiling or other overhead surface, etc. at a horizontal pitch distance between adjacent center columns 180 equal to a sum of a width of the brixel unit 110 pixel elements 112 and a target horizontal gap between adjacent brixel unit 110 pixel elements 112, as shown in
Brixel units 110 in this installation can then be calibrated and can execute actuation routines as described above.
Thus, in this variation, the system 100 can include multiple column assemblies, including: a first set of brixel units 110 installed over a first center column 180; and a second set of brixel units 110 installed over a second center column 180; etc. The system 100 can also include a base 190 configured to support and locate the first center column 180 and the second center column 180, etc. in parallel vertical orientations with the second center column 180 laterally offset from the first center column 180 by a horizontal pitch distance approximating a sum of: a width of pixel elements 112 in the set of brixel units 110; and a rotation clearance width (e.g., 0.50″ or a function of a thickness) of pixel elements 112 in the set of brixel units 110. Alternatively, adjacent center columns 180 can be fastened together at this horizontal pitch distance, such as to form a freestanding assembly following a linear or serpentine profile.
The primary controller 160 can thus: distribute a set of actuation routines to each set of brixel units 110 arranged on each center column 180; and trigger local controllers 120 in these sets of brixel units 110 to execute their assigned actuation routines via column (or “group”) controllers arranged in each center column 180.
In other variations, a pixel element 112 in a brixel unit 110: can include a light pipe; can define non-linear or non-planar surfaces; and/or can include an electronic display on one or both faces. Pixel elements 112 in a cluster or group of brixel units 110 can also form nesting Voronoi geometries.
Furthermore, a pixel element 112 can define additional faces or “facets,” such as arranged radially about the rotational axis of the pixel element 112 with different colors and/or textures applied to each face. Similarly, a pixel element 112 can include a cylindrical structure with varying colors and/or textures (e.g., a color wheel or a “texture wheel”) applied about the cylindrical face defined by the pixel element 112. In this variation, a local controller 120 in a brixel unit 110 can implement the foregoing methods and techniques to drive the pixel element 112 to an angular position corresponding to a grayscale value (or other value) contained in an actuation routine in order to form a non-binary physical representation of a pixel in an image represented by the installation as a whole.
However, a pixel element 112 can define any other form, geometry, color, texture, or pattern, etc.
The systems and methods described herein can be embodied and/or implemented at least in part as a machine configured to receive a computer-readable medium storing computer-readable instructions. The instructions can be executed by computer-executable components integrated with the application, applet, host, server, network, website, communication service, communication interface, hardware/firmware/software elements of a user computer or mobile device, wristband, smartphone, or any suitable combination thereof. Other systems and methods of the embodiment can be embodied and/or implemented at least in part as a machine configured to receive a computer-readable medium storing computer-readable instructions. The instructions can be executed by computer-executable components integrated by computer-executable components integrated with apparatuses and networks of the type described above. The computer-readable medium can be stored on any suitable computer readable media such as RAMs, ROMs, flash memory, EEPROMs, optical devices (CD or DVD), hard drives, floppy drives, or any suitable device. The computer-executable component can be a processor but any suitable dedicated hardware device can (alternatively or additionally) execute the instructions.
As a person skilled in the art will recognize from the previous detailed description and from the figures and claims, modifications and changes can be made to the embodiments of the invention without departing from the scope of this invention as defined in the following claims.
This Application claims the benefit of U.S. Provisional Application No. 62/913,084, filed on 9 Oct. 2019, which is incorporated in its entirety by this reference. This Application is related to U.S. patent application Ser. No. 15/824,244, filed on 28 Nov. 2017, which is incorporated in its entirety by this reference.
Number | Date | Country | |
---|---|---|---|
62913084 | Oct 2019 | US |