|  04-28-2012, 05:20 AM | #1 | 
| Carpe diem, c'est la vie.            Posts: 6,433 Karma: 10773670 Join Date: Nov 2011 Location: Multiverse 6627A Device: K1 to PW3 |  newtrix - geekmaster's new tricks 
			
			Eink controller documents were studied. Code was written to take advantage of Samsung Broadsheet eink controller for K3 and older kindles (using einkfb device driver) and Freescale SoC-integrated eink controller (using mxcfb device driver), plus the funky hybrid K4 booted from main, with its mxcfb hardware emulation layer using the K3 einkfb device driver. K4 diags is also supported (and I STRONGLY recommend you watch this demo from there to see better performance, but main is not too shabby either). The new code contains a multi-stage demonstration showing what can be done using new interface methods. All eink updates use ioctl() calls for all kindle models in all modes. New dithering code was written that is MUCH simpler and MUCH faster, and supports full 256-color 8-bit mode (which requires dithering despite the fact that the Freescale hardware has unused dithering support). The demo shows WHAT you can do. The source code shows you HOW to do it. The second stage of the demo is very hardware dependent on speed and what effects you see. It is rather slow on the DX, but it gets interesting near the end, and it is followed by MUCH more interesting demo stages. Be sure to watch this multi-stage demo all the way to the end. There is a special bonus that *I* think is worth the wait. We are just barely scratching the surface on capabilities here. There is some VERY interesting eink controller hardware here, mostly going unused. Look for GREAT things in the future. Now, time for the show! Teh Codez: Spoiler: 
 NOTE: To compile the source code, you must copy the eink header files from the gpl source code to your compiler include/linux folder (as seen in the source code #include statements). If using TCC, then copy the header files into /mnt/us/tcc/include/linux/. I plan to include these header files in the next release of the tcc compiler package. And by the way, I hand-optimized the dither routines to work better when compiled with TCC. The demos are no longer 5 times faster when compiled with a cross-tool. But I had to deal with a gcc compiler optimization bug that required that I use a couple of extra temporary variables to prevent bad code generation. NOT fun chasing that one down! I hope to see interesting things from you people, using this code that required significant study and experimentation to perfect. Good luck, and let's not see my efforts wasted. Do good stuff with this. UPDATE: I just noticed an obsolete comment in the dither code. Ignore the "broken code" warning. That was fixed by adding temporary vars (the compiler optimization bug). Weird stuff happens when you OR complex logic terms together that NO amount of parantheses can fix.) All better now. [I removed the comment from the code above, but it is still in the download file.]   Last edited by geekmaster; 04-28-2012 at 05:56 AM. | 
|   |   | 
|  04-28-2012, 05:32 AM | #2 | 
| Carpe diem, c'est la vie.            Posts: 6,433 Karma: 10773670 Join Date: Nov 2011 Location: Multiverse 6627A Device: K1 to PW3 | 
			
			I need feedback. Please leave some. Come on! 88 page views and ZERO feedback? What chance do I have that people will actually CREATE new stuff, stimulated by and using my code that I worked so hard on, when they cannot even create simple feedback?  Should I even BOTHER to invest more of my time and effort into creating a USEFUL code base that I give to you out of simple love of the art of technology? I am tempted to move on to iPad 3 development and leave all 9 of my kindles behind me (in the dust, so to speak). Is that what you want, when I have SO MUCH working (but unfinished) proof-of-concept code in many different aspects of kindle development (custom kernels, development and end-user tools, graphics and animation, input device sensor fusion, and so much more)? I was even working on a video game... People do not seem all that excited here -- perhaps I should move on to a "bigger pond" where I can make a bigger "splash"... In MY opinion, the BEST part of the code above is the new 256-color grayscale RENDERING mode (to support povray or other apps that do not need pre-dithered images like the screensavers and other images on the kindle). In fact, I have a "mostly done" mandelbrot program that uses my new full 256-color (grayscale) rendering mode. Is ANYBODY even interested?   Last edited by geekmaster; 05-13-2012 at 07:49 PM. | 
|   |   | 
|  04-28-2012, 02:15 PM | #3 | 
| Official Lurker            Posts: 1,050 Karma: 7096675 Join Date: Apr 2012 Device: Kindle 3.4 | 
				
				I love it!!
			 
			
			I am trying it out as I type this. The beginning reminds me of the McDonalds logo.I really like it and the effort you put into this community. Even if no one else does, I APPRECIATE YOUR WORK! qlobthehorse | 
|   |   | 
|  04-28-2012, 02:29 PM | #4 | 
| Time Waster            Posts: 422 Karma: 289160 Join Date: May 2011 Device: Kobo Glo and Aura HD | 
			
			I think the issue here with slow development is the site's audience, not much the device itself. Just have a look at the Nook Simple Touch section at XDA developers, they've done amazing stuff: http://www.youtube.com/watch?v=JDk8a0leP4U Nonetheless I always try your demos  I plan to play with the code as soon as I have the time... | 
|   |   | 
|  04-28-2012, 04:33 PM | #5 | |
| Member            Posts: 16 Karma: 25544 Join Date: Feb 2012 Device: Kindle 3 | 
			
			Impressive, as always! The cosmegg demo looks SO much better in 16 colors, and the screen flashing adds up to the hypnotic effect. Awesome! The "goodbye" part of the demo is cool. First, I thought that the binary contained extra things than the code attached, but then I realized that the trick is in sv[]. Very clever! Well done for implementing this! Your code really does incredible things with the e-ink display, showing not only that it's possible to display animations, in a decent framerate, but in 16 dithere colors, too. I had some issues compiling this on my Kindle 3. First, the files einkfb.h & mxcfb.h were missing. The I read I should find them in the Amazon Source codes; to compile, I needed the files from Kindle_src_5.1.0. Second, I received a Code: undefined symbol '__invalid_size_argument_for_IOC' Code: unsigned int __invalid_size_argument_for_IOC; Quote: 
 First, the dither16 (screen attached, no 2) shows some black where there should be white (on the top, for example) Second, the dither2 (screen attached, no 3) has a very subtle bug, that can observed easily for grays close to 50%. I attached a resized & cropped a portion of the screenshot to show the bug (screen attached, no 4). Basically, one column in 8 is off by 1 pixel. This is the code used to generate these screens: Code: for (x = 0; x < MX; x++) for (y = 0; y < MY; y++) setpx(x, y, y%256); Last edited by kiri87; 04-28-2012 at 04:36 PM. | |
|   |   | 
|  04-28-2012, 06:35 PM | #6 | |
| hub            Posts: 715 Karma: 2151032 Join Date: Jan 2012 Location: Iranian in Canada Device: K3G, DXG, Kobo mini | Quote: 
  Thanks for all your efforts. Nook Simple Touch looks so good. The videos, for example this one, shows it's really responsive... Well, in terms of hardware specification, it's as good as Kindle Touch but Kindle seems way slower. ?!!! Last edited by thatworkshop; 04-28-2012 at 07:26 PM. | |
|   |   | 
|  04-28-2012, 06:50 PM | #7 | |
| Carpe diem, c'est la vie.            Posts: 6,433 Karma: 10773670 Join Date: Nov 2011 Location: Multiverse 6627A Device: K1 to PW3 | Quote: 
 Anyway, kindle3 dither was horribly broken before due to compiler OVER-optimization making bad code, and when I got that fixed I decided to publish even though a little "off-by-one" issue still seems to exist. That will get fixed -- you need to catalog and fix these things as you find them, so thanks for adding detail. I did see that bug but it is subtle and for many things not annoying, and it will get fixed soon. After dithering, the result is 256 color. In essence, you add the upper four bits of dither to the bottom four bits of the pixel value, which might round up the top four bits to the next higher 16-bit color, then you zero out the bottom four bits of the pixel so the result is pure 16-bit hardware colors with no bottom bits to shift the cutoff point. That hardware cutoff point shifting took a lot of experimentation to figure out. That signature in the last demo was captured with my (unpublished) Touchpaint-2.0 script on the K5(touch). I have a lot of captured text in my collection. ANd yes, "sv" is the "signature vector", as you figured out, and it contains packed scalable coordinates rescaled (0-255x = 0-599 original, 0-255y= 0-799 original. Not only does scaling to 8 bits allow two coords/word, but you can rescale up or down as I did in the demo (actually started out much reduced in size and growing to 1.5x original size). Scalable vector graphics, with the line drawing function calling the "shaded circle" function to draw the signature with the same tubes used in the hoser demos. But the point is to show what CAN be done AND HOW TO DO IT. This is just a hint of things to come from me, and HOPEFULLY others too. Last edited by geekmaster; 04-15-2016 at 02:33 AM. | |
|   |   | 
|  04-28-2012, 08:25 PM | #8 | 
| Zealot            Posts: 130 Karma: 10000 Join Date: Mar 2012 Device: Kindle 3G, Kindle Touch 3G, iRiver Story HD, Sony Reader | 
			
			Hi Geekmaster, Excellent demo! I was looking at the code and wondering what sv[] was. It was worth running to the end. Anyway, I run into the header issue when I tried to compile it with tcc. I alway compile you code and run using tcc. I notice the diterh code is different this time and will try to figure it out. I was thinking about making a fractal demo with your code... Also, when I saw the speckle demo, I remember when I was going to school one of my classmates made a random dot stereogram http://en.wikipedia.org/wiki/Random_dot_stereogram. Thanks, James Last edited by jmseight; 04-28-2012 at 08:27 PM. | 
|   |   | 
|  04-28-2012, 09:08 PM | #9 | 
| Zealot            Posts: 130 Karma: 10000 Join Date: Mar 2012 Device: Kindle 3G, Kindle Touch 3G, iRiver Story HD, Sony Reader | 
			
			Hi Geekmaster, I understand why one has to dither a 256 color (8-bit) image to 1-bit image, so during update there is no flash. Would you please explain why you need to dither 256 color (8-bit) to 16 color (4-bit) grayscale? If you need this, would you not simply chop off the last 4 bits? And there will be the flash during update, correct? Thanks, James | 
|   |   | 
|  04-28-2012, 09:37 PM | #10 | |
| Carpe diem, c'est la vie.            Posts: 6,433 Karma: 10773670 Join Date: Nov 2011 Location: Multiverse 6627A Device: K1 to PW3 | Quote: 
 Although tcc can compile 5x to 9x faster than gcc, the final code is much less optimized. In this demo, I hand-optimized some of the code (batching the dither per-page instead of per-pixel, loop unrolling, splitting common logical expression phrases and moving outside loop body, etc.). These are things done for you by a good optimizing compiler, but I did them in the code (adding to its size and complexity) to make it work better with tcc. For most of my demos that run WIDE OPEN (no delays), it is worth running BOTH the gcc and tcc versions and comparing. The speckle demo (sparkle) is one such case -- you should see it run on the version I provided. I compiled the gcc version like this: arm-linux-gcc -O3 -o newtrix newtrix.c The -O3 option tells it to do extra optimization. I have a 256-color mandelbrot demo in progress. It is the original reason I began work on the 256-color dithering down to the 16-color hardware palette. But I used mostly existing code for a testbed, and kept that in the final program to provide various test "stages". For my unreleased "kindlebrot - kindle mandelbot demo" I am holding off until I have a menu to select from the nice looking default parameter sets. I also need an input method to provide custom navigation in the mandelbrot set. The kindle is not so fast using floating point, so eventually I was thinking of an integer mandelbrot re-write. By the way, you can use tccmake to link the math library like this: tccmake kindlebrot -lm   | |
|   |   | 
|  04-28-2012, 10:07 PM | #11 | 
| Carpe diem, c'est la vie.            Posts: 6,433 Karma: 10773670 Join Date: Nov 2011 Location: Multiverse 6627A Device: K1 to PW3 | 
			
			@kiri87: Regarding your images showing the kindle 3 comparison of color palettes between wb0 (raw color values), dithered 16-color, and dithered 2-color, I see a clear off-by-one error. In retrospect it is obvious that for "inverted color" devices I need to SUBTRACT the dither offset instead of adding it. This happens because the "normal" method of 8-bit and higher graphics is 0=black and 255=white, and this is how the new mxcfb device driver for the Freescale iMX508 integrated eink controller behaves. But for the older einkfb device driver used in the K3 and earlier that use the external epson broadsheet eink controller chip, the einkfb device driver assumes that color value zero is white instead of black (inverted color). A complication is the K4. Because it comes with SSH factory-installed in diags, I was doing my initial testing in an UNMODIFIED K4 (factory partitions, and not registered). When booted from diags, the K4 uses the new mxcfb eink driver to get full speed and power from the integrated eink controller. BUT (and this is a HUGE) when booting the K4 from main (with cvm and desktop framework) it runs in K3 compatibility mode using the old einkfb device driver. Not only is this eink compatibility mode slower and a lot more limited, it also uses the old inverted color palette (even when using its 8-bit framebuffer). When handling inverted color in my older code, I immediately inverted the color value (~color) and processed all pixels as black 0. But for this NEW demo, now that all my code uses ioctl() calls for all eink updates, I instead use the "inverted color update" for the inverted color devices. Now that I had a chance to sleep on what I thought looked like an "off by one" error at the top/bottom palette transition in the cosmegg demo, and taking the above information into account, it is plain to see that the color inversion affects the dithering so that instead of ADDING one to the 16-color palette when the "unused" bottom bits are greater than the dither threshold (in order to make the color MORE WHITE), we need to SUBTRACT one to make the color MORE WHITE on an inverted color palette. The inversion is now done at the last possible moment by the eink device drivers using the "inverted color update". So the dithers need to ADD only for the normal color dithers but need to SUBTRACT for the inverted color dithers. I may have already compensated for this in the 2-color dithering... I will compare the two methods and fix it. Thanks for giving me this feedback that helps me examine this from new directions.  UPDATE: I see while inspecting this code that the "right thing to do" is not to make the code conditional on white zero or black zero (like for K4main and K4diags), but to use dither tables that contain positive or negative values. One thing I realized while writing this is that 256-color mode requires that the bottom half-byte become zero, but the previous content dithers the bottom bit of the top half-byte. Dithering 4-bits can be done with a smaller 4x4 dither table with values 0-15.   Last edited by geekmaster; 04-29-2012 at 12:02 PM. | 
|   |   | 
|  04-28-2012, 10:40 PM | #12 | 
| Carpe diem, c'est la vie.            Posts: 6,433 Karma: 10773670 Join Date: Nov 2011 Location: Multiverse 6627A Device: K1 to PW3 | 
			
			The list of numbers in sv[0] is called in the computer graphics industry a "display list". It contains commands and data that render an image when the list is "executed". The display list used in this newtrix demo only implements commands for "move", "line-to", and "exit". The value zero is an "escape" which can be followed by a command. This simple version only implements an "exit" command (a second value zero). Any command does an implicit "pen-up", and in this code any non-zero value after a zero is assumed to be a "line-to" with implicit "pen-down" AFTER the command executes. You can think of a display list as a simple "machine language" executed by a software "graphics processor". The display list "language" can contain graphics commands that define one or more objects built from graphics primitives (2D: dot, line, circle, XY position, velocity, acceleration, 3D: sphere, tube, cube, XYZ position, velocity, acceleration, and you even define things like texture, transparency, and reflectivity). Display lists can also contain "subroutines" that display complex objects, and can be told to draw their object in different size, orientation, color, texture, and more. Display list subroutines can control animation using collision detection and particle physics (like gravity in the hoser demos). It is a custom language you define, so you can add what you want to it. When you add a new command to the display list language, you need to add code to the display list interpreter code to process that new command. You are only limited by your imagination. You could even script a feature length "animated motion picture" defined completely by a display list commands, which would give HUGE compression (a feature film in only a few KB, for example, but would grow a lot as you replace simple algorithmic textures and motion with detailed texture and motion capture). At the end of the sv[] table you can see three zeros. The first zero is "command" (and pen-up), which is followed by a second zero "exit". The third zero is for segfault prevention when modifying the display list driver. A little farther up in the table you can see a solitary zero, which behaves as a "pen-up" command, used to cross the letter "t" in the touchscreen-captured "geekmaster" signature. The "pen" draws with the same "shaded tubes" as the "hoser" demo, with tube diameter proportional to the same scale factor as the the signature dimensions. For those who have not watched it, the signature "scalable vector graphic" is displayed in the final "goodbye" demo after its animation has been running for awhile, starting so small it is barely visible at first, slowly growing until it covers a large part of the display. Because the background is doing continuous "color palette animation", and the signature is rendered on top of every background frame just before calling the eink update, the signature appears to "hover" above the animated background image while it slowly grows in size. You really need to see this effect. Perhaps I should post just the final stage of this demo, which I created specifically for a final "wow" effect for this program (close the show with a "bang"). EDIT: I added some links to external web pages. I recommend clicking the underlined links above and reading at least a little of the linked pages. Good stuff!  I have unfinished code that converts these display lists into "Hershey code" variant so that it can be rendered by my (also unfinished) "Hershey vector fonts" code. That way the above table can be converted into a simple character string, and rendered by the vector font code. I also have some unfinished "Z-Buffer Device" code.   Last edited by geekmaster; 04-29-2012 at 12:43 PM. | 
|   |   | 
|  04-28-2012, 11:27 PM | #13 | 
| Connoisseur            Posts: 58 Karma: 9096 Join Date: Apr 2012 Device: none | 
			
			It is awesome.I like to try technical work.It brings surprise.
		 | 
|   |   | 
|  04-29-2012, 12:37 AM | #14 | 
| Zealot            Posts: 130 Karma: 10000 Join Date: Mar 2012 Device: Kindle 3G, Kindle Touch 3G, iRiver Story HD, Sony Reader | 
			
			Hi Geekmaster, Thanks for the explanation about tcc. I have a couple of questions: 1) I understand that I can compile in the Kindle with gcc with Debian and OptWare. Debian istaking up 500MB in my Kindle and I am seriously thinking about deleting. I am sure I don't want to take another 250MB for OptWare. Is there a more resource efficient way. 2) Would you please explain why you would want to dither 256 colors to 16 colors? 3) Since most non-e-book programs are written with 24-bit colors, I have been converting 24-bit color to 8-bit color, then from 8-bit to 2-bit by dithering. Maybe there is a quick way to combine the dithering with grayscaling in one operation... 4) Motion streogram will be an excellent demo on the Kindle. My classmate made a 3D rotating cube and hypercube on the computer display, and it made quite a impression. Thanks, James | 
|   |   | 
|  04-29-2012, 02:03 AM | #15 | |
| Carpe diem, c'est la vie.            Posts: 6,433 Karma: 10773670 Join Date: Nov 2011 Location: Multiverse 6627A Device: K1 to PW3 | Quote: 
  ... But my JOB keeps intruding.    Last edited by geekmaster; 04-30-2012 at 12:33 PM. | |
|   |   | 
|  | 
| Thread Tools | Search this Thread | 
| 
 | 
|  Similar Threads | ||||
| Thread | Thread Starter | Forum | Replies | Last Post | 
| geekmaster vacation | geekmaster | Kindle Developer's Corner | 2 | 03-19-2012 09:18 PM |