diff options
-rw-r--r-- | Cargo.lock | 40 | ||||
-rw-r--r-- | Cargo.toml | 3 | ||||
-rw-r--r-- | NOTES.md | 22 | ||||
-rw-r--r-- | src/main.rs | 81 |
4 files changed, 138 insertions, 8 deletions
diff --git a/Cargo.lock b/Cargo.lock index 52e8b18..791e29d 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -33,6 +33,18 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" [[package]] +name = "bitvec" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1bc2832c24239b0141d5674bb9174f9d68a8b5b3f2753311927c172ca46f7e9c" +dependencies = [ + "funty", + "radium", + "tap", + "wyz", +] + +[[package]] name = "bytemuck" version = "1.13.1" source = "registry+https://github.com/rust-lang/crates.io-index" @@ -150,6 +162,12 @@ dependencies = [ ] [[package]] +name = "funty" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e6d5a32815ae3f33302d95fdcb2ce17862f8c65363dcfd29360480ba1001fc9c" + +[[package]] name = "gif" version = "0.11.4" source = "registry+https://github.com/rust-lang/crates.io-index" @@ -200,6 +218,7 @@ dependencies = [ name = "l16-lri" version = "0.1.0" dependencies = [ + "bitvec", "lri-rs", "png 0.17.8", ] @@ -364,6 +383,12 @@ dependencies = [ ] [[package]] +name = "radium" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc33ff2d4973d518d823d61aa239014831e521c75da58e3df4840d3f47749d09" + +[[package]] name = "rayon" version = "1.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" @@ -410,6 +435,12 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "238abfbb77c1915110ad968465608b68e869e0772622c9656714e73e5a1a522f" [[package]] +name = "tap" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "55937e1799185b12863d447f42597ed69d9928686b8d88a1df17376a097d8369" + +[[package]] name = "tiff" version = "0.6.1" source = "registry+https://github.com/rust-lang/crates.io-index" @@ -425,3 +456,12 @@ name = "weezl" version = "0.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9193164d4de03a926d909d3bc7c30543cecb35400c02114792c2cae20d5e2dbb" + +[[package]] +name = "wyz" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "05f360fc0b24296329c78fda852a1e9ae82de9cf7b27dae4b7f62f118f77b9ed" +dependencies = [ + "tap", +] diff --git a/Cargo.toml b/Cargo.toml index 4f8203a..050859b 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,4 +7,5 @@ edition = "2021" [dependencies] png = "0.17.8" -lri-rs = { path = "../lri-rs" } \ No newline at end of file +lri-rs = { path = "../lri-rs" } +bitvec = "1.0.1" diff --git a/NOTES.md b/NOTES.md index 0fde302..c57e4a6 100644 --- a/NOTES.md +++ b/NOTES.md @@ -82,3 +82,25 @@ For `wall.lri` and in the 2nd bit of sensor data *(block index 3; the third bloc was able to get a debayered, but not colour correct, image reading it as RAW_10BIT_PACKED in the BGGR arrangement. lak was able to get a usuable image with a width of 2080 in source explorer, but says "also it's croped in to 4160 4208". noteably 4160 is 2 * 2080, so I don't know? curious. + +# Data Data Data Data Data Data +## 2023-06-08 22:41 CST +I now know what lak was talking about. lak was debayering by just cramming the 2x2 BGGR area into one pixel, therefore loosing half +the width. from laks experience the height was unaffected? but it works! so the width *is* 4160. Which apparently is cropped ar1135. +I was able to confirm that by finding the bloody sensor data! The `sensor_data.proto` anyway. + +### What We Know So Far +- File made up of blocks of data. Each block starts with a header that, in the decompiled java code *(and mine, currently)*, +is called `LightHeader`. I will call this the **DataHeader** from here on out as suggested by helloavo. It is described below. +- If the header length of the DataHeader is not 32, we interpret this as sensor data. Following the header starts the raw bayer data. It's likely to be packed bits. Either 10, 12, or 14. *(as per `camera_module.proto`)*. The example file we've been using is 10-but packed. It's also 4160 by 3120 which corresponds to a cropped image from the ar1335 sensor. + +#### DataHeader *(A.K.A. LightHeader from the Java Code)* +The header is 32 bytes long. and goes as follows: +| bytes | meaning | +| ----- | ------- | +| 4 | Magic Number: "LELR" | +| 8 | Combined Length (total length including this header) | +| 8 | header length (32) **OR** message length | +| 4 | message length **OR** unknown | +| 1 | message type. 0 for `LightHeader` *(as described in lightheader.proto)* or 1 for `view_preferences.proto` | +| 7 | reserved | \ No newline at end of file diff --git a/src/main.rs b/src/main.rs index 710d3c6..8503a98 100644 --- a/src/main.rs +++ b/src/main.rs @@ -17,6 +17,7 @@ fn main() { let look_length = magic_id.len() + magic_id_skip + reserved.len(); let mut heads = vec![]; + let mut skeptical_heads = vec![]; println!("\nLooking for LELR"); for idx in 0..data.len() - look_length { @@ -34,6 +35,12 @@ fn main() { heads.push(HeaderAndOffset { header, start, end }); } else { println!("No reserve match :("); + + let header = LightHeader::new(&data[idx..]); + let start = idx; + let end = start + header.combined_length as usize; + + skeptical_heads.push(HeaderAndOffset { header, start, end }); } } } @@ -84,6 +91,9 @@ fn main() { println!("\nDumping header info.."); heads.iter().for_each(|h| h.header.nice_info()); + println!("\nDumping skeptical header info.."); + skeptical_heads.iter().for_each(|h| h.header.bin_info()); + println!("\nWriting large ones to disk and collecting the smalls!"); let mut small: Vec<u8> = vec![]; for (idx, head) in heads.iter().enumerate() { @@ -96,6 +106,7 @@ fn main() { "Wrote {:.2}MB to disk as {name}", head.header.combined_length as f32 / (1024.0 * 1024.0) ); + head.header.print_info(); } else { small.extend(&data[head.start..head.end]); } @@ -131,14 +142,57 @@ fn main() { println!("\nDumping the Message of idx 1"); dump_body(&heads[4], &data, "msg4.lri_part"); - let msg = body(&heads[4], &data); - let proto = match lri_rs::proto::lightheader::LightHeader::parse_from_bytes(msg) { - Ok(data) => { - println!("Success?!?!?!"); - println!("{data:?}"); + let mut modules = vec![]; + let mut sensor_data = vec![]; + + for (idx, head) in heads.iter().enumerate() { + print!("Head {idx} - "); + let msg = body(head, &data); + + match (head.header.header_length == 32, head.header.kind) { + (true, 1) => { + match lri_rs::proto::view_preferences::ViewPreferences::parse_from_bytes(msg) { + Ok(_) => println!("View Preferences: Parsed"), + Err(e) => println!("View Preferences, failed: {e}"), + } + } + (true, 0) => match lri_rs::proto::lightheader::LightHeader::parse_from_bytes(msg) { + Ok(data) => { + let mods = &data.modules; + let datas = &data.sensor_data; + + print!( + " [claimed: {} | actual: {}] - ", + head.header.message_length, + data.compute_size() + ); + + println!( + "LightHeader! Modules: {} - Datas: {} \\ ModCal: {}", + mods.len(), + datas.len(), + data.module_calibration.len() + ); + modules.extend_from_slice(&mods); + sensor_data.extend_from_slice(&datas); + + if false && data.module_calibration.len() > 0 { + for modc in data.module_calibration { + print!(" - {:?}", modc.get_camera_id()); + } + println!(""); + } + } + Err(e) => println!("LightHeader, failed: {e}"), + }, + (true, _) => { + println!("Unknown header kind and header_length is 32, skipping..."); + } + (false, _) => { + println!("SensorData! Skipping for now..."); + } } - Err(e) => println!("Failed {e}"), - }; + } } fn dump_body(head: &HeaderAndOffset, data: &[u8], path: &str) { @@ -273,4 +327,17 @@ impl LightHeader { *header_length as f32 / 1024.0 ); } + + pub fn bin_info(&self) { + let LightHeader { + magic_number, + combined_length, + header_length, + message_length, + kind, + reserved, + } = self; + + println!("{magic_number} {:b}", combined_length); + } } |