diff --git a/src/main/java/org/orekit/rugged/api/SensorMeanPlaneCrossing.java b/src/main/java/org/orekit/rugged/api/SensorMeanPlaneCrossing.java
index 4be92b45b028c98d676e5a807d6ffc24813663b0..4bc2f63ba80239d233cc4ea0221aa43b9f0fb6fd 100644
--- a/src/main/java/org/orekit/rugged/api/SensorMeanPlaneCrossing.java
+++ b/src/main/java/org/orekit/rugged/api/SensorMeanPlaneCrossing.java
@@ -16,7 +16,7 @@
  */
 package org.orekit.rugged.api;
 
-import java.util.Arrays;
+import java.util.ArrayList;
 import java.util.List;
 
 import org.apache.commons.math3.analysis.differentiation.DerivativeStructure;
@@ -33,17 +33,11 @@ import org.orekit.utils.PVCoordinates;
 /** Class dedicated to when ground point crosses mean sensor plane. */
 class SensorMeanPlaneCrossing {
 
-    /** Converter between spacecraft and body. */
-    private final SpacecraftToObservedBody scToBody;
-
-    /** Line numbers of the middle sample point. */
-    private final double midLine;
-
     /** Transforms sample from observed body frame to inertial frame. */
     private final List<Transform> bodyToInertial;
 
-    /** Transform from inertial frame to spacecraft frame, for middle line. */
-    private final Transform midLineScToInert;
+    /** Transforms sample from spacecraft frame to inertial frame. */
+    private final List<Transform> scToInertial;
 
     /** Minimum line number in the search interval. */
     private final int minLine;
@@ -87,7 +81,6 @@ class SensorMeanPlaneCrossing {
         try {
 
             this.sensor                      = sensor;
-            this.scToBody                    = scToBody;
             this.minLine                     = minLine;
             this.maxLine                     = maxLine;
             this.lightTimeCorrection         = lightTimeCorrection;
@@ -95,11 +88,13 @@ class SensorMeanPlaneCrossing {
             this.maxEval                     = maxEval;
             this.accuracy                    = accuracy;
 
-            midLine          = 0.5 * (minLine + maxLine);
-            bodyToInertial   = Arrays.asList(scToBody.getInertialToBody(sensor.getDate(minLine)).getInverse(),
-                                             scToBody.getInertialToBody(sensor.getDate(midLine)).getInverse(),
-                                             scToBody.getInertialToBody(sensor.getDate(maxLine)).getInverse());
-            midLineScToInert = scToBody.getScToInertial(sensor.getDate(midLine));
+            bodyToInertial = new ArrayList<Transform>(maxLine - minLine + 1);
+            scToInertial   = new ArrayList<Transform>(maxLine - minLine + 1);
+            for (int line = minLine; line <= maxLine; ++line) {
+                final AbsoluteDate date = sensor.getDate(line);
+                bodyToInertial.add(scToBody.getInertialToBody(date).getInverse());
+                scToInertial.add(scToBody.getScToInertial(date));
+            }
 
         } catch (OrekitException oe) {
             throw new RuggedException(oe, oe.getSpecifier(), oe.getParts());
@@ -174,9 +169,10 @@ class SensorMeanPlaneCrossing {
             // as we know the solution is improved in the second stage of inverse localization.
             // We expect two or three evaluations only. Each new evaluation shows up quickly in
             // the performances as it involves frames conversions
-            double  crossingLine  = midLine;
-            Transform bodyToInert = bodyToInertial.get(1);
-            Transform scToInert   = midLineScToInert;
+            final int midIndex    = bodyToInertial.size() / 2;
+            double  crossingLine  = minLine + midIndex;
+            Transform bodyToInert = bodyToInertial.get(midIndex);
+            Transform scToInert   = scToInertial.get(midIndex);
             boolean atMin         = false;
             boolean atMax         = false;
             for (int i = 0; i < maxEval; ++i) {
@@ -214,9 +210,10 @@ class SensorMeanPlaneCrossing {
                     atMax = false;
                 }
 
+                final int inf = FastMath.max(0, FastMath.min(scToInertial.size() - 2, (int) FastMath.floor(crossingLine)));
                 final AbsoluteDate date = sensor.getDate(crossingLine);
-                bodyToInert = Transform.interpolate(date, true, true, bodyToInertial);
-                scToInert   = scToBody.getScToInertial(date);
+                    bodyToInert = Transform.interpolate(date, false, false, bodyToInertial.subList(inf, inf + 2));
+                    scToInert   = Transform.interpolate(date, false, false, scToInertial.subList(inf, inf + 2));
             }
 
             return null;