gravitystorm / openstreetmap-carto

A general-purpose OpenStreetMap mapnik style, in CartoCSS
Other
1.51k stars 813 forks source link

Guidelines for adding new features #1630

Open gravitystorm opened 9 years ago

gravitystorm commented 9 years ago

In a different issue @kocio-pl says:

"AFAIK there are currently no policy on the amount of tag uses yet. It's just a matter of individual taste and feeling."

I don't want thinks to be unpredictable, so we should come to a collective decision rather than it depending one individual taste. But it's a tricky subject, and causes a huge amount of bad feelings, since every mapper wants every tag to show up somewhere, and unfortunately for us, that somewhere is almost always here.

I have two guidelines that I'd like to see implemented:

Basically, numbers-of-features based rules aren't usable. Just because there are millions of X doesn't mean we should put them on this map style. And just because only a few hundred Y have been mapped doesn't make them unsuitable.

When it comes to adding new things - well, there are roughly hundreds of thousands - perhaps millions - of different "things" in OpenStreetMap and they almost all could be added to this style. If we add things and don't remove things, then the map style will show hundreds of thousands of different things, and that's not tenable. It stops being a map and is just a complex, unreadable, useless and ugly visualisation of the database. So we need to have a plan to remove things if we keep adding more and more. I know people disagree with me here, and claim that there's no downside to adding more features (or new features won't be drawn in the same place as existing ones, or can't see the problem with having millions of different icons) but they are wrong. And the way we are doing it at the moment - where we add new features every week since "one or two more can't hurt" is unsustainable.

For the second point, if a feature is so obscure that no other rendering - even including specialist renderings - contain that feature, then I think it's inappropriate to add it to a general style. It should be the case that the main map style is a good summary of the data available, and then if you want to see more information on a topic, you can switch to another, perhaps specialist, map. Having features appearing only on the general style and not elsewhere is completely back-to-front.

Other proposals are, of course, welcome!

kocio-pl commented 9 years ago

I also think this will be hard to reach general agreement, but anyway the problem is worth discussing.

We have different backgrounds for a start - for example you're the lead developer of the whole style (and not only this one), so you tend to see universal things, while I work mainly as a micromapper, so I see the world mainly through the z17+ zoom levels.

For me even the most crowded POI space according to some mappers is just mildly saturated with informations on z19 with a big hole in the center (and I see missing icon for Fired Earth shop, because the name tells me nothing, while we have needed info in our database). But on the other hand I don't remember this style may be used on other servers and for other purposes than only main OSM website.

This is not a bad thing per se - quite the reverse: I thing it's rather healthy. The more different people, the more chance to strike the balance. That makes everything much harder and longer, but that's the price of trying to do the best we can.

I would ask some questions before we start drawing the lines:

  1. What are the most important goals of general map?

I would say it should show the things common people wants to find (and the most visible things, especially on micromapping level). On the lowest levels that would be physical view and readable country borders and names, with capitals visible early enough, on the medium level that could be readable roads, cities, touristic attractions, the borders of campuses and many other institutions and nature forms (IMO we excel at this and are still getting better, unlike on the lower and higher levels), and on the highest zoom levels that should be POIs (readable icon shapes and names when possible), highways shapes, trees, flower beds, overground pipelines and maybe even fire hydrants (red dot at z18+ is comparably important to black dot for bollard, which we have a lot by now). It's just a rough list, but I think you get the vision.

