Graphic representation of a triangle using ArrayPlotOverlapping ArrayPlotColor inversion using ArrayPlotPlotting Tupper's self-referential formula using ArrayPlotConstructing matrices from quantum states expressed in the bra-ket notationArrayPlot with logarithmic legendIntegral approximation using a matrix operatorNearest non-collinear/non-coplanar pointsHow to boost the performance of a function that approximates a 3D objectSpeeding up filling a matrix when approximating a double integralHow to achieve faster performance on plotting complex valued functions

Has a sovereign Communist government ever run, and conceded loss, on a fair election?

What should I do when a paper is published similar to my PhD thesis without citation?

How do I increase the number of TTY consoles?

Movie: boy escapes the real world and goes to a fantasy world with big furry trolls

Why restrict private health insurance?

Rationale to prefer local variables over instance variables?

The (Easy) Road to Code

Called into a meeting and told we are being made redundant (laid off) and "not to share outside". Can I tell my partner?

Is there a logarithm base for which the logarithm becomes an identity function?

How do you make a gun that shoots melee weapons and/or swords?

How exactly does an Ethernet collision happen in the cable, since nodes use different circuits for Tx and Rx?

Sampling from Gaussian mixture models, when are the sampled data independent?

If sound is a longitudinal wave, why can we hear it if our ears aren't aligned with the propagation direction?

What was so special about The Piano that Ada was willing to do anything to have it?

Under what conditions can the right to be silence be revoked in the USA?

(Codewars) Linked Lists-Sorted Insert

Too soon for a plot twist?

Idiom for feeling after taking risk and someone else being rewarded

Are these two graphs isomorphic? Why/Why not?

Short scifi story where reproductive organs are converted to produce "materials", pregnant protagonist is "found fit" to be a mother

Do black holes violate the conservation of mass?

Graphic representation of a triangle using ArrayPlot

When to use a QR code on a business card?

Computation logic of Partway in TikZ



Graphic representation of a triangle using ArrayPlot


Overlapping ArrayPlotColor inversion using ArrayPlotPlotting Tupper's self-referential formula using ArrayPlotConstructing matrices from quantum states expressed in the bra-ket notationArrayPlot with logarithmic legendIntegral approximation using a matrix operatorNearest non-collinear/non-coplanar pointsHow to boost the performance of a function that approximates a 3D objectSpeeding up filling a matrix when approximating a double integralHow to achieve faster performance on plotting complex valued functions













2












$begingroup$


So I need to write a function which takes natural integer $n$ and returns graphical representation of a matrix $n times n$ using ArrayPlot[].
This matrix has to be pixel approximation of equilateral triangle which get better and better as $n$ increases.



I figured out a set of equilateral triangle points which is $$P=(x,y) in mathbbR^2:y<sqrt3x+fracasqrt32,y<-sqrt3x+fracasqrt32,y>0$$
where $a$ is side length of this triangle.



f1[x_, a_] := -Sqrt[3]*x + (a*Sqrt[3])/2
f2[x_, a_] := Sqrt[3]*x + (a*Sqrt[3])/2
matrix[n_] := ConstantArray[0, n, n]
(...)
drawapprox[n_] := ArrayPlot[matrix[n], Mesh -> True]


So I make zero $n times n$ matrix and I want to put $1$ if a point belongs to $P$ but I don't know how to put together points from the plane to this 0-1 matrix to make it works. After that I just want to use ArrayPlot[] function to draw new 0-1 matrix which represents triangle.



How do I make up the missing (...) part?










share|improve this question







New contributor




apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







