Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7992215
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 4, 20262026-06-04T13:29:58+00:00 2026-06-04T13:29:58+00:00

I want to put my typed GADT (GExpr) into a hashmap, so I first

  • 0

I want to put my typed GADT (GExpr) into a hashmap, so I first convert it to a corresponding monomorphic ADT (Expr). When I lookup from the hashmap I’m having trouble converting the monomorphic ADT back into a GADT.

The following is a simplified version. Essentially there are two functions, “dim” and “gexprOfExpr” and I can only get one of them to work at once. Is what I’m trying to do impossible?

{-# OPTIONS_GHC -Wall #-}
{-# Language GADTs #-}

type ListDim = [Int]

data DIM0 = DIM0
data DIM1 = DIM1

class Shape sh where
  shapeOfList :: ListDim -> sh

instance Shape DIM0 where
  shapeOfList _ = DIM0
instance Shape DIM1 where
  shapeOfList _ = DIM1

data Expr = EConst ListDim Double
          | ESum ListDim Int

data GExpr sh where
  GRef :: sh -> Int -> GExpr sh
  GConst :: sh -> Double -> GExpr sh
  GSum :: GExpr DIM1 -> GExpr DIM0  -- GADT, this works for "dim"
--  GSum :: GExpr DIM1 -> GExpr sh -- phantom type, this works for "gexprOfExpr"

dim :: GExpr sh -> sh
dim (GRef sh _) = sh
dim (GConst sh _) = sh
dim (GSum _) = DIM0

gexprOfExpr :: Shape sh => Expr -> GExpr sh
gexprOfExpr (EConst lsh x) = GConst (shapeOfList lsh) x
gexprOfExpr (ESum lsh k) = GSum $ GRef (shapeOfList lsh) k

Note: I do know the type I’m trying to recover. If it would help, this would be fine:

gexprOfExpr :: Shape sh => sh -> Expr -> GExpr sh
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-04T13:29:59+00:00Added an answer on June 4, 2026 at 1:29 pm

    Saizan from #haskell gave me a tip that led to an answer. Here’s the working version:

    {-# OPTIONS_GHC -Wall #-}
    {-# Language GADTs #-}
    
    import Data.Maybe
    
    type ListDim = [Int]
    
    data DIM0 = DIM0
    data DIM1 = DIM1
    
    class Shape sh where
      shapeOfList :: ListDim -> sh
      maybeGExprOfExpr :: Expr -> Maybe (GExpr sh)
      maybeGExprOfExpr _ = Nothing
    
    instance Shape DIM0 where
      shapeOfList _ = DIM0
      maybeGExprOfExpr (ESum lsh k) = Just $ GSum $ GRef (shapeOfList lsh) k
      maybeGExprOfExpr _ = Nothing
    
    instance Shape DIM1 where
      shapeOfList _ = DIM1
    
    
    data Expr = EConst ListDim Double
              | ESum ListDim Int
    
    data GExpr sh where
      GRef :: sh -> Int -> GExpr sh
      GConst :: sh -> Double -> GExpr sh
      GSum :: GExpr DIM1 -> GExpr DIM0
    
    dim :: GExpr sh -> sh
    dim (GRef sh _) = sh
    dim (GConst sh _) = sh
    dim (GSum _) = DIM0
    
    gexprOfExpr :: Shape sh => Expr -> GExpr sh
    gexprOfExpr (EConst lsh x) = GConst (shapeOfList lsh) x
    gexprOfExpr e@(ESum _ _) = fromJust $ maybeGExprOfExpr e
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I want to put the apk file into the Kindle Fire storage(through USB cable)
I want to put all my resources into a ClientBundle for easy management. So
I want to put the image url into an input box, after click the
There is an svg file I want put into my cfm page. Safari can
I want put a button on android edittextpreference. I create a custom editextpreference: public
I've projected an Intranet Ajax application and I want put it in a full
hey, hi i want put limit on object creation means a class can have
I want to put two side by side on another (I have three )
I want to put some images in an area at the application start. As
I want to put the name of the loggedin user as the title of

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.