For me the rule of removing as much as we add may be the most correct at the medium level (however maybe that's too strict even there). For the lowest levels it's rather reworking things than adding/removing anything, and for the highest levels there's a lot of essential things which are not visible yet, so I hardly see the need to remove anything for now.

  1. The numbers on Taginfo is one thing, but what about Wiki status? If we don't take the numbers blindly, maybe we should somehow look also if the tagging is "deprecated", "approved" or "de facto"?
imagico commented 9 years ago
  • For every new feature added, (at least) one feature is removed
  • For any feature to be considered for this style, it must already be on one other osm.org front-page style

I would be for following the first - not necessarily in a strict 'quid pro quo' sense but strongly suggesting that anyone who suggests or creates PRs for adding new features should also make similar contributions w.r.t. removing.

But i would be strictly against the second. This is a typical 'preserving the status quo for the sake of conservation itself' rule. Innovation and progress need to start somewhere and since the standard style is the only one that is based on at least partly democratic control and does not have a strict thematic focus this rule - when obeyed strictly - will seriously cripple the ability to develop the style in a way that reflects mapping priorities in OSM.

In general i think formal rules are not very beneficial in this context, especially since people tend to read them the other way round - like if i create a PR that adds a feature that is already shown in another map and removes another one it will have to be accepted.

It seems to me that much of this matter is centered around POI icons which make up a large portion of recent PRs. I think these are a special case in the much broader field of map design in general and many of the problems here are related to the technical constraints that currently exist. Let's not implement global rules on map design just based in this specialized matter. In general improving readability of the map has often very little to do with how many types of features are shown but with how they are shown (and POI icons are often simply a fairly wasteful way of showing things).

Instead of a set of rules/guidelines i would create a checklist of questions that are to be considered to decide if a new feature is to be rendered. What comes to mind here is:

The answers to these questions of course depend on your point of view, such list would not have the purpose of making the decision for you, it would be a helper for those in a position of making the decision (making a PR or merging a PR) and you could use your detailed answers to these questions to support your decisions.

And i said before and will repeat here: One of the most important aspects of style development i see much too little here is the critical review of changes after they have been rolled out. This in particular applies to the addition of new features.

matkoniecz commented 9 years ago

@gravitystorm

For every new feature added, (at least) one feature is removed

I agree that we are at point where removing features may be better than adding more - for example in my road redesign I decided to display highway=motorway and highway=trunk using nearly the same style (I am copying it from Humanitarian style, the only planned difference is zoom level where road appears). I also want to get rid of highway=proposed.

Though it would be tricky to define how features are counted. 100 shop types displayed as a purple dot - is it a single feature or 100 (my bet that it is single)? Lets say that there are 27 road types that may be displayed with red dashes or not marking whatever road is private. Is it 54 features or 28? 27 road types where each may be private/public and paved/unpaved. Method for displaying access and surface status is the same across roads. Is it 29 features or 108? I think that it would not work as hard rule, but "removing features is not only acceptable but also welcomed" guideline would be great.

Also, features are not equal. Displaying shop=toys and shop=kiosk differently has lower impact than displaying highway=motorway and highway=trunk differently. Different icons for shops are quickly increasing number of features - but impact of making map more confusing is not high as these shop icons are quite intuitive. And in the worst case icon colour should make it clear that it is some kind of shop. Impact of #1239, #775 or #720 would be much more significant (as measured by increasing complexity of map) than one more shop icon. My feeling is that removing highway=proposed and adding 50 new shop icons would be balanced.

Basically, numbers-of-features based rules aren't usable. Just because there are millions of X doesn't mean we should put them on this map style. And just because only a few hundred Y have been mapped doesn't make them unsuitable.

I think that any request for rendering tag with less than 1000 occurrences and without really good explanation why it should be exempt from this rule may be rejected without discussion. "not used widely, therefore no rendering" allows to close majority of requests for new features without pointless discussion. It is especially helpful as it is common that people proposing to render rare tags are ready to debate endlessly. For example in case of #1239 effort to discuss, implement and test rendering is greater than effort that was needed to map existing occurrences of that tag.

And what may be a good explanation - for example one for rendering natural=shingle from #1217 ("In the code you can see that i included natural=shingle to be rendered like natural=scree to avoid mappers feeling additionally inclined to tag natural=scree despite this being technically wrong."). capital=yes would be clearly exempt as useful tag to describe really rare feature. But "this tag should be promoted" is not a good reason.

For any feature to be considered for this style, it must already be on one other osm.org front-page style

I would expand it to "style with rendering for the whole planet, updated at least once a month". That would include for example French-style renderer.

dieterdreist commented 9 years ago

2015-07-03 16:01 GMT+02:00 Christoph Hormann notifications@github.com:

  • For every new feature added, (at least) one feature is removed
  • For any feature to be considered for this style, it must already be on one other osm.org front-page style

    I would be for following the first - not necessarily in a strict 'quid pro quo' sense but strongly suggesting that anyone who suggests or creates PRs for adding new features should also make similar contributions w.r.t. removing.

+1, sounds reasonable. Making the removal a hard requirement might lead to nonsense for the sake of following the rules.

But i would be strictly against the second. This is a typical 'preserving

the status quo for the sake of conservation itself' rule. Innovation and progress need to start somewhere and since the standard style is the only one that is based on at least partly democratic control and does not have a strict thematic focus this rule - when obeyed strictly - will seriously cripple the ability to develop the style in a way that reflects mapping priorities in OSM.

+1, it is also somehow arbitrary what is showcased on the front page, and there are requirements like global availability that reduce the number of potential new maps there mostly to people doing business with OSM (because of the required ressources to offer an up to date global rendering that can cope with the number of requests from osm.org).

Generally we should keep in mind that this is the main style of a global project, and that the project is likely still "young" in a certain sense. "We" are naturally already biased towards the "western world" and under the influence of western culture / point of view (inevitably, just have a look where we come from and where "we" live), and so are all our maps on the front page (incl. HOT). With this requirement we would make this situation even less changeable / open to changes that don't fit into or a needed in the western world (and often don't matter because the features in questions don't happen to occur in the western world).

In general i think formal rules are not very beneficial in this context,

+1

pnorman commented 9 years ago

Basically, numbers-of-features based rules aren't usable. Just because there are millions of X doesn't mean we should put them on this map style. And just because only a few hundred Y have been mapped doesn't make them unsuitable.

While I agree that they aren't always suitable, for shop and similar POIs where we have a generic fallback, I think it's a reasonable first pass.

More throughts from me later

joostschouppe commented 9 years ago

Definitely agree with the general idea. Really like the idea to use rendering questions as a means to improve documentation as @imagico seemed to suggest. It might make sense to introduce some kind of pop poll for suggesting additions and removals. Then popular slots for addition could be freed up only if and when some removal suggestion reaches critical mass.This would avoid having to devise logical rules, and would just leave it to the community.

kocio-pl commented 9 years ago

Also, features are not equal. Displaying shop=toys and shop=kiosk differently has lower impact than displaying highway=motorway and highway=trunk differently. Different icons for shops are quickly increasing number of features - but impact of making map more confusing is not high as these shop icons are quite intuitive. And in the worst case icon colour should make it clear that it is some kind of shop. Impact of #1239, #775 or #720 would be much more significant (as measured by increasing complexity of map) than one more shop icon. My feeling is that removing highway=proposed and adding 50 new shop icons would be balanced.

While I agree with this conclusion, it reminds me of important hint we should consider crafting (not just adding or removing) any feature on the map:

The most general scale guide would be like:

  1. Big scale - worldwide features, mainly natural ones (like continents and the oceans), but also country borders and capitals.
  2. Medium scale - roughly speaking: anything from country to city level.
  3. Small scale - anything from part of the city to street/building level (so called micromapping).

They are different beasts, really: most important big scale objects are areas, most important small scale objects are points, and medium scale is associated mainly with lines (however there is also mix of important areas and points involved).

Now - we tend to focus on medium scale and see virtually every feature through these "lenses". However the impact of displaying highway=motorway and highway=trunk differently is far less on both extremes than:

We may even treat the medium scale as a special case and take more care of it, but if something is less visible or just doesn't belong there, we should - metaphorically speaking - change our regular glasses for telescope or microscope, respectively.

gravitystorm commented 9 years ago

Instead of a set of rules/guidelines i would create a checklist of questions that are to be considered to decide if a new feature is to be rendered. What comes to mind here is:

My point about using other styles as a yardstick is to avoid exactly this outcome. You've listed 12 perfectly reasonable points that should be considered, but you're advocating that all those decisions should be made in this one style in this one repository. But we're already overwhelmed by conversation, and I'm trying to diffuse the amount of work and angst that goes into this style, not increase it further.

If you're unhappy about the number of styles on the front page, then we should either solve that (by increasing the number of styles) or change the rule (to include a wider acceptance criteria, as @matkoniecz suggested). But openstreetmap-carto will probably collapse under the weight of discussion if we need to go into such depths ourselves. I would like to expand this scrutiny effort, using the distributed knowledge of all the other people working on their own renderings, not just concentrate everything here.

imagico commented 9 years ago

My suggestion was not meant to advocate more discussion. It is meant as a helper for (a) contributors to check their requests for adding new features to be viable before making them and therefore avoiding fruitless discussion and (b) style maintainers to make fast yet transparent decisions on closing issues/rejecting PRs without a pointless discussion.

I completely understand your desire to keep style development here focused on the important things and avoid the style degenerating in quality and readability - i just don't think this particular regulation would have a positive effect.

One thing that aggravates the problem of excessive unproductive discussions here is that there is no forum for generic OSM map styling discussion elsewhere. A lot of discussions started here are on a fairly generic level that is not really suited for this place. Discussions on how a certain POI tag can in principle be visualized with an icon for example are something not specific to this style and could IMO be separated from actual style development. Managing discussion here in a way that decidedly directs subjects on a level that is not specific to this style to a different place would help a lot. This certainly covers a lot of new feature discussions. If on the other hand someone has a concrete plan how a certain new feature could be shown in this style based on extensive research into the possibilities and suggests this here it would IMO be very bad if he/she would be turned down based on the formal argument that this feature is not shown in any other qualified OSM map without considering the merits of the suggestion itself.

I would like to expand this scrutiny effort, using the distributed knowledge of all the other people working on their own renderings, not just concentrate everything here.

That is a good idea, if however you put the barrier that high (for example like @matkoniecz: global maps with regular updates) the primary effect would be removing a possibility for style developers to contribute to OSM when new features are involved, especially those with limited ressources (who cannot run their own global map) and those not from regions with a large and well organized local community who have their own local focus style (like in Germany or France).

brycenesbitt commented 9 years ago

A problem: There is no truly "open" rendering style in OpenStreetMap. The database is open: people can and do add whatever they want. There's no equivalent on the rendering side: renderings are like castles with moats, with the hordes massing outside banging on the gates. The maintainers inside protecting the integrity of the rendering, and the masses outside complaining, are a hard dynamic for everyone.

The way out may be more top level maps, including a true "bagel with everything" approach map with few rules, another new map focused explicitly on motorists, and an open community version of cycling, public transport and political maps. Organize this all on a new mailing list called rendering@openstreetmap.org, so osm-carto does not become the only focal point for discussion debate, hopes and dreams. Offer a mix of "curated" maps created with the integrity of a single voice (such as OpenCycleMap), and "open" maps created via a messier process.


@gravitystorm "For every new feature added, (at least) one feature is removed" is a particularly moat-like rule that ignores the fact that rendering is not a zero sum game. A small community could get it's feature rendered with little to zero impact on anyone else. Deciding to render trees or fire hydrants or road signs is a big deal, because there are so many. Other features (and here "motorhome toilet dump stations" or "farm product stands" come to mind) have essentially zero impact on anyone else, because they are located in areas that are otherwise empty on the map. Very close to exactly nobody is overwhelmed by clutter for such items, as there is no clutter.

matthijsmelissen commented 9 years ago

@gravitystorm I'm happy you started this discussion. My point of view:

For every new feature added, (at least) one feature is removed For any feature to be considered for this style, it must already be on one other osm.org front-page style

I don't think I'd be personally in favour of either of these guidelines.

the map style will show hundreds of thousands of different things, and that's not tenable.

I think we can distinguish three (related but distinct) issues here:

  1. displaying too many different features
  2. using too many different symbols
  3. displaying those symbols on too early zoom levels

@gravitystorm Which of these do you think are problems with our style?

In my opinion the problem is 3., and a bit of 2. I don't think 1. is a problem.

For example, rendering things like hackerspaces would be no problem to me at all if we render them with text only (no icon, addressing 2), and render them only on high zoom levels (addressing 3).

It stops being a map and is just a complex, unreadable, useless and ugly visualisation of the database.

I think that's the core issue. We do really bad at the issues you mention. I would expect though that we can do a lot by simply changing minimum zoom levels, and maybe even by toning down colours.

I think having concrete examples makes things easier to discuss. @gravitystorm, what do you think of the example given by @kocio-pl? Too me on z19 the map is readable, useful and not terribly ugly. Would you prefer a reduction in the number of different icons, of even a reduction in the number of different displayed POI, here too?

kocio-pl commented 9 years ago

@brycenesbitt +1

I like the democratic, open aspect of this style very much, even if it's limited by many aspects. But I hate feeling like a "hordes agent" (?) inside the castle, just because I want to try some things rather than just keep the house tidy. I would be happy to work with some "development"/"working"/"for mappers" version of this style (less strict, with more features and testing stuff), but when I recently asked if new hardware donations could be used for this, @pnorman said it won't.

We definitely should have some place to talk about more general things related to rendering. Mailing list or maybe subforum on OSM forum would be easy to set. This alone could not resolve the problem of "open" rendering style, of course (talking without a chance of getting the real output will be harsh exercise in frustration), but that would be a good start.

The big question is how to make the rendering in OSM more open, collaborative process in a peaceful way, without anybody feeling ignored or being under pressure.

pnorman commented 9 years ago

I have two guidelines that I'd like to see implemented:

For every new feature added, (at least) one feature is removed For any feature to be considered for this style, it must already be on one other osm.org front-page style

The style is currently in a place where removing features is more valuable than adding them, but I'm not sure that this is the most effective way reign this issue in. On the other hand, I don't really have an alternative suggestion.


I get the feeling that some people view this style as an OpenStreetMap project to design a style for osm.org. I do not consider it that. I consider it a project started by Andy for a style that shows off OSM data, and which is shown on osm.org. I have an interest in the latter, I would probably contribute much less to the former. Remember, Andy chose to put this project under @gravitystorm, not @openstreetmap.

Part of showing off OSM data is good cartography. Part of good cartography is being selective in what to render, which means not continually adding new features to the map.

dieterdreist commented 9 years ago

sent from a phone

Am 07.07.2015 um 10:32 schrieb Paul Norman notifications@github.com:

I consider it a project started by Andy for a style that shows off OSM data, and which is shown on osm.org.

this is not a project started by Andy AFAIK, but the continuation of the OpenStreetMap main map (mapnik, the former "Chilton"-style), the only one published on osm.org that is generated with OSM(F) resources.

matthijsmelissen commented 9 years ago

Part of good cartography is being selective in what to render, which means not continually adding new features to the map.

Do you have any concrete suggestions of features that you'd prefer not to render?

imagico commented 9 years ago

@pnorman - yes, this is Andy's project but being the style that is rendered on the main OSMF infrastructure comes with responsibilities to fairly deal with the wishes from the community. The OSM community needs to have a say in what is rendered on the project infrastructure and what is featured as the main map on the project website. Allowing everyone to directly edit the style would not work of course, so this influence has to be indirect. The current construct with a group of style maintainers responsible for channeling and structuring the requests and suggestions seems to work quite well though. (slight critique here: style maintainers currently all have a fairly technical background and approach to things. This is natural to some extent - merging pull requests and reviewing changes in a primarily technical task. But a more cartographic/geographic view of things can be helpful sometimes. I am not saying this needs to be changed or even that it could be changed, just an observation).

@math1985 - the primary problem about POIs IMO is the lack of a reliable prioritization system. As soon as not all POIs can be shown selection gets arbitrary.

And yes, there are areas where z=19 is overcrowded with POI icons or at least would be if those were fully mapped in these areas:

http://www.openstreetmap.org/#map=19/38.71272/-9.13924 http://www.openstreetmap.org/#map=19/1.29943/103.85460

I for one think one of the most pressing needs in this style is improving overall consistency in styling - features that are similar in reality should be similar in rendering and things that are different should be shown differently. This is often not the case currently but it is very hard to to improve since even small changes in styling can have enormous side effects on the overall look and readability. It is much easier to just add a new feature than to change existing styling without causing a mess. This is probably one of the main causes of feature creep here.

Maybe it would be a good idea to open a new separate issue to collect some ideas for what features could be well removed from the style.

kocio-pl commented 9 years ago

Remember, Andy chose to put this project under @gravitystorm, not @openstreetmap.

I guess this is exactly where most of the tension comes from: the "private" style (designed mostly by few people with strong opinion how should it look like) being default visualisation for the community project. This community is rapidly growing, so I think the clash is unavoidable.

And this is not so clear from the beginning: the license is open, the GitHub makes participation easy, and there are many leaders in FLOSS world, so using private namespace for the project may suggest just the strong leadership. Nothing besides that really warns that you are on kind of the "private" ground and while the leaders are polite, they don't really like being "leaders" at all - they have their own clear vision and just allow others to participate to some extent.

Part of showing off OSM data is good cartography. Part of good cartography is being selective in what to render, which means not continually adding new features to the map.

I understand it. But on the other hand - part of community GIS project is having community influence on all parts of the process.

Try to imagine Wikipedia with lot of people writing things as they like it ("any tags you like"), but what gets showed at the main website are only some featured articles carefully selected by the few "super-editors". Some other thematic selections can be found, but most articles are not shown even if they could be, just because super-editors think the readers would be overwhelmed - no other encyclopaedia contains so detailed articles, anyway, so what's the problem?

Even Wikipedia has some limits what it can contain and what are formal requirements, but if it conforms these general rules, nobody limits it anymore - all the articles are visible.

mboeringa commented 9 years ago

One thing that is really missing in this discussion is the option of the real time creation of "toggable" on/off thematic overlay layers of certain types of objects on the OpenStreetMap Rails web application via Overpass turbo API calls instead of trying to pre-render everything in a style.

This would circumvent the impossible task of trying to display everything, as @gravitystorm justly points out.

This would allow dedicated, specialized thematic rendering, without cluttering up the base map.

There are several existing implementations of this already, but unfortunately, on websites separate from the main Rails web application, and therefore not found or known by the average user. A good example is Marc Zoutendijk's OpenPoiMap:

http://openpoimap.org/

I really think adding such an option to the main Rails application, would lessen the burden on carto and other styles displayed on the main website, and potentially sharply reduce the number of requests for features being rendered.

Of course, this is not a solution for all types of objects, especially the ones needing layered rendering, but POI icons are a definite candidate.

gravitystorm commented 9 years ago

Nothing besides that really warns that you are on kind of the "private" ground and while the leaders are polite, they don't really like being "leaders" at all

This is quite insulting, but I'm not sure if you are aware of how much so? I mean, I find this DEEPLY insulting.

I put a lot of effort into the initial port, and I made sure that the whole project - not just the code - was open to other people to get involved. I've built a whole team here: I've added multiple maintainers - all of whom have the same authority as I do - and we've accepted pull requests from many different people and put a whole ton of effort into helping dozens of new people - including you - get started, learn how things work, get your changes processed and incorporated. But you boldly state that this is still a "private" project with insufficient "community influence"?

And you make these statements on a thread where I've taken one of your complaints and instead of just decreeing new rules I even open things up for discussion and stated "we should come to a collective decision"?

Really?

matkoniecz commented 9 years ago

"private" ground

It is enough to check what is the proportion of proposed pull requests to rejected to see that it is really far away from truth https://github.com/gravitystorm/openstreetmap-carto/pulls?q=is%3Apr+is%3Aclosed And note that many marked as rejected by Github were merged manually or included in other PR.

dieterdreist commented 9 years ago

sent from a phone

Am 07.07.2015 um 12:43 schrieb mboeringa notifications@github.com:

One thing that is really missing in this discussion is the option of the real time creation of "toggable" on/off thematic overlay layers of certain types of objects on the OpenStreetMap Rails web application via Overpass turbo API calls instead of trying to pre-render everything in a style.

this is really a different issue, useful for searching stuff, while prerendering them is the basis for exploring the area (aka see "what it is like")

kocio-pl commented 9 years ago

This is quite insulting, but I'm not sure if you are aware of how much so? I mean, I find this DEEPLY insulting.

I am surprised... and I'm sorry. I still don't feel there was any rudeness involved, because I don't even see it as a personal problem and I don't look for anybody to blame for it.

I already remember one time you felt urged by me and angry because of this, while I had no slightest intention to make anybody feel bad - I was just trying to get some decision because nobody (including you) told anything. How rude is it to ask anybody to just tell anything and discuss things? I didn't expect anyone will "do the work as I said" - "I have no time" or "I decided that I won't fix it" are also perfectly valid answers one can discuss further, if needed. But no answer at all in community project - how do you think a newbie like me feels trying to get to know anything at all? I can make my homework - it's not a shame when you have to learn - but no documentation, no rules and no answers makes learning hard experience, requiring a lot of patience, guessing and being very persistent. I don't like it this way - I prefer open disagreement over being quiet "just in case".

This time is no different: for the start, just to be VERY clear - I respect you personally, your work and your point of view, I just disagree with the degree of being conservative regarding to rendering. I may be totally wrong in how I see your attitude toward leadership - you may love this, I don't know! - but for me it doesn't really look like this. If I put the words between quotation marks and it's not quotation, it means "as if" - I just try to show the problem by comparing, not to judge you or anybody else! I even wrote exactly what I mean by this: (designed mostly by few people with strong opinion how should it look like).

If you don't like the word and find it insulting, I can drop it and describe the problem I see in different words. I think the leadership of community project is HARD - it's "more like herding cats" (as Linus Torvalds said it once) and we all know how obedient cats are... I didn't claim you've done nothing important for this style and project - simply because I don't think this is the case at all! I just want to say the formal things (like the open license and so on) are not everything for a community project to be healthy. The feeling you're welcome and can speak in the open way and being taken seriously is also important part of it. Lack of some important answers (you never answered why you generally don't like more icons, even if it was not just me who asked - at least I'm not aware of it) is not nice, nor constructive. Even in this thread @math1985 asked you personally a few questions, which are important to resolve some things - but unfortunately you omitted them again and instead answered me...

It may be hard to measure the effect of collaborative atmosphere, but let's look how many people are involved in mapping, how many discussion you can find on mailing lists about crafting the right tagging, and how many people discuss the rendering here. Of course, there are more technical difficulties when dealing directly with the code, but I believe if everybody get the message "you can also learn to code or even just discuss the rendering", there would be much more people involved, because many people care for rendering even more than for tagging. Yet they tend to tag for renderer rather than complain here. For me it's at least telling us something. And THIS shows the core of the problem for me - do you see it also?

I'm very happy you started this thread/issue and appreciate it a lot. I also try my best to not make things personal when the problem lies somewhere else IMO - and even this is not enough sometimes, because I clearly failed at showing it the way I really see it, so sorry once again, Andy. Please, try to answer more questions and show us more of the reasons you believe are true, because I see no other way to resolve general problems we have.

kocio-pl commented 9 years ago

@imagico

And yes, there are areas where z=19 is overcrowded with POI icons or at least would be if those were fully mapped in these areas:

http://www.openstreetmap.org/#map=19/38.71272/-9.13924 http://www.openstreetmap.org/#map=19/1.29943/103.85460

Most of big cities in the world will have a lot of shops, but now there are only some places well micromapped and I consider the issue the problem of tomorrow. And even then they will be crowded, but still well readable (so not "overcrowded" in my view) - you have showed probably the highest physically possible density of shops in the city (excluding some marketplaces, I guess), so it won't be worse than that at the highest zoom levels.

There are some things unreadable and overcrowded in the middle scale, however. If we should start with cleaning this style, I would start here for sure. The main roads should be much better soon, thanks to the work of @matkoniecz, but the only other things you can recognize there, are the sea/ocean, airports and city names. It's just much worse than anything related to POIs I ever saw!

But if we remove anything mainly/just to make the most dense places look better, we will hide some things in many more less dense places. The former ones are just a small percent of the latter ones, so effectively we will loose more than we will gain this way.

daganzdaanda commented 9 years ago

@kocio-pl , it sounds as if you would like more leadership, i.e. more rules or decisions from Andy? Or do you just want to hear his opinion more? I think this repo works quite well at the moment, especially since more people have stepped forward as maintainers to share the burden and the workload. Andy is a "leader", but not the only one here, and he's certainly not imposing his will above everybody else. Of course there are some issues that have been open long. But I think that's mostly because everybody here is doing this on their free time, and can't look at all the issues at once. I don't think any issue will be forgotten.

daganzdaanda commented 9 years ago

Back on topic: I agree with most of what @imagico wrote. Something like his checklist could be used to remind people of what a good addition should bring to the style."Scoring" low on that checklist should be the main reason to say no to a new addition. If something has been proven to work in any other multi-purpose style, that should be a plus point, but not a reason to automatically copy the feature into carto. Also, he is right about reminding us to review changes after roll-out. But if something throws up new problems, we usually catch them on the second try.

About icons: I don't see many different icons as a problem. It's definitely better to have the icons than just a dot or the housenumber as before. In very dense situations I'd like to see a z20 someday, or density-based rules. But until then, the one thing that bugs me more is that very high dx between generic dot and Label. I'll open an issue about that.

gravitystorm commented 9 years ago

this is not a project started by Andy AFAIK, but the continuation of the OpenStreetMap main map (mapnik, the former "Chilton"-style), the only one published on osm.org that is generated with OSM(F) resources.

This isn't quite accurate - I know it's nitpicking, but it's important to get right. This is a fork of the "Chilton" style and obviously shows that great cartographic heritage. But I chose to use a different technology, different code hosting, a different way of working (via pull requests) and managing things (i.e. a team of maintainers), and I made new goals for this project, for example reusability of the stylesheets in other forks. This project was running for many months independently, before it also became the default cartography on osm.org

The OSMF is free to choose whatever stylesheets it likes to run on its hardware. It currently runs one style, and it currently runs this one. But at some point there will be a better option, and things will move on again, and a different style will be the default. Compare with the default online editor, for example - there have now been at least four. For the map styles, there have been at least three, if you count white-lines-on-landsat.

I feel that being the default stylesheet does come with responsibilities towards the wider OSM community, and I certainly bear those in mind (e.g. mapper feedback loop), but I wouldn't go as far as to say we're obliged to do things that we disagree with, even if they are popular with non-contributors. For this project, the final decisions are with the maintainers.

Of course the lines between "this project" and the wider community are deliberately blurred - just see my presentations, the workshops that we've run, the ability for anyone to comment or to make PRs! Even the choice of maintainers is open and flexible.

gravitystorm commented 9 years ago
  1. displaying too many different features
  2. using too many different symbols
  3. displaying those symbols on too early zoom levels

@gravitystorm Which of these do you think are problems with our style?

  1. is the biggest problem for me. A map becomes incomprehensible when it is too complicated or requires too much learning to make use of. Even I struggle to recognise features from our map due to the complexity of what we try to show - http://www.openstreetmap.org/#map=18/51.50275/0.00323 showing a wide grey line with white dashes confused me for a while this morning, and I resorted to using the query tool to figure out what the feature actually was.

It's also a burden when we're trying to change things. For example, by showing so many different landuse colours, when we want to change the building colours there's a big list of things to consider. It's not the best example, but I want to make sure people are aware that there is a non-zero burden on stylesheet development for every feature that is added to the style. It's not like we merge the PR and then there's no other consequences.

  1. Is the second biggest problem. Having so many different icons makes it hard to read the map, since in crowded areas they all need viewing to figure out what they are and it's a huge list of things to (subconsciously) re-recognise when you pan the map around. Having a mixture of a few icons and generic symbols was my preferred approach, but I realise that most people preferred lots of icons so we've gone with that approach. It doesn't mean that I like it though :-)
  2. is not a big problem, since it's easily solved. So this is why I'm focussed on the first two issues.
gravitystorm commented 9 years ago

Andy is a "leader", but not the only one here, and he's certainly not imposing his will above everybody else.

I've been trying really hard not to impose my will here over the last few years. I know that I could, since making all the decisions myself works for my other map styles! But a big part of what is important to me is to make this a collaborative project rather than just "Andy's style". So in a lot of discussions I take a back seat, or keep out of it entirely, or wait for a while to see what other people are thinking before I give my own opinions.

i.e. more rules or decisions from Andy? Or do you just want to hear his opinion more?

Good questions.

matkoniecz commented 9 years ago

by showing so many different landuse colours, when we want to change the building colours there's a big list of things to consider

I may confirm that it is a problem. For example it is surprisingly hard to find road colours that will ensure that (a) road is clearly visible across all possible backgrounds (b) rendering is not terrible.

nebulon42 commented 9 years ago

I've been trying really hard not to impose my will here over the last few years. I know that I could, since making all the decisions myself works for my other map styles!

This is a stance that cannot be valued highly enough. Letting things happen is not easy, I'm not sure if I would be capable of that. Kudos also for opening Pandora's box once again and trying to hear people's opinions instead of just changing things. I suggest to watch Andy's talk at SOTM US on YouTube if you haven't done so yet.

Creating a map style is really really hard work. I tried it on a public transport style from scratch, which will be open if I ever finish it. Such a style omits a lot which this style doesn't. Still, at the beginning I was completely overwhelmed by the complexity of the features and the zoom levels. Getting a coherent representation is quite hard and having a design background initially doesn't help much as I discovered. Still I can only recommend to try it.

I think that democratically or procedurally working out which features to add and which not won't work, but I'm happy to be proven wrong. IMO a style cannot be a democracy as design cannot be really a democratic process. But a number of styles could benefit from each other and evolve together. So it would be better not to give this style a "constitution", but do democratize styles in general which is out of scope of this discussion.

Still, that would require increasing the number of available open styles (on osm.org?). Rendering capacity is an important bottleneck here, but maybe a vector tile stack could solve that in some years. Then it might be also possible to split responsibilities for the mapper feedback loop and the first impression on osm.org into two styles, which also would ease things a bit.

kocio-pl commented 9 years ago

@daganzdaanda

@kocio-pl , it sounds as if you would like more leadership, i.e. more rules or decisions from Andy? Or do you just want to hear his opinion more?

Basically, I want to know better what's going on: what are the decisions and the reasons and when decision maker(s) simply abstain or just don't have the resources. I don't care if we call better communication to be "more" or "less" leadership - it would be just better.

Andy is a "leader", but not the only one here, and he's certainly not imposing his will above everybody else.

Of course, I see that he trusts some people and lets me play here too. But I still don't know who decides and to what extent. The repo's owner has the last say on everything? Or maybe all the people with write access decide on their own? Since there are not many more people involved, I can't see how the rest of the community can influence this process, but that is interesting for me too (I'm one of them).