$endgroup$
















    2












    $begingroup$


    So I need to write a function which takes natural integer $n$ and returns graphical representation of a matrix $n times n$ using ArrayPlot[].
    This matrix has to be pixel approximation of equilateral triangle which get better and better as $n$ increases.



    I figured out a set of equilateral triangle points which is $$P=(x,y) in mathbbR^2:y<sqrt3x+fracasqrt32,y<-sqrt3x+fracasqrt32,y>0$$
    where $a$ is side length of this triangle.



    f1[x_, a_] := -Sqrt[3]*x + (a*Sqrt[3])/2
    f2[x_, a_] := Sqrt[3]*x + (a*Sqrt[3])/2
    matrix[n_] := ConstantArray[0, n, n]
    (...)
    drawapprox[n_] := ArrayPlot[matrix[n], Mesh -> True]


    So I make zero $n times n$ matrix and I want to put $1$ if a point belongs to $P$ but I don't know how to put together points from the plane to this 0-1 matrix to make it works. After that I just want to use ArrayPlot[] function to draw new 0-1 matrix which represents triangle.



    How do I make up the missing (...) part?










    share|improve this question







    New contributor




    apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.







    $endgroup$














      2












      2








      2





      $begingroup$


      So I need to write a function which takes natural integer $n$ and returns graphical representation of a matrix $n times n$ using ArrayPlot[].
      This matrix has to be pixel approximation of equilateral triangle which get better and better as $n$ increases.



      I figured out a set of equilateral triangle points which is $$P=(x,y) in mathbbR^2:y<sqrt3x+fracasqrt32,y<-sqrt3x+fracasqrt32,y>0$$
      where $a$ is side length of this triangle.



      f1[x_, a_] := -Sqrt[3]*x + (a*Sqrt[3])/2
      f2[x_, a_] := Sqrt[3]*x + (a*Sqrt[3])/2
      matrix[n_] := ConstantArray[0, n, n]
      (...)
      drawapprox[n_] := ArrayPlot[matrix[n], Mesh -> True]


      So I make zero $n times n$ matrix and I want to put $1$ if a point belongs to $P$ but I don't know how to put together points from the plane to this 0-1 matrix to make it works. After that I just want to use ArrayPlot[] function to draw new 0-1 matrix which represents triangle.



      How do I make up the missing (...) part?










      share|improve this question







      New contributor




      apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.







      $endgroup$




      So I need to write a function which takes natural integer $n$ and returns graphical representation of a matrix $n times n$ using ArrayPlot[].
      This matrix has to be pixel approximation of equilateral triangle which get better and better as $n$ increases.



      I figured out a set of equilateral triangle points which is $$P=(x,y) in mathbbR^2:y<sqrt3x+fracasqrt32,y<-sqrt3x+fracasqrt32,y>0$$
      where $a$ is side length of this triangle.



      f1[x_, a_] := -Sqrt[3]*x + (a*Sqrt[3])/2
      f2[x_, a_] := Sqrt[3]*x + (a*Sqrt[3])/2
      matrix[n_] := ConstantArray[0, n, n]
      (...)
      drawapprox[n_] := ArrayPlot[matrix[n], Mesh -> True]


      So I make zero $n times n$ matrix and I want to put $1$ if a point belongs to $P$ but I don't know how to put together points from the plane to this 0-1 matrix to make it works. After that I just want to use ArrayPlot[] function to draw new 0-1 matrix which represents triangle.



      How do I make up the missing (...) part?







      plotting matrix approximation






      share|improve this question







      New contributor




      apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question







      New contributor




      apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question






      New contributor




      apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 4 hours ago









      apoxeiroapoxeiro

      132




      132




      New contributor




      apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      apoxeiro is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.




















          1 Answer
          1






          active

          oldest

          votes


















          3












          $begingroup$

          Update: An alternative method using SparseArray:



          ClearAll[sa, plot2]
          sa[a_] := SparseArray[i_, j_ /;
          a - i < f1[j - (a + Boole[OddQ[a]])/2, a] &&
          a - i < f2[j - (a + Boole[OddQ[a]])/2, a] -> 1, a, a]
          plot2[a_] := ArrayPlot[sa[a], Mesh -> All]

          Row[plot2 /@ Range[3, 21, 2]]


          enter image description here



          Original answer:



          aplot[a_] := ArrayPlot[Boole @ MapIndexed[
          a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
          a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
          matrix[a], 2], Mesh -> All];

          Row[Show[plot@#, Graphics[FaceForm[], EdgeForm[Thick, Red], SSSTriangle[#, #, #]]] & /@
          Range[3, 21, 2]]


          enter image description here



          With a = 101; and Mesh -> None, we get



          a = 1001; 
          ap1001 = ArrayPlot[Boole@MapIndexed[
          a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
          a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
          matrix[a], 2], Mesh -> None];

          Graphics[ap1001[[1]], FaceForm[], EdgeForm[Thick, Red],
          SSSTriangle[1001, 1001, 1001]]


          enter image description here






          share|improve this answer











          $endgroup$












            Your Answer





            StackExchange.ifUsing("editor", function ()
            return StackExchange.using("mathjaxEditing", function ()
            StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
            StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
            );
            );
            , "mathjax-editing");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "387"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: false,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );






            apoxeiro is a new contributor. Be nice, and check out our Code of Conduct.









            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmathematica.stackexchange.com%2fquestions%2f192959%2fgraphic-representation-of-a-triangle-using-arrayplot%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            3












            $begingroup$

            Update: An alternative method using SparseArray:



            ClearAll[sa, plot2]
            sa[a_] := SparseArray[i_, j_ /;
            a - i < f1[j - (a + Boole[OddQ[a]])/2, a] &&
            a - i < f2[j - (a + Boole[OddQ[a]])/2, a] -> 1, a, a]
            plot2[a_] := ArrayPlot[sa[a], Mesh -> All]

            Row[plot2 /@ Range[3, 21, 2]]


            enter image description here



            Original answer:



            aplot[a_] := ArrayPlot[Boole @ MapIndexed[
            a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
            a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
            matrix[a], 2], Mesh -> All];

            Row[Show[plot@#, Graphics[FaceForm[], EdgeForm[Thick, Red], SSSTriangle[#, #, #]]] & /@
            Range[3, 21, 2]]


            enter image description here



            With a = 101; and Mesh -> None, we get



            a = 1001; 
            ap1001 = ArrayPlot[Boole@MapIndexed[
            a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
            a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
            matrix[a], 2], Mesh -> None];

            Graphics[ap1001[[1]], FaceForm[], EdgeForm[Thick, Red],
            SSSTriangle[1001, 1001, 1001]]


            enter image description here






            share|improve this answer











            $endgroup$

















              3












              $begingroup$

              Update: An alternative method using SparseArray:



              ClearAll[sa, plot2]
              sa[a_] := SparseArray[i_, j_ /;
              a - i < f1[j - (a + Boole[OddQ[a]])/2, a] &&
              a - i < f2[j - (a + Boole[OddQ[a]])/2, a] -> 1, a, a]
              plot2[a_] := ArrayPlot[sa[a], Mesh -> All]

              Row[plot2 /@ Range[3, 21, 2]]


              enter image description here



              Original answer:



              aplot[a_] := ArrayPlot[Boole @ MapIndexed[
              a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
              a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
              matrix[a], 2], Mesh -> All];

              Row[Show[plot@#, Graphics[FaceForm[], EdgeForm[Thick, Red], SSSTriangle[#, #, #]]] & /@
              Range[3, 21, 2]]


              enter image description here



              With a = 101; and Mesh -> None, we get



              a = 1001; 
              ap1001 = ArrayPlot[Boole@MapIndexed[
              a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
              a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
              matrix[a], 2], Mesh -> None];

              Graphics[ap1001[[1]], FaceForm[], EdgeForm[Thick, Red],
              SSSTriangle[1001, 1001, 1001]]


              enter image description here






              share|improve this answer











              $endgroup$















                3












                3








                3





                $begingroup$

                Update: An alternative method using SparseArray:



                ClearAll[sa, plot2]
                sa[a_] := SparseArray[i_, j_ /;
                a - i < f1[j - (a + Boole[OddQ[a]])/2, a] &&
                a - i < f2[j - (a + Boole[OddQ[a]])/2, a] -> 1, a, a]
                plot2[a_] := ArrayPlot[sa[a], Mesh -> All]

                Row[plot2 /@ Range[3, 21, 2]]


                enter image description here



                Original answer:



                aplot[a_] := ArrayPlot[Boole @ MapIndexed[
                a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
                a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
                matrix[a], 2], Mesh -> All];

                Row[Show[plot@#, Graphics[FaceForm[], EdgeForm[Thick, Red], SSSTriangle[#, #, #]]] & /@
                Range[3, 21, 2]]


                enter image description here



                With a = 101; and Mesh -> None, we get



                a = 1001; 
                ap1001 = ArrayPlot[Boole@MapIndexed[
                a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
                a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
                matrix[a], 2], Mesh -> None];

                Graphics[ap1001[[1]], FaceForm[], EdgeForm[Thick, Red],
                SSSTriangle[1001, 1001, 1001]]


                enter image description here






                share|improve this answer











                $endgroup$



                Update: An alternative method using SparseArray:



                ClearAll[sa, plot2]
                sa[a_] := SparseArray[i_, j_ /;
                a - i < f1[j - (a + Boole[OddQ[a]])/2, a] &&
                a - i < f2[j - (a + Boole[OddQ[a]])/2, a] -> 1, a, a]
                plot2[a_] := ArrayPlot[sa[a], Mesh -> All]

                Row[plot2 /@ Range[3, 21, 2]]


                enter image description here



                Original answer:



                aplot[a_] := ArrayPlot[Boole @ MapIndexed[
                a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
                a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
                matrix[a], 2], Mesh -> All];

                Row[Show[plot@#, Graphics[FaceForm[], EdgeForm[Thick, Red], SSSTriangle[#, #, #]]] & /@
                Range[3, 21, 2]]


                enter image description here



                With a = 101; and Mesh -> None, we get



                a = 1001; 
                ap1001 = ArrayPlot[Boole@MapIndexed[
                a - #2[[1]] < f1[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &&
                a - #2[[1]] < f2[#2[[2]] - (a + Boole[OddQ[a]])/2, a] &,
                matrix[a], 2], Mesh -> None];

                Graphics[ap1001[[1]], FaceForm[], EdgeForm[Thick, Red],
                SSSTriangle[1001, 1001, 1001]]


                enter image description here







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited 2 hours ago

























                answered 2 hours ago









                kglrkglr

                188k10203421




                188k10203421




















                    apoxeiro is a new contributor. Be nice, and check out our Code of Conduct.









                    draft saved

                    draft discarded


















                    apoxeiro is a new contributor. Be nice, and check out our Code of Conduct.












                    apoxeiro is a new contributor. Be nice, and check out our Code of Conduct.











                    apoxeiro is a new contributor. Be nice, and check out our Code of Conduct.














                    Thanks for contributing an answer to Mathematica Stack Exchange!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    Use MathJax to format equations. MathJax reference.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmathematica.stackexchange.com%2fquestions%2f192959%2fgraphic-representation-of-a-triangle-using-arrayplot%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Mobil Contents History Mobil brands Former Mobil brands Lukoil transaction Mobil UK Mobil Australia Mobil New Zealand Mobil Greece Mobil in Japan Mobil in Canada Mobil Egypt See also References External links Navigation menuwww.mobil.com"Mobil Corporation"the original"Our Houston campus""Business & Finance: Socony-Vacuum Corp.""Popular Mechanics""Lubrite Technologies""Exxon Mobil campus 'clearly happening'""Toledo Blade - Google News Archive Search""The Lion and the Moose - How 2 Executives Pulled off the Biggest Merger Ever""ExxonMobil Press Release""Lubricants""Archived copy"the original"Mobil 1™ and Mobil Super™ motor oil and synthetic motor oil - Mobil™ Motor Oils""Mobil Delvac""Mobil Industrial website""The State of Competition in Gasoline Marketing: The Effects of Refiner Operations at Retail""Mobil Travel Guide to become Forbes Travel Guide""Hotel Rankings: Forbes Merges with Mobil"the original"Jamieson oil industry history""Mobil news""Caltex pumps for control""Watchdog blocks Caltex bid""Exxon Mobil sells service station network""Mobil Oil New Zealand Limited is New Zealand's oldest oil company, with predecessor companies having first established a presence in the country in 1896""ExxonMobil subsidiaries have a business history in New Zealand stretching back more than 120 years. We are involved in petroleum refining and distribution and the marketing of fuels, lubricants and chemical products""Archived copy"the original"Exxon Mobil to Sell Its Japanese Arm for $3.9 Billion""Gas station merger will end Esso and Mobil's long run in Japan""Esso moves to affiliate itself with PC Optimum, no longer Aeroplan, in loyalty point switch""Mobil brand of gas stations to launch in Canada after deal for 213 Loblaws-owned locations""Mobil Nears Completion of Rebranding 200 Loblaw Gas Stations""Learn about ExxonMobil's operations in Egypt""Petrol and Diesel Service Stations in Egypt - Mobil"Official websiteExxon Mobil corporate websiteMobil Industrial official websiteeeeeeeeDA04275022275790-40000 0001 0860 5061n82045453134887257134887257

                    Frič See also Navigation menuinternal link

                    Identify plant with long narrow paired leaves and reddish stems Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?What is this plant with long sharp leaves? Is it a weed?What is this 3ft high, stalky plant, with mid sized narrow leaves?What is this young shrub with opposite ovate, crenate leaves and reddish stems?What is this plant with large broad serrated leaves?Identify this upright branching weed with long leaves and reddish stemsPlease help me identify this bulbous plant with long, broad leaves and white flowersWhat is this small annual with narrow gray/green leaves and rust colored daisy-type flowers?What is this chilli plant?Does anyone know what type of chilli plant this is?Help identify this plant