8
$\begingroup$

While studying data structures i was told my instructor that even i am given 3 hour/30 days/3 years to find out whether two graphs are isomorphic or not, it is very very complex and even after spending this much amount of time i will not able to figure out clearly whether the given two graphs are isomorphic or not. It is NP-complete problem.

So i got the curiosity that why i am studying it then. What could be the possible applications of such isomorphic graphs which can be solved ?

  • 7
    Graph isomorphism is not known to be NP-complete. Wikipedia says "[i]ts practical applications include primarily cheminformatics, mathematical chemistry (identification of chemical compounds), and electronic design automation (verification of equivalence of various representations of the design of an electronic circuit)."2012-03-15
  • 0
    @QiaochuYuan : well, i was told by my instructor today that it is class NP problem. That's why i posted my confusion here...2012-03-15
  • 9
    "NP" does not mean "NP-complete," although I guess this is an understandable mistake; graph isomorphism is one of the few problems in NP not known to either be in P or be NP-complete along with factoring.2012-03-15
  • 0
    @QiaochuYuan : ok. I am aware of neither NP or NP complex problem. I just heard that so that i posted right here. I am editing the post for it.2012-03-15
  • 1
    The term is "NP-complete", not "NP complex".2012-03-15
  • 0
    What precisely is your question?2012-03-15
  • 0
    @Azoo : what can be the applications of the isomorphic graphs?2012-03-15
  • 0
    You mean what is the application of the isomorphism problem in practice?2012-03-15
  • 0
    In my opinion it is important very often to determine when two graphs are NOT isomorphic, but that is exactly the same problem....2012-03-15

4 Answers 4

9

Bluntly put, the applications are endless...

Before I start the list, I think it will be appropriate to explain something. First of all, all the entities in the world (real and abstract) are connected by some relations. A big part of them is kind of regular or close to regular (e.g. the ordering of natural numbers), and people can and do exploit this very often. However, there is huge, gigantic, infinitely larger (or even more colossal, but I lack words...) class of relations that are weird, curious, peculiar, or even ridiculous. We do not know how to bridle them, so we analyze very tiny, finite parts of them using graphs. Every time when we show an isomorphism between such graphs, a new star starts to shine on the firmament of human thinking power.

Ok, to be more concrete (this list wasn't sorted by any criterion):

  • Cryptography, e.g. zero knowledge proofs.
  • In automata theory: multiple uses, mainly to show that some two languages are equal.
  • In parallel processing, to reason about behaviour of complex systems.
  • In verification of many things: computer programs, logic proofs, or even electronic circuits.
  • In compilers, e.g. to perform various optimizations.
  • In any search engine that can use formulas more sophisticated than words, e.g. in chemistry, biology, but I guess also music and other arts fall into that category as well.
  • Security, i.e. fingerprints scanners, facial scanners, retina scanners and so on.
  • I do not know for sure, but it is highly probable, that any system that performs clustering would benefit from fast graph-isomorphism algorithm, e.g.
    • linking two facebook's accounts of the same person,
    • recognizing web users based on their behavior,
    • recognizing plagiarism in students solutions,
    • :-) I have no idea if there is a Numb3rs episode that uses graph isomorphism problem, but there should be one.
  • Civil engineering, city planning, building interior planning (this may fall into "search" category as well, e.g. recognizing geographic locations with desired properties).
  • Analysis of social structures (special cases may include schools, military, parties, events, etc.), big part of it is search again.
  • Analysis of business relations.
  • I have no idea about medicine (not biology), but there has to be something there, this domain is too wide. Edit: Quick search revealed two (quite obvious...) applications:
    • travel medicine,
    • searching in database or medical images.

Please note, that most of those points are meta-examples, they do not specify particular use, i.e. there are multiple uses in each of those.

  • 1
    If graph isomorphism is an NP-Complete problem which is very hard to solve and takes plenty of time then how the real world applications implement it?2012-03-17
  • 1
    @ankur.trapasiya Contrary to popular believes, algorithms with exponential running time can be very fast (for real-world problem instances), e.g. recent SAT algorithm $O(1.308^n)$ by [Hertli](http://arxiv.org/abs/1103.2165). There are approximating algorithms, e.g. recent $13/9$ for TSP by [Mucha](http://arxiv.org/abs/1108.1130), or even exact polynomial time algorithms for special cases: many for planar graphs, or graphs with bounded treewidth, etc., compare [this](http://arxiv.org/abs/1103.0534) great paper. Finally, heuristics, heuristics, heuristics--after all this is what we humans do ;-)2012-03-17
  • 1
    I would like know above graph isomorphism applications in detail. Can you provide me the sources.2014-03-21
  • 1
    @Gold Quick search revealed multiple matches: [1](http://www.visionbib.com/bibliography/match559s1.html), [2](http://dl.acm.org/citation.cfm?id=1312644), [3](http://www.cs.kent.edu/~jbaker/paper/), [4](http://asdfjournals.com/ijcst/ijcst-issues/ijcst-v1i1y2013/ijcst-0005html-v1i1y2013/) [5](http://www.issb.genopole.fr/~faulon/isomorphism.php), [6](http://ieeexplore.ieee.org/xpl/articleDetails.jsp?arnumber=5376472), [7](http://books.google.pl/books?id=3AcL57MLS0sC&lpg=PA13&ots=oCg0Ry3g7D&dq=graph%20isomorphism%20social&pg=PA13#v=onepage&q=graph%20isomorphism%20social&f=false).2014-03-21
  • 0
    @Gold As for the list from the post, it does not have any source, you hear things, see things, read things, there are discussions at seminars on what people do or plan to do, etc. Many times there's no source at all, and even if there is, I forgot (it's not directly relevant to my research). As for the 7 examples above, I didn't read these papers, so I am unable to comment on their quality.2014-03-21
5

For subgraph isomorphism, there are too many applications; like finding defect in texture. Texture mades of regular images, and if some pieces of given texture has another shape, it can be defect (like hole).

You can divide texture in different pieces and apply graph isomorphism on pieces (Instead of using NP-Complete problem like subgraph isomorphism). Also graph isomorphism is solvable in planar graphs (by knowing that planar graphs tree-width is at most 3 times of its diameter), and texture is planar graph, so this can be a real application in real world.

Also another sample is implicitly related problems, too many problems can be reduced to graph isomorphism (and vise versa). May be this is theoretical result, but in fact, you can find at least one usage of each problem in real world, and this usage can be extended to graph isomorphism.

And finally, I personally like pure science, another real world usage of graph isomorphism is enjoyment of people like me.

5

A good example is the perturbative expansion of Feynman's path integral by summing over Feynman diagrams. This is an infinite series, each stage of which is parameterized by a finite sum over isomorphism classes of certain kinds of graphs. Writing down all isomorphism classes of graphs with certain data requires being able to tell if two graphs are isomorphic.

  • 0
    Sorry to say but I am not having that much knowledge to understand your answer.2012-03-16
  • 0
    @ankur.trapasiya: that's okay, I only have a very primitive understanding of the path integral myself. :)2012-03-16
  • 0
    If graph isomorphism is an NP-Complete problem which is very hard to solve and takes plenty of time then how the real world applications implement it?2012-03-17
  • 0
    @ankur.trapasiya: only the first few terms can be computed.2012-03-17
1

If your question is actually: "what are possible applications of the isomorphism problem", then check this: http://en.wikipedia.org/wiki/Graph_isomorphism_problem#Applications

Another very interesting application of the isomorphism problem is the development of algorithms for fingerprint matching http://euler.mat.ufrgs.br/~trevisan/workgraph/regina.pdf