This thread helps me get the picture now, but as we see - these are not straightforward things if one has to explain them at all.

Of course there are some issues that have been open long. But I think that's mostly because everybody here is doing this on their free time, and can't look at all the issues at once. I don't think any issue will be forgotten.

When I think so or I don't care, I just leave such issue as it is. But when I'm not sure or I just think it is really forgotten or got stucked, I try to bring it back on the table. It means that I'm willing to help to resolve it. This is the best moment when somebody might say "I have no time for this, but would like to..." or "nobody cares, so do as you like, if you can".

But if I want something, the repo's owner says he doesn't like it and stops communicating after that, I don't know what to do... I can risk and try to do what I like (and that was what I really did it), but I also do it on my free time, so I'd rather know how big is the risk I take, before I made - say - 99% of the hard work only to be trashed eventually.

It doesn't have to be personal decisions every time, though. If there are some known rules, I would use them happily and just look for some help in this process. But, this way or another, it should be clear for the people what's going on - who decides, what are the rules and how much power they have. The leader is the person who may not code too much, because there can be other coders, he can also let other people take the responsibility for some things (again - look at Linus today), but she should be good at connecting all these dots - and that means communicating and making things clear.

pnorman commented 9 years ago

it sounds as if you would like more leadership, i.e. more rules or decisions from Andy? Or do you just want to hear his opinion more?

