This application is based upon and claims the benefit of priority from Japanese Patent Application No. 2019-168061, filed on Sep. 17, 2019; the entire contents of which are incorporated herein by reference.
Embodiments described herein relate generally to an estimation device, an estimation method, and a computer program product.
In autonomous driving and driver assistance, estimating the self-location of a vehicle in a map is expected to contribute to sophisticated determination using information linked to the map and to highly accurate motion estimation of the vehicle. In the field of robots, the self-location in a map can be used for tracking a preset movement path. Conventionally, there is a known technique that collates a landmark observed by a sensor mounted on a moving object with a landmark at a known position registered in a map database in advance and estimates the self-location in a map of the moving object as position of the sensor with less inconsistency in observation of landmarks.
Unfortunately, it is difficult for the conventional technique to improve the accuracy in estimation processing in a situation in which erroneous correspondence may occur in the collation of landmarks.
An estimation device includes a storage unit configured to store therein first position information, the first position information indicating at least one of a position of and a pose of a first landmark in a map; and one or more hardware processors configured to function as an acquisition unit, and an estimation unit. The acquisition unit is configured to acquire second position information, the second position information indicating at least one of a position of and a pose of a second landmark in a neighborhood of a moving object. The estimation unit is configured to estimate third position information and correspondence (i.e., association) between the first landmark and the second landmark, based on the first position information and the second position information, where the third position information is indicative of at least one of a position of and a pose of the moving object in the map. The estimation unit estimates the third position information and the matching such that an observation error of the second landmark in at least one of the position and the pose specified by the third position information and a matching error indicating an error in the correspondence are reduced. The estimation device, the estimation method, and the computer program according to embodiments will be described below with reference to the accompanying drawings.
An estimation device in a first embodiment is mounted on, for example, a moving object.
The moving object 10 includes an estimation device 20, an output unit 10A, a camera 10B, a sensor 10C, a power control unit 10G, and a power unit 10H.
The moving object 10 may be any moving object. Examples of the moving object 10 include a vehicle, a carriage, and a movable robot. Examples of the vehicle include a motorcycle, an automobile, and a bicycle. The moving object 10 may be, for example, a moving object running through a human driving operation or may be a moving object capable of automatically driving (autonomous driving) without a human driving operation.
The estimation device 20 is implemented, for example, by dedicated or general-purpose computer hardware. The estimation device 20 estimates the location indicating at least one of the position and the pose of the moving object 10. Specifically, the estimation device 20 checks the correspondence between a landmark (second landmark) observed by the camera 10B and a landmark (first landmark) registered in map data simultaneously when estimating the location of the moving object 10 in time series. This configuration enables robust self-location estimation with ambiguous correspondence of landmarks.
The estimation device 20 is not necessarily mounted on the moving object 10. The estimation device 20 may be mounted on a stationary object. The stationary object is, for example, an object unable to move, such as an object fixed to the ground. Examples of the stationary object fixed to the ground include a guard rail, a pole, a parked vehicle, and a road sign. For example, the stationary object is an object stationary relative to the ground. The estimation device 20 may be installed in a cloud server that executes processing on a cloud system.
The power unit 10H is a drive device mounted on the moving object 10. Examples of the power unit 10H include an engine, a motor, and a wheel.
The power control unit 10G controls the power unit 10H. The power unit 10H is driven under the control of the power control unit 10G.
The output unit 10A outputs information. In the first embodiment, the output unit 10A outputs estimation result information indicating the estimation result of motion of the camera 10B estimated by the estimation device 20.
The output unit 10A includes, for example, a communication function of transmitting estimation result information, a display function of displaying estimation result information, and a sound output function of outputting sound indicating estimation result information. The output unit 10A includes, for example, at least one of a communication unit 10D, a display 10E, and a speaker 10F. In the first embodiment, the output unit 10A includes the communication unit 10D, the display 10E, and the speaker 10F, by way of example.
The communication unit 10D transmits estimation result information to another device. For example, the communication unit 10D transmits estimation result information to another device through a communication line. The display 10E displays information on the estimation result. Examples of the display 10E include a liquid crystal display (LCD), a projector, and a light. The speaker 10F outputs sound indicating information on the estimation result.
Examples of the camera 10B include a monocular camera, a stereo camera, a fisheye camera, and an infrared camera. Any number of cameras 10B may be provided. The image taken may be a color image composed of three channels R, G, and B or may be a monochrome image of one channel represented by gray scales. The camera 10B captures time-series images of the neighborhood of the moving object 10. The camera 10B captures time-series images, for example, by capturing images of the neighborhood of the moving object 10 in time series. The neighborhood of the moving object 10 is, for example, a region in a predetermined range from the moving object 10. This range is, for example, a range that can be imaged by the camera 10B.
In the first embodiment, the camera 10B is installed such that the front of the moving object 10 is included as the imaging direction. That is, in the first embodiment, the camera 10B captures images of the front of the moving object 10 in time series.
The sensor 10C is a sensor that measures measurement information. Examples of the measurement information include the speed of the moving object 10 and the steering angle of the steering wheel of the moving object 10. Examples of the sensor 10C include an inertial measurement unit (IMU), a speed sensor, and a steering angle sensor. The IMU measures measurement information including three-axis acceleration and three-axis angular velocity of the moving object 10. The speed sensor measures the speed from the amount of rotation of a wheel. The steering angle sensor measures the steering angle of the steering wheel of the moving object 10. For example, the sensor 10C is a depth distance sensor that measures the distance to an object, such as a LiDAR (light detection and ranging, or laser imaging detection and ranging).
An example of the functional configuration of the moving object 10 in the first embodiment will now be described in detail.
The moving object 10 includes an estimation device 20, an output unit 10A, a camera 10B, a sensor 10C, a power control unit 10G, and a power unit 10H. The estimation device 20 includes a processing unit 20A and a storage unit 20B. The output unit 10A includes a communication unit 10D, a display 10E, and a speaker 10F.
The processing unit 20A, the storage unit 20B, the output unit 10A, the camera 10B, the sensor 10C, and the power control unit 10G are connected through a bus 10I. The power unit 10H is connected to the power control unit 10G.
The output unit 10A (the communication unit 10D, the display 10E, and the speaker 10F), the camera 10B, the sensor 10C, the power control unit 10G, and the storage unit 20B may be connected through a network. The communication system of the network used for the connection may be wired or may be wireless. The network used for the connection may be implemented by a combination of a wired system and a wireless system.
Examples of the storage unit 20B include a semiconductor memory device, a hard disk, and an optical disc. Examples of the semiconductor memory device include a random access memory (RAM) and a flash memory. The storage unit 20B may be a storage device provided on the outside of the estimation device 20. The storage unit 20B may be a storage medium. Specifically, the storage medium may store or temporarily store a computer program and a variety of information downloaded through a local area network (LAN) or the Internet. The storage unit 20B may be configured with a plurality of storage media.
The storage unit 20B stores, for example, first position information indicating at least one of the position of and the pose of a first landmark in a map. The first position information is stored, for example, in a map database indicating a position in map. The position of the first landmark may be represented by a point in a map or may be represented by any form such as a set of points, a rectangle, and a known shape model.
The first landmark 101 is preferably a target whose position can be registered in a coordinate system of a map database and that is present at the same position without moving when observed by the camera 10B and the sensor 10C. The first landmark 101 is preferably a target fixed to a road, for example, a road structure such as a road signal, a traffic sign, a road marking, and a pole, or a signboard. A target that is essentially movable can be used as the first landmark 101 if it is assured in advance that the target is not moving between the creation of a map database and the observation or if it can be verified that the target is not moving. A specific marker that can be installed by the user in the environment may be used as the first landmark 101.
The first position information may be defined by an absolute coordinate system with latitude and longitude or may be defined by any coordinate system in which a specific position serves as a reference of coordinates.
Returning to
The acquisition unit 21 acquires second position information indicating at least one of the position and the pose of a second landmark around the moving object 10. The acquisition unit 21 acquires second position information, for example, from an image captured by the camera 10B. For example, the acquisition unit 21 acquires second position information from data acquired by the sensor 10C.
The estimation unit 22 accepts the second position information from the acquisition unit 21 and reads the first position information from the storage unit 20B. The estimation unit 22 then estimates third position information indicating at least one of the position in a map and the pose of the moving object 10 and correspondence between the first landmark and the second landmark, based on the first position information and the second position information. The detail of the processing by the estimation unit 22 will be described later.
For example, the processing unit 20A may be implemented by allowing a processor such as a central processing unit (CPU) to execute a computer program, that is, by software. For example, the processing unit 20A may be implemented by one or more processors such as a dedicated integrated circuit (IC), that is, by hardware. For example, the processing unit 20A may be implemented by software and hardware in combination.
The term “processor” used in the present embodiment includes CPU, graphical processing unit (GPU), application specific integrated circuit (ASIC), and programmable logic device. Examples of the programmable logic device include simple programmable logic device (SPLD), complex programmable logic device (CPLD), and field programmable gate array (FPGA).
The processor reads and executes a computer program stored in the storage unit 20B to implement the processing unit 20A. A computer program may be directly built in a circuit of the processor, rather than storing a computer program in the storage unit 20B. In this case, the processor reads and executes the computer program built in the circuit to implement the processing unit 20A.
Some of the functions of the moving object 10 illustrated in
The detail of the operation of the estimation unit 22 will now be described.
First, the camera 10B mounted on the moving object 10 observes the second landmarks 102a and 102b, at the observation positions 201a and 201b. The second position information of the second landmarks 102a and 102b is represented by a local coordinate system (image coordinates) defined in the moving object 10. Hereinafter the second landmarks 102a and 102b are simply referred to as second landmark 102 when they are not distinguished from each other.
Here, the sensor may be any sensor that can observe a target retained as the first landmark 101 in the map database, as the second landmark 102. As described above, an image may be acquired using the camera 10B, or the sensor 10C that measures the distance to an object, such as LiDAR, may be used.
Any method may be used to detect the second landmark 102 from sensor data. When the sensor data is an image, for example, a feature point detecting method or specific object recognition by a convolutional neural network (CNN) may be used.
The positional relation of the second landmark 102 may be represented, for example, by a pixel position in an image. For example, the positional relation of the second landmark 102 may be represented by the observation direction of the second landmark 102 relative to the position and pose of the moving object 10, like the direction and the distance in a depth distance sensor.
In the first embodiment, the second landmark 102 is observed with a point of coordinates defined in sensor data. However, the second landmark 102 may be observed with a set of points, a rectangle, a known shape model, and the like. The second landmark 102 may be represented in any form that can be collated with the first position information as long as an observation error Eobs and a matching error Ematch described later can be calculated.
The estimation unit 22 estimates third position information indicating at least one of the position in map and the pose of the moving object 10 and correspondence between the first landmark 101 and the second landmark 102, based on the first position information of the first landmark 101 and the second position information of the second landmark 102.
Specifically, for example, the estimation unit 22 reduces the sum E of an observation error Eobs from observation information V of the second landmark 102 using the position pose P in map of the moving object 10 and a matching error Ematch from map data M including the first landmark 101, for a three-dimensional point L indicating a position in map of the second landmark 102, using Equation (1) below.
E(P,L,W|M,V)=Eobs(P,L|V)+Ematch(L,W|M) (1)
Here, the observation information V is second position information represented, for example, by the coordinates of an image observed by the camera 10B. W is a variable indicating correspondence between the first landmark 101 and the second landmark 102.
The observation error Eobs represents the difference between observation information v when the second landmark 102 is observed again based on the estimated position in map and observation information V actually observed by the camera 10B, in the estimated position pose of the moving object 10. For example, the estimation unit 22 evaluates the observation error Eobs by a re-projection error which is an error between the projection position when the three-dimensional point L in map of the second landmark 102 is projected onto a two-dimensional image plane using a camera model and the detected position of the second landmark 102 detected from an image (second position information), and reduces (optimizes) the re-projection error.
The observation error Eobs is not limited to the re-projection error, as long as the error between the observation information v, calculated based on the estimated position pose of the moving object 10 and the position of the second landmark 102, and the actual observation information V can be evaluated. For example, the observation error Eobs may be evaluated by the angle formed by vectors indicating the direction of the second landmark 102 or may be evaluated by the degree of agreement based on the degree of overlapping of the projected shape model.
The matching error Ematch indicates which first landmark 101 is matched with each second landmark 102 and the difference from the matched first landmark 101. For example, the estimation unit 22 sets the correspondence W as a weight matrix represented by the weight of correspondence to the first landmark 101 included in the map database, for each of the second landmarks.
Here, the position used for evaluating the distance is any position calculated from the position registered in the map database and may be a three-dimensional point, a two-dimensional point projected on a certain plane, or a latitude and longitude representation. The position for obtaining an error is calculated by the linear sum of the position of the first landmark 101. However, any position may be used as long as the position of the first landmark 101 matched with the second landmark 102 can be referred to. For example, a certain first landmark 101 may be weighted by Softmax, or the first landmark 101 may be weighted using a nonlinear function
In the first embodiment, depending on the weight of matching, a second landmark 102 may be matched with a plurality of first landmarks 101. However, a constraint may be imposed such that one first landmark 101 is matched with one second landmark 102. More specifically, the estimation unit 22 estimates the correspondence by setting a one-to-one correspondence between the second landmark 102 and the first landmark 101.
Although the distance between two positions is used as the error, the difference between shapes may be used when shape models are available, or an error represented in any form may be used as long as the difference between the first landmark 101 and the second landmark 102 matched with each other can be evaluated.
Although a mode in which the variable of correspondence W is represented as a weight matrix has been illustrated, the variable of correspondence W may be in any form other than a weight matrix as long as the correspondence between the first landmark 101 and the second landmark 102 can be represented. For example, a pair of the first landmark 101 and the second landmark 102 matched with each other may be retained, where overlapping is permitted. For example, a method such as the Levenberg-Marquardt method may be used as the method of optimizing the error.
In the description of
The method of estimating a three-dimensional position of the second landmark 102 using measurement at a plurality of places by one camera 10B has been described. However, a plurality of cameras 10B may be mounted on the moving object 10. The depth may be directly estimated from an image captured by one camera 10B, or the depth may be measured by the sensor 10C such as a depth distance sensor. The estimation unit 22 may use a method of obtaining the observation error Eobs using observation information V including the depth. In this case, at least one observation position 201 is necessary.
Next, the estimation unit 22 estimates the third position information and the matching between the first landmark 101 and the second landmark 102 by reducing the observation error Eobs and the matching error Ematch according to Equation (1) above (step S4). Specifically, the estimation unit 22 estimates the third position information and the matching between the first landmark 101 and the second landmark 102 such that the observation error Eobs of the second landmark 102 in at least one of position or pose specified by the third position information and the matching error Ematch are reduced.
The position in map of the moving object 10 obtained by the process in the flowchart in
As described above, in the estimation device 20 in the first embodiment, the storage unit 20B stores first position information indicating at least one of the position in map and the pose of the first landmark 101. The acquisition unit 21 acquires second position information indicating at least one of the position and the pose of the second landmark 102 around the moving object 10. The estimation unit 22 estimates third position information indicating at least one of the position in map and the pose of the moving object 10 and the correspondence between the first landmark 101 and the second landmark 102, based on the first position information and the second position information. The estimation unit 22 estimates the third position information and the correspondence such that the observation error Eobs of the second landmark 102 in at least one of position or pose specified by the third position information and the matching error Ematch indicating an error in the correspondence are reduced.
In the estimation device 20 in the first embodiment with this configuration, the accuracy in the estimation processing can be improved even in a situation in which erroneous and ambiguous correspondence may occur in the collation between a landmark in map data (first landmark 101) and the observed landmark (second landmark 102). Specifically, the estimation unit 22 reduces (optimizes) the observation error Eobs using the estimated position pose of the moving object 10 and the matching error Ematch from the matched first landmark 101, for the position in map of the second landmark 102. In this configuration, the map data is matched with the observation data, whereby the correspondence between the landmark in map data (first landmark 101) and the observed landmark (second landmark 102) (collation between landmarks) can be estimated simultaneously when the location in map of the moving object 10 is estimated. That is, it is not necessary to collate the landmarks definitely in advance before the process of estimating the location in map of the moving object 10. The estimation device 20 in the first embodiment can discard inconsistent correspondence based on the observation of the second landmark 102 by the camera 10B and the sensor 10C, and the positional relation between the observed second landmark 102 and the first landmark 101 in map data and, therefore, enables robust self-location estimation even when ambiguous correspondence of landmarks tends to occur by single collation.
A second embodiment will now be described. In a description of the second embodiment, the same description as the first embodiment is omitted, and the points different from the first embodiment will be described.
The moving object 10 includes an estimation device 20-2, an output unit 10A, a camera 10B, a sensor 10C, a power control unit 10G, and a power unit 10H. The estimation device 20-2 includes a processing unit 20A and a storage unit 20B.
The processing unit 20A includes an acquisition unit 21, an estimation unit 22, and a limitation unit 23. In the second embodiment, the limitation unit 23 is added.
The limitation unit 23 limits the first landmark 101 to be matched, for each second landmark 102. The limitation unit 23 limits the first landmark 101 to be matched, for example, based on at least one of the position, pose, shape, type, and state of the second landmark 102.
The estimation unit 22 estimates the correspondence between the first landmark 101 limited by the limitation unit 23 and the second landmark 102.
The example in
The example in
The example in
In the example above, the map database is limited using the kind of first landmark 101. However, any information other than kind may be used for limitation as long as the information is registered in the map database. For example, the approximate position of the second landmark 102 may be used, or the first landmark 101 from which distance to the second landmark 102 is longer than a predetermined distance may be deleted from the map database. For example, the limitation unit 23 may use information of installation such as the orientation of a plane or the height from the road surface or may use a temporal change in state, such as flashing on and off, for limitation. For example, when the shape of the first landmark 101 is available, the limitation unit 23 may use the closeness to the shape as a reference, or when some parts of the second landmark 102 can be observed, the limitation unit 23 may use whether the parts are included as a reference. For example, the limitation unit 23 may use the color or the texture of the first landmark 101 or may put limitations using a character on the first landmark 101.
Although a mode in which a part of the map database is extracted for each second landmark 102 has been described so far, a plurality of map databases may be allocated to one second landmark 102. In this case, the location and pose estimated individually for each map database may be combined in the subsequent process, or the estimation unit 22 may make an estimation while switching the map databases as appropriate.
For example, the storage unit 20B may store a plurality of pieces of map data including first position information. In this case, the limitation unit 23 limits the first landmark 101 to be matched, for each map data. The estimation unit 22 then may estimate the correspondence between the first landmark 101 limited by the limitation unit 23 and the second landmark 102, and the third position information, for each map data.
The limitation unit 23 limits the first landmark 101 to be matched among the first landmarks 101 associated with the first position information read by the process at step S13, based on at least one of the position, pose, shape, and state of the second landmark 102 (step S14).
Next, the estimation unit 22 estimates the above-noted third position information and the matching between the first landmark 101 limited by the process at step S14 and the second landmark 102 (step S15).
As described above, according to the second embodiment, unlike the first embodiment, the position pose of the moving object 10 and the matching between the first landmark 101 and the second landmark 102 can be estimated using a part of the map database limited for each second landmark 102. This configuration can eliminate the first landmark 101 that is obviously not to be matched in advance and therefore enables robust self-location estimation even when erroneous matching tends to occur.
A third embodiment will now be described. In a description of the third embodiment, the same description as the first embodiment is omitted, and the points different from the first embodiment will be described.
The functional configuration of the moving object 10 in the third embodiment is similar to the first embodiment (see
The acquisition unit 21 in the third embodiment further acquires relative motion information indicating at least one of sequential position and pose of the moving object 10. The relative motion information indicates, for example, the position pose including rotation of the moving object 10.
The relative motion information may be estimated using the observation information V, for example, using Structure from Motion based on feature points detected from time-series camera images, or may be acquired using the sensor 10C different from the camera 10B as in wheel odometry.
The estimation unit 22 estimates the third position information and the matching such that the above-noted observation error Eobs, the above-noted matching error Ematch, and a relative motion error indicating an error between at least one of relative position and pose of the moving object 10 specified by the above-noted third position information in time-series and at least one of relative position and pose included in the relative motion information are reduced.
Specifically, the estimation unit 22 applies a constraint such that the relative motion error between the relative position of the moving object 10 estimated from the third position information in time series and the relative position acquired by the acquisition unit 21 is reduced, while reducing the observation error Eobs and the matching error Ematch similarly to the first embodiment. In the first embodiment, a constrain is indirectly applied when the same second landmark 102 is observed at a plurality of observation positions 201, while in the third embodiment, a constraint is directly applied between the observation positions 201 from which the relative motion information is acquired. In the third embodiment, time-series motion is used as a constraint in a range with no or few second landmarks 102, whereby more stable and smooth position estimation can be realized. With this configuration, even when the correspondence is not uniquely determined, the constraint of the time-series movement of the moving object 10 is explicitly applied, so that the effect of erroneous matching between the second landmark 102 and the first landmark 101 can be reduced.
The relative motion information acquired by the acquisition unit 21 and the coordinate system of the map database are not necessarily defined on the same scale. More specifically, the scale of the coordinate system of the map database may differ from the scale of the coordinate system of the relative motion information.
For example, the map database is on the scale of real space, whereas the relative position pose included in the relative motion information may be defined in a space in which the distance between initial two frames is 1. In this case, the estimation unit 22 estimates (calculates) a scale change in two coordinate systems and reduces the relative position difference after changing one of the relative positions to the scale of the other relative position.
For example, the estimation unit 22 changes the scale of the relative motion information to the scale of the map database and thereafter calculates the relative motion error. With this configuration, even when the acquisition unit 21 acquires the relative motion information on the scale different from the scale of the map database, a constraint on the scale in the map database can be obtained. Here, the scale may be estimated using one scale in the entire scene, or the scale may be estimated for some or one observation position 201. For example, the estimation unit 22 may calculate the scale in calculating the relative motion error, for at least one of the position and the pose of the moving object 10 at each time.
Although a mode in which the estimation device 20 in the third embodiment acquires the third position information and the relative motion information in time series has been described so far, the data used does not necessarily have to be time-series as long as the relative positional relation can be acquired. For example, data of a plurality of cameras 10B and sensors 10C with the relative pose calibrated in advance may be used, or sensor data observed on a plurality of movable bodies 10 may be used.
The acquisition unit 21 acquires the relative motion information of the moving object 10 (step S33).
Next, the estimation unit 22 reads the first position information of the first landmark 101 from the storage unit 20B (step S34).
Next, the estimation unit 22 estimates the third position information and the matching between the first landmark 101 and the second landmark 102 such that the observation error Eobs, the matching error Ematch, and the relative motion error are reduced (step S35).
As described above, in the estimation device 20 in the third embodiment, unlike the first embodiment, the relative positional relation of the observation position 201 of the moving object 10 is used by the estimation unit 22 as a direct constraint. This configuration can increase constraints on the matching of landmarks that can be observed without inconsistency and therefore enables robust self-location estimation even when erroneous matching tends to occur.
Lastly, an example of the hardware configuration of the estimation device 20 in the first to third embodiments is described.
The display device 304, the input device 305, and the communication device 306 are not necessarily included. For example, when the estimation device 20 is connected to another device, the display function, the input function, and the communication function of the other device may be used.
The control device 301 executes a computer program loaded from the auxiliary storage device 303 to the main storage device 302. The control device 301 is, for example, one or more processors such as CPU. The main storage device 302 is a memory such as read only memory (ROM) and RAM. Examples of the auxiliary storage device 303 include a memory card and a hard disk drive (HDD).
The display device 304 displays information. The display device 304 is, for example, a liquid crystal display. The input device 305 accepts input of information. The input device 305 is, for example, a hardware key. The display device 304 and the input device 305 may be a liquid crystal touch panel serving as the display function and the input function. The communication device 306 communicates with other devices.
The computer program executed in the estimation device 20 is stored in a computer-readable recording medium such as a CD-ROM, a memory card, a CD-R, and a digital versatile disc (DVD) in an installable or executable file format and provided as a computer program product.
The computer program executed in the estimation device 20 may be stored on a computer connected to a network such as the Internet and downloaded via the network. The computer program executed by the estimation device 20 may be provided via a network such as the Internet, without downloading.
The computer program executed in the estimation device 20 may be embedded in, for example, a ROM in advance.
The computer program executed in the estimation device 20 has a module configuration including functions that can be implemented by a computer program, of the functions of the estimation device 20.
The functions implemented by a computer program may be loaded to the main storage device 302 by the control device 301 reading and executing the computer program from a storage medium such as the auxiliary storage device 303. That is, the functions implemented by a computer program are generated on the main storage device 302.
Some of the functions of the estimation device 20 may be implemented by hardware such as IC. The IC is, for example, a processor that executes dedicated processing.
When the functions are implemented using a plurality of processors, each processor may implement one of the functions or may implement two or more of the functions.
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel embodiments described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the embodiments described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Number | Date | Country | Kind |
---|---|---|---|
2019-168061 | Sep 2019 | JP | national |