<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>Photon on cdelmonte.dev</title>
    <link>https://cdelmonte.dev/tags/photon/</link>
    <description>Recent content in Photon on cdelmonte.dev</description>
    <generator>Hugo -- 0.147.7</generator>
    <language>en-us</language>
    <lastBuildDate>Tue, 26 May 2026 00:00:00 +0000</lastBuildDate>
    <atom:link href="https://cdelmonte.dev/tags/photon/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Where Spark Changes Shape: UnsafeRow, the JVM, and the Relocation of Portability</title>
      <link>https://cdelmonte.dev/essays/where-spark-changes-shape/</link>
      <pubDate>Tue, 26 May 2026 00:00:00 +0000</pubDate>
      <guid>https://cdelmonte.dev/essays/where-spark-changes-shape/</guid>
      <description>Run df.explain on a Parquet scan and you find ColumnarToRow, an operator whose only job is to change the data&amp;rsquo;s shape. It is the seam where two architectural eras meet, and a record of how portability in analytical systems has relocated from the JVM runtime to the data format and the query plan.</description>
    </item>
  </channel>
</rss>