I'd like more rules or decisions from Andy.

kocio-pl commented 9 years ago

A map becomes incomprehensible when it is too complicated or requires too much learning to make use of. Even I struggle to recognise features from our map due to the complexity of what we try to show - http://www.openstreetmap.org/#map=18/51.50275/0.00323 showing a wide grey line with white dashes confused me for a while this morning, and I resorted to using the query tool to figure out what the feature actually was.

Sure, I also could not recognize it and eventually I had to use this fallback... :smile: However if I see the shop dot with a name which is not clear, I would have to do it much more frequently to know what kind of shop it really is.

We've already crossed the limit of any reasonable amount of features - list of keys on Wiki page is not complete, yet the table of contents alone takes more than the whole screen on my computer! So we go the other route: colors have meaning and we craft the symbols to be easy to understand and consistent. That works for me even if I don't know all the symbols.

The example you gave is special because it's a complex rendering and we are simply not able to explain all the possibilities that can be (especially this rare). But at least it looks like a kind of road and this is the most important information there.

Let's think how big is our scope - not just the whole globe, not just many scales (from the Earth down to buildings), not even just a lot of data (more than mighty Google wants to touch), but also constantly growing list of tagging schemes. One can not rely on classic cartography entirely under these circumstances, because there was no such things before. Abandon all hope of resorting to keys, you who enter here...

