On 3/26/23 1:43 PM, Jen Kris via Python-list wrote:
The base class:


class Constraint(object):

def __init__(self, strength):
         super(Constraint, self).__init__()
         self.strength = strength

def satisfy(self, mark):
         global planner
         self.choose_method(mark)

The subclass:

class UrnaryConstraint(Constraint):

def __init__(self, v, strength):
         super(UrnaryConstraint, self).__init__(strength)
         self.my_output = v
         self.satisfied = False
         self.add_constraint()

        def choose_method(self, mark):
         if self.my_output.mark != mark and \
            Strength.stronger(self.strength, self.my_output.walk_strength):
self.satisfied = True
         else:
             self.satisfied = False

The base class Constraint doesn’t have a "choose_method" class method, but it’s 
called as self.choose_method(mark) on the final line of Constraint shown above.

My question is:  what makes "choose_method" a method of the base class, called 
as self.choose_method instead of UrnaryConstraint.choose_method?  Is it 
super(UrnaryConstraint, self).__init__(strength) or just the fact that Constraint is its 
base class?

Also, this program also has a class BinaryConstraint that is also a subclass of 
Constraint and it also has a choose_method class method that is similar but not 
identical:

def choose_method(self, mark):
     if self.v1.mark == mark:
             if self.v2.mark != mark and Strength.stronger(self.strength, 
self.v2.walk_strength):
                 self.direction = Direction.FORWARD
             else:
                 self.direction = Direction.BACKWARD

When called from Constraint, it uses the one at UrnaryConstraint.  How does it 
know which one to use?

Thanks,

Jen

Perhaps the key point to remember is that when looking up the methods on an object, those methods are part of the object as a whole, not particually "attached" to a given class. When creating the subclass typed object, first the most base class part is built, and all the methods of that class are put into the object, then the next level, and so on, and if a duplicate method is found, it just overwrites the connection. Then when the object is used, we see if there is a method by that name to use, so methods in the base can find methods in subclasses to use.

Perhaps a more modern approach would be to use the concept of an "abstract base" which allows the base to indicate that a derived class needs to define certain abstract methods, (If you need that sort of support, not defining a method might just mean the subclass doesn't support some optional behavior defined by the base)

--
Richard Damon

--
https://mail.python.org/mailman/listinfo/python-list

Reply via email to