<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Houston Haynes</title>
    <description>The latest articles on DEV Community by Houston Haynes (@houstonhhaynes).</description>
    <link>https://dev.to/houstonhhaynes</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F66920%2Fccaf7df8-c056-4419-97da-a24f1a7526ff.jpg</url>
      <title>DEV Community: Houston Haynes</title>
      <link>https://dev.to/houstonhhaynes</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/houstonhhaynes"/>
    <language>en</language>
    <item>
      <title>Achieving Full Screen PBP in 4K, One Person's Journey</title>
      <dc:creator>Houston Haynes</dc:creator>
      <pubDate>Sat, 10 Aug 2019 23:39:23 +0000</pubDate>
      <link>https://dev.to/houstonhhaynes/achieving-full-screen-pbp-in-4k-one-person-s-journey-4akp</link>
      <guid>https://dev.to/houstonhhaynes/achieving-full-screen-pbp-in-4k-one-person-s-journey-4akp</guid>
      <description>&lt;h1&gt;
  
  
  Theory vs Practice
&lt;/h1&gt;

&lt;p&gt;It seemed simple. Use a 4K monitor to run multiple computer screens simultaneously. There are dozens of choices for this. Picture by Picture (PBP) is a feature so common you'll scarcely see it in long form in the description. Just the acronym is all that's needed to sell the concept. But not all PBP designs and not all monitor drivers are equal. While it's tempting to call out certain vendors, the half-life of driver implementations (and generations of monitor hardware technology) is so short that this article might be out of date by the time you read it. So consider this in context if you're thinking about running multiple systems into a single display.&lt;/p&gt;

&lt;h2&gt;
  
  
  Bigger (and Wider) is not always Better
&lt;/h2&gt;

&lt;p&gt;This journey started with my 55 inch 4K TV, which was occasionally pressed into service while working from home. Mostly it served as a proxy for a white board during group working sessions with video feeds and slide/board presentations. Eventually I started using it more generally, but for detailed coding work it created too much eye strain. It is an earlier generation 4K TV and simply wasn't designed for at-arms-length viewing. So when I moved to remote work full-time, I looked for a purpose-built 4K monitor. I also wanted it to handle more than one input simultaneously, so I can work across multiple systems. While researching I quickly set aside the idea of an ultra-wide curved monitor. I'm not looking to frag virtual enemies at 120fps. The work I'm planning focuses more on using my system GPU for small-scale TensorFlow experiments. In fact, one of my early use cases was to set up my personal machine for various machine learning benchmark exercises (in Windows 10 and Ubuntu) while the work notebook handled general office and light-lift development duties. So the use case is fairly simple and straight-forward, or so I thought.&lt;/p&gt;

&lt;h2&gt;
  
  
  Reading the Fine Print
&lt;/h2&gt;

&lt;p&gt;Here's a photo of the first 4K monitor I bought, with the initial attempt at PBP shown below.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2Fphxtc131csezypjezs09.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2Fphxtc131csezypjezs09.jpg" alt="Philips 4K PBP double letter boxing"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Needless to say this is not at all what I was expecting. I tried all combinations of display properties, from 1:1 to full width, and nothing made any difference. I contacted the manufacturers technical support team and in few days I received a rather curt response.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;&lt;em&gt;Please make sure you are running HDMI 2.0 3840x2160@60hz, turn to page 10 in the user manual, PBP will have bars on the top and bottom.&lt;/em&gt; &lt;/p&gt;
&lt;/blockquote&gt;

&lt;center&gt;[cue sad trombone]&lt;/center&gt;

&lt;p&gt;So, in effect the customer has to use their psychic powers to know that 10-pages deep into the manual there's a proviso which says that &lt;em&gt;full screen PBP &lt;strong&gt;is not possible&lt;/strong&gt;&lt;/em&gt;. At that moment I realized I had not bought a monitor. I had bought a $600 boomerang. At least the product return process worked perfectly, so &lt;strong&gt;that&lt;/strong&gt; feature was fully implemented.  &lt;/p&gt;

&lt;h2&gt;
  
  
  Take Two, this time with Feeling
&lt;/h2&gt;