It's also a burden when we're trying to change things. For example, by showing so many different landuse colours, when we want to change the building colours there's a big list of things to consider. It's not the best example, but I want to make sure people are aware that there is a non-zero burden on stylesheet development for every feature that is added to the style. It's not like we merge the PR and then there's no other consequences.

It's always good to know the costs. That's why we try to test and discuss PRs before merging. The unfortunate consequence is that the bar is even higher for anybody trying to modify the style, but we can't just assume everything will be OK. Here I agree with you fully.

  1. Is the second biggest problem. Having so many different icons makes it hard to read the map, since in crowded areas they all need viewing to figure out what they are and it's a huge list of things to (subconsciously) re-recognise when you pan the map around. Having a mixture of a few icons and generic symbols was my preferred approach, but I realise that most people preferred lots of icons so we've gone with that approach. It doesn't mean that I like it though :-)

I haven't noticed such problem and I was not aware it exists at all - I just see the colors and know instantly "oh, that is some eat-and-drink area, so it's probably important part of this town" or "funny, this street has so many book stores!" - and so on.

  1. is not a big problem, since it's easily solved. So this is why I'm focussed on the first two issues.

I don't like messing with zoom levels too much, because we should remember that those dense areas are quite rare and such a universal change will be worse for all the rest. Instead I think we should use as much dynamic solutions as possible - way_area for areas, minimal space between the points and don't-know-what-yet for lines.

