The 2026 ZiPS Projections Are Almost Here!

As soon as one story in baseball ends, another begins. And so, with the 2025 season dissipating into silence as the champions hoist the World Series trophy, its remnants seed the next phase of the sport’s existence out from the quantum foam. The four months between now and Opening Day feel like an interminable gap, but we have the Hot Stove League to keep the MLB baseballmatic universe rolling. That means, as has been the case for nearly a quarter of a century now, it’s time for me to start rolling out the ZiPS projections for next season.
For those new to my projections, ZiPS is a computer projection system I initially developed in 2002–04. It officially went live for the public in 2005, after it had reached a level of non-craptitude I was content with. The origins of ZiPS are similar to Tom Tango’s Marcel the Monkey, coming out of discussions I had in the late 1990s with Chris Dial, one of my best friends (our first interaction involved Chris calling me an expletive!) and a fellow stat nerd. ZiPS quickly evolved from its original iteration as a reasonably simple projection system, and it now both does a lot more and uses a lot more data than I ever envisioned it would 20 years ago. At its core, however, it’s still doing two primary tasks: estimating what the baseline expectation for a player is at the moment I hit the button, and then estimating where that player may be going using large cohorts of relatively similar players.
So why is ZiPS named ZiPS? At the time, Voros McCracken’s theories on the interaction of pitching, defense, and balls in play were fairly new, and since I wanted to integrate some of his findings, I decided (with his blessing) that the name of my system would rhyme with DIPS (defense-independent pitching statistics). I didn’t like SIPS, so I went with the next letter in my last name. I originally named my work ZiPs as a nod to CHiPs, one of my favorite shows to watch as a kid, but I mis-typed ZiPs as ZiPS when I released the projections publicly, and since my now-colleague Jay Jaffe had already reported on ZiPS for his Futility Infielder blog, I chose to just go with it. I never expected that all of this would be useful to anyone but me; if I had, I would surely have named it in less bizarre fashion.
ZiPS uses multiyear statistics, with more recent seasons weighted more heavily; in the beginning, all the statistics received the same yearly weighting, but eventually, this became more varied based on additional research. And research is a big part of ZiPS. Every year, I run hundreds of studies on various aspects of the system to determine their predictive value and better calibrate the player baselines. What started with the data available in 2002 has expanded considerably. Basic hit, velocity, and pitch data began playing a larger role starting in 2013, while data derived from Statcast has been included in recent years as I’ve gotten a handle on its predictive value and the impact of those numbers on existing models. I believe in cautious, conservative design, so data are only included once I have confidence in their improved accuracy, meaning there are always builds of ZiPS that are still a couple of years away. Additional internal ZiPS tools like zBABIP, zHR, zBB, and zSO are used to better establish baseline expectations for players. These stats work similarly to the various flavors of “x” stats, with the “z” standing for something I’d wager you’ve already guessed.
How does ZiPS project future production? First, using both recent playing data with adjustments for zStats, and other factors such as park, league, and quality of competition, ZiPS establishes a baseline estimate for every player being projected. To get an idea of where the player is going, the system compares that baseline to the baselines of all other players in its database, also calculated from the best data available for the player in the context of their time. The current ZiPS database consists of about 152,000 baselines for pitchers and about 185,000 for hitters. For hitters, outside of knowing the position played, this is offense only; how good a player is defensively doesn’t yield information on how a player will age at the plate.
Using a whole lot of stats, plus information on the shape of a player’s production and other characteristics, ZiPS then finds a large cohort that is most similar to the player. I use Mahalanobis distance extensively for this. A few years ago, Brandon G. Nguyen did a wonderful job broadly demonstrating how I do this while he was a computer science/math student at Texas A&M, though the variables used aren’t identical.
As an example, here are the top 50 near-age comparables for possible American League MVP Cal Raleigh right now, a particularly difficult player to comp. The total cohort is much larger than this, but 50 ought to be enough to give you an idea:
With comp candidates in the hundreds of thousands, not the billions, you’re never blessed with perfect comps. ZiPS would love to find a multitude of switch-hitting catchers in their late 20s with serious Three True Outcome game and butt-themed nicknames (OK, the last bit isn’t in the database), but it won’t, so it tries to assemble a group that is at least Cal Raleigh-ish. From testing, I know that ZiPS works significantly better over the long haul when the Cal Raleighs are compared to Cal Raleighs, not Francisco Lindors or Juan Pierres or Matt Raleighs. The exact mix algorithm to assemble comps was determined by extensive testing, basically by having a computer running ZiPS 24-7 for about a year. The large group of similar players is then used to calculate an ensemble model on the fly for a player’s future career prospects, both good and bad.
One of the tenets of projections that I follow is that no matter what the ZiPS projection says, that’s what the projection is. Even if inserting my opinion would improve a specific projection, I’m philosophically opposed to doing so. ZiPS is most useful when people know that it’s purely data-based, not some unknown mix of data and my opinion. Over the years, I like to think I’ve taken a clever approach to turning more things into data — for example, ZiPS’ use of basic injury information — but some stuff just isn’t in the model. ZiPS doesn’t know if a pitcher wasn’t allowed to throw his slider coming back from injury, or if a left fielder suffered a family tragedy in July. Those sorts of things are outside a projection system’s purview, even though they can affect on-field performance. ZiPS isn’t mathemagical, and anyone using a useful tool should know its limitations and apply their own judgment to the question at hand.
It’s also important to remember that the bottom-line projection is, in layman’s terms, only a midpoint. You don’t expect every player to hit that midpoint; 10% of players are “supposed” to fail to meet their 10th-percentile projection and 10% of players are similarly “supposed” to pass their 90th-percentile forecast. This point can create a surprising amount of confusion. ZiPS gave a .300 batting average projection to just one player in 2025: Luis Arraez. But that’s not the same thing as ZiPS thinking there would only be a single .300 hitter. On average, ZiPS thought there would be 15 hitters with at least 100 plate appearances to eclipse .300, not one. In the end, there were 13.
Another crucial thing to bear in mind is that the basic ZiPS projections are not playing-time predictors; by design, ZiPS has no idea who will actually play in the majors in 2026. Considering this, ZiPS only makes its projections for how players would perform in full-time major league roles. Having ZiPS tell me how someone would hit as a full-time player in the big leagues is a far more interesting use of a projection system than if it were to tell me how that same person would perform as a part-time player or a minor leaguer. For the depth charts that go live in every article, I use the FanGraphs Depth Charts to determine the playing time for individual players. Since we’re talking about team construction, I can’t leave ZiPS to its own devices for an application like this. It’s the same reason I use modified depth charts for team projections in-season. There’s a probabilistic element in the ZiPS depth charts: Sometimes Joe Schmo will play a full season, sometimes he’ll miss playing time and Buck Schmuck will have to step in. But the basic concept is very straightforward.
There are no major updates this year on the level of 2025, when I officially started using spring training data (with less weight than regular season data) for a final ZiPS run right before the season. There are, however, the usual calibration adjustments and quality-of-life updates that make ZiPS simpler to run, while providing more ways to look at projection data. I’ll be doing some KBO/NPB pieces after the 30 team articles, so there’s a little bonus in there. And there are at least a few new things in the model, such as a model for how many games a catcher is likely to play at 1B/DH in order to get a more accurate WAR projection than just assuming all their games are played as a catcher.
Have any questions, suggestions, or concerns about ZiPS? I’ll try to reply to as many as I reasonably can in the comments below. Also, if the projections have been valuable to you now or in the past, I would urge you to consider becoming a FanGraphs Member, should you have the ability to do so. It’s with your continued and much appreciated support that I have been able to keep so much of this work available to the public for so many years. Improving and maintaining ZiPS is a time-intensive endeavor, and reader support allows me the flexibility to put an obscene number of hours into its development. It’s hard to believe I’ve been developing ZiPS for nearly half my life now! Hopefully, the projections and the things we’ve learned about baseball have provided you with a return on your investment, or at least a small measure of entertainment, whether it’s from being delighted or enraged.
Dan Szymborski is a senior writer for FanGraphs and the developer of the ZiPS projection system. He was a writer for ESPN.com from 2010-2018, a regular guest on a number of radio shows and podcasts, and a voting BBWAA member. He also maintains a terrible Twitter account at @DSzymborski.
I sold Chris Hoiles a pair of boots at Sunny’s “The Affordable Outdoor Store” (formerly Sunny’s Surplus) near Timonium in the summer of 1994, after he finished an autograph signing there. He was friendly.
Looking forward to ZIPS!