&lt;p&gt;The second monitor was lighter, used less power, was practically immune to screen burn and was nearly $100 cheaper than my first choice. So I felt lucky in many respects. However the second PBP result was not much better than the first. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2Fmkoxrksc9p8u0uaipa3k.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2Fmkoxrksc9p8u0uaipa3k.jpg" alt="ViewSonic 4K PBP letter-boxing"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;While running full screen the images scaled to the full height of the display area, there was still letter-boxing occurring. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2F9kh6hu8ltln9d4phu1hg.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2F9kh6hu8ltln9d4phu1hg.jpg" alt="ViewSonic monitor input Full Screen setting"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;So I sent a message to the second manufacturer's tech support group. And while this team was more polite, the initial response wasn't all that helpful. All of their suggestions simply re-iterated through the combinations of settings I had already tried, to no positive result. We even conducted an over-the-phone session to ensure we were apples-to-apples on the settings and output. It nagged at me that this wasn't something that manufacturers had already solved. Running 1920X2160 side-by-side with two separate monitor inputs seemed (to me, at least) to be a standard use case for a 4K monitor that's capable of handling more than one input at a time. But I resigned myself to switching separately between the two inputs at the full 3840X2160 resolution - toggling between them using the rear panel monitor controls. In truth, it was a nice "problem" to have. &lt;/p&gt;

&lt;h2&gt;
  
  
  Checking under the (Other) Hood
&lt;/h2&gt;

&lt;p&gt;A week later I received an email from the second tech support team, to reach out via phone and attempt another possible fix. I wasn't hopeful, but once we started chatting it out the idea dawned on me that &lt;em&gt;&lt;strong&gt;the computer's&lt;/strong&gt; video driver&lt;/em&gt; might be shaping the output in anticipation of a 16:9 aspect ratio. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2Fmwss4ydl2zqp3b7y0mw0.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2Fmwss4ydl2zqp3b7y0mw0.png" alt="NVidia Control Panel settings - Full Screen"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Once we checked the NVidia Control Panel, we saw that it was set to format the chosen resolution to "Aspect Ratio". That in effect meant that the driver was letter-boxing the output to the monitor when the resolution was set to a non-16:9 resolution. Once the setting was changed to "Full Screen" then everything fell into place.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2Fw2uq8k9s09gqywz18kz3.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fthepracticaldev.s3.amazonaws.com%2Fi%2Fw2uq8k9s09gqywz18kz3.jpg" alt="ViewSonic 4K with proper PBP configuration"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;There it was - two separate systems filling right/left sides of the screen, each with their own over/under window arrangement. With a 43" screen, each side could provide two 21" 1080p areas. And it's possible to set up an over/under PBP, so 3840X1080 is also possible. But after confirming that also worked as expected I went back to the left-right arrangement. It is glorious. &lt;/p&gt;

&lt;center&gt;[cue angels singing]&lt;/center&gt;

&lt;p&gt;I added a USB switch to toggle an external keyboard and mouse between the two systems. Since the work laptop connected to its own VNET, a Synergy-like software solution was not an option. However the physical "non-V KVM" works exceptionally well, and I adapted to it in less than a day.&lt;/p&gt;

&lt;h2&gt;
  
  
  Greater than the Sum of its Parts
&lt;/h2&gt;

&lt;p&gt;So this turned out to be a layered object lesson. I was genuinely surprised that two different manufacturers &lt;em&gt;didn't&lt;/em&gt; know how to address this out-of-the-gate. In a computing world where so much consumer-level hardware is plug-and-play, this was a surprisingly high-friction affair. I'm glad it was eventually solved, but it goes to show that you can't necessarily count on all domain knowledge to be in one place. That's one of the reasons I'm leaving this trail of breadcrumbs here. I had wondered whether trying the NVidia Control Panel settings with the first monitor would have made it work. But given that model &lt;em&gt;also&lt;/em&gt; had issues with potential screen burn (&lt;strong&gt;how&lt;/strong&gt; are those designs &lt;em&gt;still&lt;/em&gt; a thing?) I would have returned it either way. &lt;/p&gt;

&lt;p&gt;The final result is much better than I expected, providing flexibility in managing workloads across the two local machines. It also gives me more options for attaching to VMs - whether GPU-provisioned AMIs in AWS or Data Science VMs in Azure. I can essentially run a "quad" setup where the third and fourth "boxes" are machine learning instances doing full-bore workloads in the cloud, with the burden of running the virtual desktops for those sessions spanning the two slabs under my desk. But again that's a discussion I'll save for some other time. For now I'm happy just to have the pieces in place for true multi-tasking in the home office.&lt;/p&gt;

</description>
      <category>productivity</category>
      <category>programming</category>
      <category>azure</category>
      <category>machinelearning</category>
    </item>
  </channel>
</rss>