brycenesbitt commented 9 years ago
  1. Additional line and area types are a presentation problem. Differences in line shading, color and pattern only go so far, especially since there's no good key or index.
  2. Additional POI types I do not see as leading to a clutter problem. This is doubly true of things with a rendered name, and things like shop with a well defined color scheme.

The examples of "cluttered" areas given so far in this thread seem quite fine. Mostly, they're urban areas with shops. One shop icon per shop seems very very reasonable at the highest zoom. Would anyone suggest, say, skipping shop icons? The natural density of the area has to come into this. If there's a shop every 10 meters then OSM ought have an icon every 10 meters.

dieterdreist commented 9 years ago

2015-07-07 19:48 GMT+02:00 Andy Allan notifications@github.com:

this is not a project started by Andy AFAIK, but the continuation of the OpenStreetMap main map (mapnik, the former "Chilton"-style), the only one published on osm.org that is generated with OSM(F) resources.

This isn't quite accurate - I know it's nitpicking, but it's important to get right. This is a fork of the "Chilton" style and obviously shows that great cartographic heritage. But I chose to use a different technology, different code hosting, a different way of working (via pull requests) and managing things (i.e. a team of maintainers), and I made new goals for this project, for example reusability of the stylesheets in other forks. This project was running for many months independently, before it also became the default cartography on osm.org

