[erlang-questions] Code complexity and encapsulation

Cobus Carstens cobus.carstens@REDACTED
Mon May 19 12:07:21 CEST 2014


Have a look at R-trees: http://en.wikipedia.org/wiki/R-tree

Regards,
  C

On Monday, 19 May 2014 10:50:05 UTC+2, Suraj Kumar wrote:
>
> Hi,
>
> I'm attempting to build a system whose engineering challenges will 
> classically benefit from the so-called Object-Oriented Programming 
> paradigm: Specifically, that of encapsulation. However, the real complexity 
> of the problem is that there are going to be millions of objects 'existent 
> in space and time' simultaneously. 
>
> The problem domain is analogous to a drawing system: There is a 2D 'canvas 
> onto which several different types of 'shape objects' can be fit into. Once 
> they are all placed on the canvas, it is required that the canvas gets to 
> know all the shapes which seem to coincide with point P (x, y co-ordinates) 
> (or must do similar natured querying of all the shapes without being aware 
> of their details). To find this, the canvas has to ask each shape, in an 
> agnostic/implementation-independent way, whether the object "is_on_point 
> (x,y)".
>
> Thus far, I've gone about modeling each 'shape' as one 'record' in Erlang. 
> I've written some 'utility' functions to determine types of various 
> records. I've also written boilerplate logic in the 'canvas' class to check 
> types and then call appropriate functions. I've also introduced a major 
> convention hell which new programmers will have to understand if they want 
> to add a new type of shape to the system.
>
>
> Is there a cleaner way of modeling this? Should I be using OTP instead of 
> looking for a way to do this in native Erlang? If yes, what would you 
> suggest is a good supervisor/worker-process model so that such 
> encapusulation and complexity can be achieved? Any examples I can look at?
>
> Regards,
>
>   -Suraj
>
> -- 
> An Onion is the Onion skin and the Onion under the skin until the Onion 
> Skin without any Onion underneath.
>
>  
> _____________________________________________________________
> The information contained in this communication is intended solely for the 
> use of the individual or entity to whom it is addressed and others 
> authorized to receive it. It may contain confidential or legally privileged 
> information. If you are not the intended recipient you are hereby notified 
> that any disclosure, copying, distribution or taking any action in reliance 
> on the contents of this information is strictly prohibited and may be 
> unlawful. If you have received this communication in error, please notify 
> us immediately by responding to this email and then delete it from your 
> system. The firm is neither liable for the proper and complete transmission 
> of the information contained in this communication nor for any delay in its 
> receipt.

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://erlang.org/pipermail/erlang-questions/attachments/20140519/3b7f5433/attachment.htm>


More information about the erlang-questions mailing list