proj4j
proj4j copied to clipboard
Projection.initialize() method
The initialization method defined in the base class Projection
is not called in this case.
Clearly, classes that extend the base projection class are required to call this method to initialize the projection parameters - by my understanding of the codes.
However, many classes extending the Projection
class (like LandsatProjection
class) do not provide the default constructor and most likely the initialize()
method is never called in such cases.
Are the users supposed to call the initialize()
method? If not how about consider making it protected method?
The story is that lots of projections (i.e. LandsatProjection) require some love as well as the entire project code (actually we're an open source project, you can help us). We know that there are lot's of issues with the codebase.
In case of initialize, I'm pretty sure 1. it is not required in all the cases, and I don't see how did you figure out that it is required everywhere - all projections rely on different parameters. Mb only from the code hygiene point. 2. the LandsatProjection
doesn't properly work.
@pomadchin I think the comments to the Projection.initialize()
method says a lot about its uses.
/**
* Initialize the projection. This should be called after setting parameters and before
* using the projection.
* This is for performance reasons as initialization may be expensive.
*/
public void initialize() {
spherical = (e == 0.0);
one_es = 1-es;
rone_es = 1.0/one_es;
totalScale = a * fromMetres;
totalFalseEasting = falseEasting * fromMetres;
totalFalseNorthing = falseNorthing * fromMetres;
}
Looking at the codes, the projections that require further initialization override this method and in all cases call the base method.
The easiest way to manage such project is to file known issues as tasks, otherwise, it is not obvious when you download the sources. I have done that with my current project on GitHub SharpVectors/issues
I am running into these issues, because I started porting it to .NET/C#, which gives me the opportunity to look at the sources file by file, and I am filing these issues to draw attention to them.
@paulushub are you sure that all projections use
spherical, one_es, rone_es, totalScale, totalFalseEasting, totalFalseNorthing
?
For instance Landsat uses none of these parameters => that is why the lack of this call won't break anything. Mb for the code hygiene purposes it makes sense to make code more readable though.
I'm pretty sure that all non standard projections don't use common parameters and it can explain the lack of init method and lack of overrided constructors.
I see, here is the pointer to tests with non working projections we have a bunch of tests that are failing due to some bad math. Hope it will help you.
Also I appreciate a lot all the issues created, thank you!
@paulushub are you sure that all projections use
Possibly not, but since this is also a port of the C/C++ codes, it is safer to simply follow the pattern defined in the comment, rather than searching to find if a project/inverse needs that or not.
I would like even to get rid of the init method tbh.