Yes, sorry for misreprenting this, you are of course right, this is a fork of the old mapnik style, this is using different technology at the upper layers (carto instead of writing xml, github instead of svn and trac). On the other hand, this work has replaced the old style and is used as the one and only OSMF-OSM map on osm.org, so it stands in a continuity with the old style and is the "official successor". People would likely contribute less to this project if it was perceived as your private project and not featured on the main site.

pnorman commented 9 years ago

This isn't quite accurate - I know it's nitpicking, but it's important to get right. This is a fork of the "Chilton" style and obviously shows that great cartographic heritage. But I chose to use a different technology, different code hosting, a different way of working (via pull requests) and managing things (i.e. a team of maintainers), and I made new goals for this project, for example reusability of the stylesheets in other forks. This project was running for many months independently, before it also became the default cartography on osm.org

I'd probably say that from a cartographic and management standpoint, it's a fork, going in different directions. From a code standpoint, it's a guided rewrite.

As someone who has contributed to both the old osm.xml style and OpenStreetMap Carto, the technical differences (git vs svn, github vs trac, carto vs XML) enable the different ways of project management and cartography.

so it stands in a continuity with the old style and is the "official successor"

People may view it like that, but as Andy has pointed out, that's not what it is from a cartographic goal and project management perspective.

As a partial aside, personally, I look forwards to the day something else is deployed on tile.osm.org and the default on osm.org, because it means that there's something even better for showing off OSM. I also want to raise that bar higher and higher by improving what we have here.

kocio-pl commented 9 years ago

Should we have some discussion platform then - be it a mailing list or subforum - for subjects that are outside the scope of simple cartographic issues and meta-issues (project governing like community-developers communication and technical problems like POI overlays or separate development tree)? I think this would be useful.

brycenesbitt commented 9 years ago

osm-carto has become THE place to discuss rendering. A new mailing list: rendering@openstreetmap.org could be worth a shot to try and even out that discussion: putting other rendering on an equal footing to osm-carto, and relieving some of the pressure on osm-carto.

pnorman commented 9 years ago

A rendering list would be interesting, but I fear it would be like tagging@ and not be particularly useful to those doing work. I doubt style developers would read it regularly in that case.

osm-carto has become THE place to discuss rendering

I wouldn't say so. Most of my general rendering discussions take place elsewhere, generally direct with individuals. There's also stackexchange, help.osm.org, IRC, and other venues. The repo is one of the more active place where rendering discussions happen as this is one of the most actively developed stylesheets, but only a subset of rendering topics are relevant here.

The purpose of the issue tracker is to work on OpenStreetMap Carto. If there's regularly discussion happening here that doesn't further those aims, then we - as maintainers and moderators - need to step in and bring it back on topic or if that doesn't work, close down the issues.

brycenesbitt commented 9 years ago

Yes the tagging@ list has become an unproductive pit. But that does not necessarily mean rendering@ would.

@pnorman your statement that "Most of my general rendering discussions take place elsewhere, generally direct with individuals." highlights the point that OSM rendering is controlled by a small subset of the community, in stark contrast to the data collection and tagging.

Separately I feel that an unintended side effect of osm-carto's relatively curated rendering, is that it holds OSM back from engaging with new mapping communities. Anyone wishing to map a new feature in OSM has to jump through insane hoops to get that work visible to the world.

kocio-pl commented 9 years ago

@pnorman I think you're still talking about clearly defined osm-carto problems, but I've just asked what about "subjects that are outside the scope of simple cartographic issues and meta-issues". They simply don't belong here and this thread shows it's important for the people to talk about more general problems also (I rarely see 12 participants in issues discussion for this repo); and it's clearly community thing, not just something to discuss between individuals.

@brycenesbitt I think forum would be better, because I don't expect so much discussion and it would be also much easier to find this subforum and individual threads (you can pin those most universal, like "OSM rendering basics"). What do you think about this? Do you still prefer mailing list over subforum?

jojo4u commented 9 years ago

I prefer forum.

gravitystorm commented 9 years ago

I'm happy to see people discussing non-openstreetmap-carto topics, either on a mailing list or a forum, but it's unlikely that I would be personally involved in those discussions since that would mean even less time for me to participate here! I would suggest, however, two things:

I realise this topic has itself gone massively off-track. I will now try to bring it back on-track in my next comment.

gravitystorm commented 9 years ago

I made two suggestions for rules to implement, and I've gone through this topic and tried to summarize the feelings of people towards them:

Pro: gravitystorm, imagico, matkoniecz, dieterdreist Anti: kocio-pl, brycenesbitt, math1985

Pro: gravitystorm, matkoniecz Anti: imagico, dieterdreist, math1985

So, not really a consensus either way. Does anyone else have specific guidelines they would like to put forward for consideration? If you aren't proposing a guideline, then for now please refrain from commenting.

kocio-pl commented 9 years ago

For the second rule you can count me in @imagico camp (he summarized it right). But I don't have any guidelines to offer other than "mind the scale" I wrote already.

Maybe you've tried to be specific too early and answering two general questions I asked at the beginning could be useful before going into details?

imagico commented 9 years ago

My suggestion of having a multi-criterion checklist instead of yes/no rules still stands. The purpose of this would be functioning as a helper for contributors as well as maintainers. The idea would be that a new feature suggestion that fails to meet a significant portion of the checklist criteria should ideally not be made in the first place and if made should be quickly rejected by the maintainers without elaborate discussion, ideally with a short statement regarding what criteria it fails.

If this truly helps avoiding pointless discussions and reducing the feature clutter in the style i can't say. But it seems unlikely it would have a significant negative impact.

matthijsmelissen commented 9 years ago

@kocio-pl

  1. What are the most important goals of general map?

The answer to this question is documented in https://github.com/gravitystorm/openstreetmap-carto/blob/master/CARTOGRAPHY.md udner Purposes.

kocio-pl commented 9 years ago

I've just looked at the list made by @imagico (unfortunately I had no time to read it carefully until now) and I can say it sounds reasonably and covers a lot of important factors (it even contains my criterion of scale and touches my second question). As subjective as the answers can be, it may be very useful as a general hint and I like that it's so flexible. I guess guidelines instead of rules are better crafted for such diverse goals and split developers community as we have now. I also could not find anything I disagree with, so I find it to be the best solution for our current lack of regulations. It would be great to make it a section in CARTOGRAPHY.md file probably.

@gravitystorm While I think it's not crucial to engage you in every rendering-related problem around, it would be of course much better if you can easily take part in such discussions. If you are subscribed to osm-dev or plan to do so, I will subscribe there too. I have already asked forum admin about creating new subforum and still got no answer, but if he would agree, I would use it as a general board about rendering OSM data and just send anybody with some particular problems to the list.

EDIT: osm-dev is moderated, which may be suboptimal for any bigger discussion we may have. Maybe general talk list would be better then?

pnorman commented 9 years ago

At this point, I would say we should have no increases to the number of icons on the map, and should aim at decreasing it.

kocio-pl commented 9 years ago

Why do you think so?

IMO more icons are important to make high scale tiles (especially z=19/z=max) really worth having, because typically at this level there simply isn't anything more interesting to see - even buildings are more like a background area there. The centre of a big city may look rather empty without them (especially comparing to overcrowded zoomed out view), let alone any less developed place.

The only real problems are they should be easy to recognize and not too dense. First one is the subject of discussions during testing phase, the second one should be ideally controlled with some dynamic method like minimal distance between the icons for given zoom level.